@colijnit/transaction 12.1.142 → 12.1.143
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 +516 -314
- package/bundles/colijnit-transaction.umd.js.map +1 -1
- package/colijnit-transaction.d.ts +78 -78
- package/colijnit-transaction.metadata.json +1 -1
- package/esm2015/colijnit-transaction.js +79 -79
- package/esm2015/lib/component/add-product/add-product.component.js +31 -2
- package/esm2015/lib/component/checkout/checkout-overview-relation-edit/checkout-overview-relation-edit.component.js +152 -20
- package/esm2015/lib/component/checkout/checkout.module.js +4 -2
- package/esm2015/lib/component/confirmation-dialog/confirmation-dialog.component.js +10 -4
- package/esm2015/lib/component/core/base/components/characteristic-answer/characteristic-answer.component.js +7 -2
- package/esm2015/lib/component/dialog/catalog/dialog-catalog/dialog-catalog.component.js +63 -13
- package/esm2015/lib/component/dialog/catalog/dialog-catalog/dialog-catalog.module.js +5 -3
- package/esm2015/lib/component/dialog/transaction-header/dialog-transaction-header-branch/dialog-transaction-header-branch.component.js +7 -2
- package/esm2015/lib/component/dialog/transaction-header/dialog-transaction-header-delivery-method/dialog-transaction-header-delivery-method.component.js +7 -2
- package/esm2015/lib/component/dialog/transaction-line/dialog-transaction-line-delivery-method/dialog-transaction-line-delivery-method.component.js +7 -2
- package/esm2015/lib/component/dialog/transaction-line/dialog-transaction-line-supplier/dialog-transaction-line-supplier.component.js +7 -2
- package/esm2015/lib/component/dialog/transaction-line/dialog-transaction-line-vat/dialog-transaction-line-vat.component.js +7 -2
- package/esm2015/lib/component/dialog/transaction-line/dialog-transaction-line-warehouse-cc/dialog-transaction-line-warehouse-cc.component.js +7 -2
- package/esm2015/lib/component/relation/relation-address/relation-address.component.js +35 -12
- package/esm2015/lib/component/relation/relation-addresses/relation-addresses.component.js +12 -4
- package/esm2015/lib/component/relation/relation-base.component.js +8 -5
- package/esm2015/lib/component/relation/relation-contact-details/relation-contact-details.component.js +28 -3
- package/esm2015/lib/component/relation/relation-general/relation-general.component.js +27 -113
- package/esm2015/lib/component/relation/relation-general/relation-general.module.js +6 -8
- package/esm2015/lib/component/shared/transaction-article-text/transaction-article-text.component.js +8 -3
- package/esm2015/lib/component/transaction-line-side-panel/transaction-line-side-panel.component.js +2 -2
- package/esm2015/lib/component/transaction-lines/transaction-lines.component.js +2 -2
- package/esm2015/lib/interface/relation-suggestions-request.interface.js +2 -0
- package/esm2015/lib/res/dictionary/dictionaries.js +2 -2
- package/esm2015/lib/service/article-connector.service.js +20 -4
- package/esm2015/lib/service/pending-reason.service.js +3 -3
- package/esm2015/lib/service/transaction-connector-adapter.service.js +5 -5
- package/esm2015/lib/service/transaction-connector.service.js +3 -3
- package/esm2015/lib/service/transaction.service.js +14 -3
- package/esm2015/lib/transaction-version.js +3 -3
- package/fesm2015/colijnit-transaction.js +516 -262
- package/fesm2015/colijnit-transaction.js.map +1 -1
- package/lib/component/add-product/add-product.component.d.ts +1 -0
- package/lib/component/checkout/checkout-overview-relation-edit/checkout-overview-relation-edit.component.d.ts +31 -14
- package/lib/component/checkout/checkout-overview-relation-edit/style/_layout.scss +16 -0
- package/lib/component/checkout/checkout-overview-relation-edit/style/_material-definition.scss +8 -0
- package/lib/component/core/base/components/characteristic-answer/characteristic-answer.component.d.ts +3 -2
- package/lib/component/dialog/catalog/dialog-catalog/dialog-catalog.component.d.ts +9 -0
- package/lib/component/dialog/catalog/dialog-catalog/style/_layout.scss +19 -0
- package/lib/component/dialog/catalog/dialog-catalog/style/_material-definition.scss +2 -1
- package/lib/component/relation/relation-address/relation-address.component.d.ts +10 -7
- package/lib/component/relation/relation-addresses/relation-addresses.component.d.ts +3 -1
- package/lib/component/relation/relation-base.component.d.ts +7 -4
- package/lib/component/relation/relation-contact-details/relation-contact-details.component.d.ts +3 -0
- package/lib/component/relation/relation-general/relation-general.component.d.ts +0 -10
- package/lib/component/relation/relation-general/style/_layout.scss +0 -16
- package/lib/component/relation/relation-general/style/_material-definition.scss +0 -7
- package/lib/component/shared/transaction-article-text/style/_layout.scss +3 -2
- package/lib/component/transaction-header/transaction-header-popup/style/_layout.scss +3 -0
- package/lib/interface/relation-suggestions-request.interface.d.ts +13 -0
- package/lib/res/dictionary/dictionaries.d.ts +1 -0
- package/lib/service/article-connector.service.d.ts +5 -1
- package/lib/service/pending-reason.service.d.ts +1 -1
- package/lib/service/transaction-connector-adapter.service.d.ts +13 -13
- package/lib/service/transaction-connector.service.d.ts +12 -12
- package/lib/service/transaction.service.d.ts +14 -12
- package/package.json +1 -1
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { __awaiter } from "tslib";
|
|
2
|
-
import { Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation } from
|
|
3
|
-
import { TransactionConnectorService } from
|
|
4
|
-
import { DictionaryService } from
|
|
5
|
-
import { FormMasterService } from
|
|
6
|
-
import { RelationBaseComponent } from
|
|
7
|
-
import { Address } from
|
|
8
|
-
import { isNill } from
|
|
9
|
-
import { StringUtils } from
|
|
2
|
+
import { Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation } from '@angular/core';
|
|
3
|
+
import { TransactionConnectorService } from '../../../service/transaction-connector.service';
|
|
4
|
+
import { DictionaryService } from '../../../service/dictionary.service';
|
|
5
|
+
import { FormMasterService } from '@colijnit/corecomponents_v12';
|
|
6
|
+
import { RelationBaseComponent } from '../relation-base.component';
|
|
7
|
+
import { Address } from '@colijnit/relationapi/build/model/address.bo';
|
|
8
|
+
import { isNill } from '@colijnit/ioneconnector/build/utils/function/is-nill.function';
|
|
9
|
+
import { StringUtils } from '@colijnit/ioneconnector/build/utils/string-utils';
|
|
10
10
|
export class RelationAddressComponent extends RelationBaseComponent {
|
|
11
11
|
constructor(_dictionary, _connector, _formMasterService) {
|
|
12
12
|
super();
|
|
@@ -60,14 +60,36 @@ export class RelationAddressComponent extends RelationBaseComponent {
|
|
|
60
60
|
});
|
|
61
61
|
}
|
|
62
62
|
changeHouseNo() {
|
|
63
|
-
if (this.address
|
|
63
|
+
if (this.address) {
|
|
64
64
|
this.address.houseNo = Number(this.address.houseNo);
|
|
65
|
+
this.suggestionRequest.houseNr = this.address.houseNo;
|
|
66
|
+
this.inputChangeForSuggestions.next(this.suggestionRequest);
|
|
65
67
|
}
|
|
66
68
|
}
|
|
67
69
|
handleCountryChange(country) {
|
|
68
70
|
this.countryModel = country;
|
|
69
71
|
if (this.address) {
|
|
70
72
|
this.address.countryId = this.countryModel.code;
|
|
73
|
+
this.suggestionRequest.country = country.description;
|
|
74
|
+
this.inputChangeForSuggestions.next(this.suggestionRequest);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
handlePostalCodeChange() {
|
|
78
|
+
if (this.address) {
|
|
79
|
+
this.suggestionRequest.postalCode = this.address.postalCode;
|
|
80
|
+
this.inputChangeForSuggestions.next(this.suggestionRequest);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
handleStreetChange() {
|
|
84
|
+
if (this.address) {
|
|
85
|
+
this.suggestionRequest.street = this.address.streetName;
|
|
86
|
+
this.inputChangeForSuggestions.next(this.suggestionRequest);
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
handleCityChange() {
|
|
90
|
+
if (this.address) {
|
|
91
|
+
this.suggestionRequest.city = this.address.city;
|
|
92
|
+
this.inputChangeForSuggestions.next(this.suggestionRequest);
|
|
71
93
|
}
|
|
72
94
|
}
|
|
73
95
|
_setSelectedAddress() {
|
|
@@ -100,6 +122,7 @@ RelationAddressComponent.decorators = [
|
|
|
100
122
|
<co-input-text [(model)]="address.postalCode"
|
|
101
123
|
[placeholder]="'POSTAL_CODE' | localize"
|
|
102
124
|
(blur)="checkForPostalCodeCheckError()"
|
|
125
|
+
(modelChange)="handlePostalCodeChange()"
|
|
103
126
|
required
|
|
104
127
|
></co-input-text>
|
|
105
128
|
<co-input-text class="default-width"
|
|
@@ -115,10 +138,10 @@ RelationAddressComponent.decorators = [
|
|
|
115
138
|
></co-input-text>
|
|
116
139
|
</div>
|
|
117
140
|
<div class="relation-address-data-row default">
|
|
118
|
-
<co-input-text [(model)]="address.streetName" [placeholder]="'STREET' | localize" required></co-input-text>
|
|
141
|
+
<co-input-text [(model)]="address.streetName" [placeholder]="'STREET' | localize" required (modelChange)="handleStreetChange()"></co-input-text>
|
|
119
142
|
</div>
|
|
120
143
|
<div class="relation-address-data-row default">
|
|
121
|
-
<co-input-text [(model)]="address.city" [placeholder]="'CITY' | localize" required></co-input-text>
|
|
144
|
+
<co-input-text [(model)]="address.city" [placeholder]="'CITY' | localize" required (modelChange)="handleCityChange()"></co-input-text>
|
|
122
145
|
</div>
|
|
123
146
|
`,
|
|
124
147
|
encapsulation: ViewEncapsulation.None
|
|
@@ -135,4 +158,4 @@ RelationAddressComponent.propDecorators = {
|
|
|
135
158
|
addressChange: [{ type: Output }],
|
|
136
159
|
showClass: [{ type: HostBinding, args: ["class.co-relation-address",] }]
|
|
137
160
|
};
|
|
138
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relation-address.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/relation/relation-address/relation-address.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewEncapsulation} from \"@angular/core\";\nimport {TransactionConnectorService} from \"../../../service/transaction-connector.service\";\nimport {GetPostalCodeRetrievalOutputParams} from \"@colijnit/transactionapi/build/model/get-postal-code-retrieval-output-params\";\nimport {DictionaryService} from \"../../../service/dictionary.service\";\nimport {FormMasterService} from \"@colijnit/corecomponents_v12\";\nimport {RelationBaseComponent} from \"../relation-base.component\";\nimport {Address} from \"@colijnit/relationapi/build/model/address.bo\";\nimport {Country} from \"@colijnit/transactionapi/build/model/country.bo\";\nimport {isNill} from \"@colijnit/ioneconnector/build/utils/function/is-nill.function\";\nimport {StringUtils} from \"@colijnit/ioneconnector/build/utils/string-utils\";\n\n@Component({\n  selector: \"co-relation-address\",\n  template: `\n    <label *ngIf=label [textContent]=\"label | localize\"\n           class=\"checkout-label-h3\"\n    ></label>\n      <div class=\"relation-address-data-row default\">\n        <co-list-of-values [model]=\"countryModel\"\n                           [collection]=\"countries\"\n                           [displayField]=\"'description'\"\n                           [label]=\"'COUNTRY'| localize\"\n                           [required]=\"true\"\n                           (modelChange)=\"handleCountryChange($event)\"\n        ></co-list-of-values>\n      </div>\n      <div class=\"relation-address-data-row default\">\n        <co-input-text [(model)]=\"address.postalCode\"\n                       [placeholder]=\"'POSTAL_CODE' | localize\"\n                       (blur)=\"checkForPostalCodeCheckError()\"\n                       required\n        ></co-input-text>\n        <co-input-text class=\"default-width\"\n                       [(model)]=\"address.houseNo\"\n                       [placeholder]=\"'HOUSE_NO' | localize\"\n                       [digitsOnly]=\"true\"\n                       (blur)=\"checkForPostalCodeCheckError()\"\n                       (modelChange)=\"changeHouseNo()\"\n                       required\n        ></co-input-text>\n        <co-input-text [(model)]=\"address.houseNoAddition\"\n                       [placeholder]=\"'HOUSE_NO_ADDITION' | localize\"\n        ></co-input-text>\n      </div>\n      <div class=\"relation-address-data-row default\">\n        <co-input-text [(model)]=\"address.streetName\" [placeholder]=\"'STREET' | localize\" required></co-input-text>\n      </div>\n      <div class=\"relation-address-data-row default\">\n        <co-input-text [(model)]=\"address.city\" [placeholder]=\"'CITY' | localize\" required></co-input-text>\n      </div>\n  `,\n  encapsulation: ViewEncapsulation.None\n})\nexport class RelationAddressComponent extends RelationBaseComponent implements OnInit {\n  @Input()\n  public set address(value: Address) {\n    this._address = value;\n    this._setSelectedAddress();\n  }\n\n  public get address(): Address {\n    return this._address;\n  }\n\n  @Input()\n  public label: string;\n\n  @Output()\n  public addressChange: EventEmitter<Address> = new EventEmitter<Address>();\n\n  @HostBinding(\"class.co-relation-address\")\n  public showClass(): boolean {\n    return true;\n  }\n\n  public countries: Country[] = [];\n  public fields: Object = {text: \"description\", value: \"code\"};\n  public countryModel: Country;\n\n  public postalCodeCheckErrorMessage: string = \"\";\n  private _prevPostalCodeForCheck: string = \"\";\n  private _prevHouseNoForCheck: number;\n  private _address: Address = new Address();\n\n  public constructor(\n    private _dictionary: DictionaryService,\n    private _connector: TransactionConnectorService,\n    private _formMasterService: FormMasterService\n  ) {\n    super();\n  }\n\n  async ngOnInit(): Promise<void> {\n    this._connector.getCountries().then((countries: Country[]) => {\n      this.countries = countries;\n      this._setSelectedAddress();\n    });\n  }\n\n  public async checkForPostalCodeCheckError(): Promise<void> {\n    if (!this.address.postalCode || isNill(this.address.houseNo)) {\n      this.postalCodeCheckErrorMessage = \"\";\n      return;\n    }\n\n    if (this._prevPostalCodeForCheck !== this.address.postalCode || this._prevHouseNoForCheck !== this.address.houseNo) {\n      this._prevPostalCodeForCheck = this.address.postalCode;\n      this._prevHouseNoForCheck = this.address.houseNo;\n      const postalCodeResponse: GetPostalCodeRetrievalOutputParams = await this._connector.getPostalCodeRetrieval((this.address.postalCode ? this.address.postalCode : \"\"),\n      StringUtils.ParseString(this.address.houseNo));\n      if (postalCodeResponse && postalCodeResponse.isBadAddress) {\n        this.postalCodeCheckErrorMessage = this._dictionary.get(\"UNKNOWN_ADDRESS_CHECK_IT\");\n      } else if (postalCodeResponse.status.toLowerCase().indexOf(\"fout\") < 0) {\n        this.postalCodeCheckErrorMessage = \"\";\n        this.address.streetName = postalCodeResponse.street;\n        this.address.city = postalCodeResponse.city;\n      }\n    }\n  }\n\n  public changeHouseNo(): void {\n    if (this.address.houseNo) {\n      this.address.houseNo = Number(this.address.houseNo);\n    }\n  }\n\n  public handleCountryChange(country: Country): void {\n    this.countryModel = country;\n    if (this.address) {\n      this.address.countryId = this.countryModel.code;\n    }\n  }\n\n  private _setSelectedAddress(): void {\n    if (!this.address || !this.countries) {\n      return;\n    }\n    if (!this.address.countryId) {\n      this.address.countryId = \"NL\";\n    }\n    this.countryModel = this.countries.find(c => c.code === this.address.countryId);\n  }\n}\n"]}
|
|
161
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relation-address.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/relation/relation-address/relation-address.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewEncapsulation} from '@angular/core';\nimport {TransactionConnectorService} from '../../../service/transaction-connector.service';\nimport {GetPostalCodeRetrievalOutputParams} from '@colijnit/transactionapi/build/model/get-postal-code-retrieval-output-params';\nimport {DictionaryService} from '../../../service/dictionary.service';\nimport {FormMasterService} from '@colijnit/corecomponents_v12';\nimport {RelationBaseComponent} from '../relation-base.component';\nimport {Address} from '@colijnit/relationapi/build/model/address.bo';\nimport {Country} from '@colijnit/transactionapi/build/model/country.bo';\nimport {isNill} from '@colijnit/ioneconnector/build/utils/function/is-nill.function';\nimport {StringUtils} from '@colijnit/ioneconnector/build/utils/string-utils';\n\n@Component({\n  selector: \"co-relation-address\",\n  template: `\n    <label *ngIf=label [textContent]=\"label | localize\"\n           class=\"checkout-label-h3\"\n    ></label>\n      <div class=\"relation-address-data-row default\">\n        <co-list-of-values [model]=\"countryModel\"\n                           [collection]=\"countries\"\n                           [displayField]=\"'description'\"\n                           [label]=\"'COUNTRY'| localize\"\n                           [required]=\"true\"\n                           (modelChange)=\"handleCountryChange($event)\"\n        ></co-list-of-values>\n      </div>\n      <div class=\"relation-address-data-row default\">\n        <co-input-text [(model)]=\"address.postalCode\"\n                       [placeholder]=\"'POSTAL_CODE' | localize\"\n                       (blur)=\"checkForPostalCodeCheckError()\"\n                       (modelChange)=\"handlePostalCodeChange()\"\n                       required\n        ></co-input-text>\n        <co-input-text class=\"default-width\"\n                       [(model)]=\"address.houseNo\"\n                       [placeholder]=\"'HOUSE_NO' | localize\"\n                       [digitsOnly]=\"true\"\n                       (blur)=\"checkForPostalCodeCheckError()\"\n                       (modelChange)=\"changeHouseNo()\"\n                       required\n        ></co-input-text>\n        <co-input-text [(model)]=\"address.houseNoAddition\"\n                       [placeholder]=\"'HOUSE_NO_ADDITION' | localize\"\n        ></co-input-text>\n      </div>\n      <div class=\"relation-address-data-row default\">\n        <co-input-text [(model)]=\"address.streetName\" [placeholder]=\"'STREET' | localize\" required (modelChange)=\"handleStreetChange()\"></co-input-text>\n      </div>\n      <div class=\"relation-address-data-row default\">\n        <co-input-text [(model)]=\"address.city\" [placeholder]=\"'CITY' | localize\" required (modelChange)=\"handleCityChange()\"></co-input-text>\n      </div>\n  `,\n  encapsulation: ViewEncapsulation.None\n})\nexport class RelationAddressComponent extends RelationBaseComponent implements OnInit {\n  @Input()\n  public set address(value: Address) {\n    this._address = value;\n    this._setSelectedAddress();\n  }\n\n  public get address(): Address {\n    return this._address;\n  }\n\n  @Input()\n  public label: string;\n\n  @Output()\n  public addressChange: EventEmitter<Address> = new EventEmitter<Address>();\n\n  @HostBinding(\"class.co-relation-address\")\n  public showClass(): boolean {\n    return true;\n  }\n\n  public countries: Country[] = [];\n  public fields: Object = {text: \"description\", value: \"code\"};\n  public countryModel: Country;\n\n  public postalCodeCheckErrorMessage: string = \"\";\n  private _prevPostalCodeForCheck: string = \"\";\n  private _prevHouseNoForCheck: number;\n  private _address: Address = new Address();\n\n  public constructor(\n    private _dictionary: DictionaryService,\n    private _connector: TransactionConnectorService,\n    private _formMasterService: FormMasterService\n  ) {\n    super();\n  }\n\n  async ngOnInit(): Promise<void> {\n    this._connector.getCountries().then((countries: Country[]) => {\n      this.countries = countries;\n      this._setSelectedAddress();\n    });\n  }\n\n  public async checkForPostalCodeCheckError(): Promise<void> {\n    if (!this.address.postalCode || isNill(this.address.houseNo)) {\n      this.postalCodeCheckErrorMessage = \"\";\n      return;\n    }\n\n    if (this._prevPostalCodeForCheck !== this.address.postalCode || this._prevHouseNoForCheck !== this.address.houseNo) {\n      this._prevPostalCodeForCheck = this.address.postalCode;\n      this._prevHouseNoForCheck = this.address.houseNo;\n      const postalCodeResponse: GetPostalCodeRetrievalOutputParams = await this._connector.getPostalCodeRetrieval((this.address.postalCode ? this.address.postalCode : \"\"),\n      StringUtils.ParseString(this.address.houseNo));\n      if (postalCodeResponse && postalCodeResponse.isBadAddress) {\n        this.postalCodeCheckErrorMessage = this._dictionary.get(\"UNKNOWN_ADDRESS_CHECK_IT\");\n      } else if (postalCodeResponse.status.toLowerCase().indexOf(\"fout\") < 0) {\n        this.postalCodeCheckErrorMessage = \"\";\n        this.address.streetName = postalCodeResponse.street;\n        this.address.city = postalCodeResponse.city;\n      }\n    }\n  }\n\n  public changeHouseNo(): void {\n    if (this.address) {\n      this.address.houseNo = Number(this.address.houseNo);\n      this.suggestionRequest.houseNr = this.address.houseNo;\n      this.inputChangeForSuggestions.next(this.suggestionRequest);\n    }\n  }\n\n  public handleCountryChange(country: Country): void {\n    this.countryModel = country;\n    if (this.address) {\n      this.address.countryId = this.countryModel.code;\n      this.suggestionRequest.country = country.description;\n      this.inputChangeForSuggestions.next(this.suggestionRequest);\n    }\n  }\n\n  public handlePostalCodeChange(): void {\n    if (this.address) {\n      this.suggestionRequest.postalCode = this.address.postalCode;\n      this.inputChangeForSuggestions.next(this.suggestionRequest);\n    }\n  }\n\n  public handleStreetChange(): void {\n    if (this.address) {\n      this.suggestionRequest.street = this.address.streetName;\n      this.inputChangeForSuggestions.next(this.suggestionRequest);\n    }\n  }\n\n  public handleCityChange(): void {\n    if (this.address) {\n      this.suggestionRequest.city = this.address.city;\n      this.inputChangeForSuggestions.next(this.suggestionRequest);\n    }\n  }\n\n  private _setSelectedAddress(): void {\n    if (!this.address || !this.countries) {\n      return;\n    }\n    if (!this.address.countryId) {\n      this.address.countryId = \"NL\";\n    }\n    this.countryModel = this.countries.find(c => c.code === this.address.countryId);\n  }\n}\n"]}
|
|
@@ -7,11 +7,13 @@ import { Address } from '@colijnit/relationapi/build/model/address.bo';
|
|
|
7
7
|
import { AddressType } from '@colijnit/relationapi/build/enum/address-type.enum';
|
|
8
8
|
import { RelationService } from '../../../service/relation.service';
|
|
9
9
|
import { BusinessObjectFactory } from '@colijnit/ioneconnector/build/service/business-object-factory';
|
|
10
|
+
import { IconCacheService } from "../../../service/icon-cache.service";
|
|
10
11
|
export class RelationAddressesComponent extends RelationBaseComponent {
|
|
11
|
-
constructor(_formMasterService, _relationService) {
|
|
12
|
+
constructor(_formMasterService, _relationService, iconCacheService) {
|
|
12
13
|
super();
|
|
13
14
|
this._formMasterService = _formMasterService;
|
|
14
15
|
this._relationService = _relationService;
|
|
16
|
+
this.iconCacheService = iconCacheService;
|
|
15
17
|
this.icons = Icon;
|
|
16
18
|
this.readonly = false;
|
|
17
19
|
this.addresses = [];
|
|
@@ -110,7 +112,12 @@ RelationAddressesComponent.decorators = [
|
|
|
110
112
|
</ng-template>
|
|
111
113
|
<ng-template #templateFooter>
|
|
112
114
|
<div class="co-dialog-footer-button-wrapper">
|
|
113
|
-
<co-button
|
|
115
|
+
<co-button class="save-button"
|
|
116
|
+
[iconData]="iconCacheService.getIcon(icons.CheckDuotone)"
|
|
117
|
+
(click)="submitForm()"></co-button>
|
|
118
|
+
<co-button class="close-button"
|
|
119
|
+
[iconData]="iconCacheService.getIcon(icons.Crossskinny)"
|
|
120
|
+
(click)="showEditAddressDialog = false"></co-button>
|
|
114
121
|
</div>
|
|
115
122
|
</ng-template>
|
|
116
123
|
</co-dialog>
|
|
@@ -123,7 +130,8 @@ RelationAddressesComponent.decorators = [
|
|
|
123
130
|
];
|
|
124
131
|
RelationAddressesComponent.ctorParameters = () => [
|
|
125
132
|
{ type: FormMasterService },
|
|
126
|
-
{ type: RelationService }
|
|
133
|
+
{ type: RelationService },
|
|
134
|
+
{ type: IconCacheService }
|
|
127
135
|
];
|
|
128
136
|
RelationAddressesComponent.propDecorators = {
|
|
129
137
|
readonly: [{ type: Input }],
|
|
@@ -134,4 +142,4 @@ RelationAddressesComponent.propDecorators = {
|
|
|
134
142
|
selectedNawNrChange: [{ type: Output }],
|
|
135
143
|
showClass: [{ type: HostBinding, args: ["class.co-relation-addresses",] }]
|
|
136
144
|
};
|
|
137
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relation-addresses.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/relation/relation-addresses/relation-addresses.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation} from '@angular/core';\r\nimport {Icon} from '../../../enum/icon.enum';\r\nimport {RelationBaseComponent} from '../relation-base.component';\r\nimport {FormMasterService} from '@colijnit/corecomponents_v12';\r\nimport {Address} from '@colijnit/relationapi/build/model/address.bo';\r\nimport {AddressType} from '@colijnit/relationapi/build/enum/address-type.enum';\r\nimport {RelationService} from '../../../service/relation.service';\r\nimport {BusinessObjectFactory} from '@colijnit/ioneconnector/build/service/business-object-factory';\r\n\r\n@Component({\r\n  selector: \"co-relation-addresses\",\r\n  template: `\r\n    <div class=\"default-data-row\">\r\n      <co-carousel *ngIf=\"addresses && addresses.length > 1\">\r\n        <co-relation-address-tile #carouselItem *ngFor=\"let address of addresses | filter:'isActive':true; let index = index\"\r\n                                  [address]=\"address\"\r\n                                  [readonly]=\"readonly\"\r\n                                  [selected]=\"selectedNawNr === address.nawNr\"\r\n                                  (editAddressClicked)=\"editAddress($event)\"\r\n                                  (selectedChange)=\"changeAddress($event)\"\r\n        ></co-relation-address-tile>\r\n      </co-carousel>\r\n    </div>\r\n    <div class=\"default-data-row\" *ngIf=\"!readonly\">\r\n      <div class=\"relation-address-new\">\r\n        <icon class=\"relation-address-icon\" [icon]=\"icons.ArrowPointRight\"></icon>\r\n        <div [textContent]=\"'ADDRESS_ADD' | localize\" (click)=\"showNewAddressDialog()\"></div>\r\n      </div>\r\n    </div>\r\n    <co-dialog class=\"dialog-relation-addresses-create-address\" *ngIf=\"showEditAddressDialog\"\r\n               [footerTemplate]=\"templateFooter\"\r\n               [headerTemplate]=\"templateHeader\"\r\n               (closeClick)=\"showEditAddressDialog = false\"\r\n    >\r\n      <co-form>\r\n        <co-relation-address\r\n          [relation]=\"relation\"\r\n          [(address)]=\"addressToEdit\"\r\n        ></co-relation-address>\r\n      </co-form>\r\n      <ng-template #templateHeader>\r\n        <div class=\"co-dialog-header-title\" [textContent]=\"'NEW_ADDRESS' | localize\"></div>\r\n      </ng-template>\r\n      <ng-template #templateFooter>\r\n        <div class=\"co-dialog-footer-button-wrapper\">\r\n          <co-button [label]=\"'OK' | localize\" (click)=\"submitForm()\"></co-button>\r\n        </div>\r\n      </ng-template>\r\n    </co-dialog>\r\n  `,\r\n  providers: [\r\n    FormMasterService\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class RelationAddressesComponent extends RelationBaseComponent implements AfterViewInit {\r\n  public readonly icons: typeof Icon = Icon;\r\n\r\n  @Input()\r\n  public readonly: boolean = false;\r\n\r\n  @Input()\r\n  public addresses: Address[] = [];\r\n\r\n  @Input()\r\n  public showOnlyActive: boolean = true;\r\n\r\n  @Input()\r\n  public type: AddressType = AddressType.DeliveryAddress;\r\n\r\n  @Input()\r\n  public selectedNawNr: number = 0;\r\n\r\n  @Output()\r\n  public selectedNawNrChange: EventEmitter<number> = new EventEmitter<number>();\r\n\r\n  @HostBinding(\"class.co-relation-addresses\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public showEditAddressDialog: boolean = false;\r\n  public addressToEdit: Address;\r\n\r\n  private _boFactory: BusinessObjectFactory = new BusinessObjectFactory();\r\n\r\n  constructor(\r\n    private _formMasterService: FormMasterService,\r\n    private _relationService: RelationService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    if (!this.selectedNawNr && this.addresses && this.addresses.length > 0) {\r\n      this.changeAddress(this.addresses[0]);\r\n    }\r\n  }\r\n\r\n  public submitForm(): void {\r\n    if (this._formMasterService.submitSlaves()) {\r\n      this.saveAddress(this.addressToEdit);\r\n    }\r\n  }\r\n\r\n  public async saveAddress(address: Address): Promise<void> {\r\n    address.relationId = this.relation.relationId;\r\n    address.addressType = this.type;\r\n    if (!address.nawNr) { // new address\r\n      address.startDate = new Date();\r\n      address.sequence = this.relation.getNextAddressSequence();\r\n      const savedAddress: Address = await this._relationService.insertAddress(address);\r\n      this.relation.addresses.push(savedAddress);\r\n      this.changeAddress(savedAddress);\r\n    } else {\r\n      const savedAddress: Address = await this._relationService.updateAddress(address);\r\n      const idx: number = this.relation.addresses.findIndex(a => a.nawNr === address.nawNr);\r\n      if (idx > -1) {\r\n        this.relation.addresses[idx] = savedAddress;\r\n      }\r\n    }\r\n    this.showEditAddressDialog = false;\r\n  }\r\n\r\n  public showNewAddressDialog(): void {\r\n    this.addressToEdit = new Address();\r\n    this.showEditAddressDialog = true;\r\n  }\r\n\r\n  public changeAddress(address: Address): void {\r\n    if (address && !this.readonly) {\r\n      this.selectedNawNr = address.nawNr;\r\n      this.selectedNawNrChange.emit(this.selectedNawNr);\r\n    }\r\n  }\r\n\r\n  public editAddress(addr: Address): void {\r\n    if (!this.readonly) {\r\n      this.addressToEdit = <Address><unknown>this._boFactory.makeWithRawBackendData(Address, addr);\r\n      this.showEditAddressDialog = true;\r\n    }\r\n  }\r\n}\r\n"]}
|
|
145
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relation-addresses.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/relation/relation-addresses/relation-addresses.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation} from '@angular/core';\r\nimport {Icon} from '../../../enum/icon.enum';\r\nimport {RelationBaseComponent} from '../relation-base.component';\r\nimport {FormMasterService} from '@colijnit/corecomponents_v12';\r\nimport {Address} from '@colijnit/relationapi/build/model/address.bo';\r\nimport {AddressType} from '@colijnit/relationapi/build/enum/address-type.enum';\r\nimport {RelationService} from '../../../service/relation.service';\r\nimport {BusinessObjectFactory} from '@colijnit/ioneconnector/build/service/business-object-factory';\r\nimport {IconCacheService} from \"../../../service/icon-cache.service\";\r\n\r\n@Component({\r\n  selector: \"co-relation-addresses\",\r\n  template: `\r\n    <div class=\"default-data-row\">\r\n      <co-carousel *ngIf=\"addresses && addresses.length > 1\">\r\n        <co-relation-address-tile #carouselItem *ngFor=\"let address of addresses | filter:'isActive':true; let index = index\"\r\n                                  [address]=\"address\"\r\n                                  [readonly]=\"readonly\"\r\n                                  [selected]=\"selectedNawNr === address.nawNr\"\r\n                                  (editAddressClicked)=\"editAddress($event)\"\r\n                                  (selectedChange)=\"changeAddress($event)\"\r\n        ></co-relation-address-tile>\r\n      </co-carousel>\r\n    </div>\r\n    <div class=\"default-data-row\" *ngIf=\"!readonly\">\r\n      <div class=\"relation-address-new\">\r\n        <icon class=\"relation-address-icon\" [icon]=\"icons.ArrowPointRight\"></icon>\r\n        <div [textContent]=\"'ADDRESS_ADD' | localize\" (click)=\"showNewAddressDialog()\"></div>\r\n      </div>\r\n    </div>\r\n    <co-dialog class=\"dialog-relation-addresses-create-address\" *ngIf=\"showEditAddressDialog\"\r\n               [footerTemplate]=\"templateFooter\"\r\n               [headerTemplate]=\"templateHeader\"\r\n               (closeClick)=\"showEditAddressDialog = false\"\r\n    >\r\n      <co-form>\r\n        <co-relation-address\r\n          [relation]=\"relation\"\r\n          [(address)]=\"addressToEdit\"\r\n        ></co-relation-address>\r\n      </co-form>\r\n      <ng-template #templateHeader>\r\n        <div class=\"co-dialog-header-title\" [textContent]=\"'NEW_ADDRESS' | localize\"></div>\r\n      </ng-template>\r\n      <ng-template #templateFooter>\r\n        <div class=\"co-dialog-footer-button-wrapper\">\r\n          <co-button class=\"save-button\"\r\n                     [iconData]=\"iconCacheService.getIcon(icons.CheckDuotone)\"\r\n                     (click)=\"submitForm()\"></co-button>\r\n          <co-button class=\"close-button\"\r\n                     [iconData]=\"iconCacheService.getIcon(icons.Crossskinny)\"\r\n                     (click)=\"showEditAddressDialog = false\"></co-button>\r\n        </div>\r\n      </ng-template>\r\n    </co-dialog>\r\n  `,\r\n  providers: [\r\n    FormMasterService\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class RelationAddressesComponent extends RelationBaseComponent implements AfterViewInit {\r\n  public readonly icons: typeof Icon = Icon;\r\n\r\n  @Input()\r\n  public readonly: boolean = false;\r\n\r\n  @Input()\r\n  public addresses: Address[] = [];\r\n\r\n  @Input()\r\n  public showOnlyActive: boolean = true;\r\n\r\n  @Input()\r\n  public type: AddressType = AddressType.DeliveryAddress;\r\n\r\n  @Input()\r\n  public selectedNawNr: number = 0;\r\n\r\n  @Output()\r\n  public selectedNawNrChange: EventEmitter<number> = new EventEmitter<number>();\r\n\r\n  @HostBinding(\"class.co-relation-addresses\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public showEditAddressDialog: boolean = false;\r\n  public addressToEdit: Address;\r\n\r\n  private _boFactory: BusinessObjectFactory = new BusinessObjectFactory();\r\n\r\n  constructor(\r\n    private _formMasterService: FormMasterService,\r\n    private _relationService: RelationService,\r\n    public iconCacheService: IconCacheService,\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    if (!this.selectedNawNr && this.addresses && this.addresses.length > 0) {\r\n      this.changeAddress(this.addresses[0]);\r\n    }\r\n  }\r\n\r\n  public submitForm(): void {\r\n    if (this._formMasterService.submitSlaves()) {\r\n      this.saveAddress(this.addressToEdit);\r\n    }\r\n  }\r\n\r\n  public async saveAddress(address: Address): Promise<void> {\r\n    address.relationId = this.relation.relationId;\r\n    address.addressType = this.type;\r\n    if (!address.nawNr) { // new address\r\n      address.startDate = new Date();\r\n      address.sequence = this.relation.getNextAddressSequence();\r\n      const savedAddress: Address = await this._relationService.insertAddress(address);\r\n      this.relation.addresses.push(savedAddress);\r\n      this.changeAddress(savedAddress);\r\n    } else {\r\n      const savedAddress: Address = await this._relationService.updateAddress(address);\r\n      const idx: number = this.relation.addresses.findIndex(a => a.nawNr === address.nawNr);\r\n      if (idx > -1) {\r\n        this.relation.addresses[idx] = savedAddress;\r\n      }\r\n    }\r\n    this.showEditAddressDialog = false;\r\n  }\r\n\r\n  public showNewAddressDialog(): void {\r\n    this.addressToEdit = new Address();\r\n    this.showEditAddressDialog = true;\r\n  }\r\n\r\n  public changeAddress(address: Address): void {\r\n    if (address && !this.readonly) {\r\n      this.selectedNawNr = address.nawNr;\r\n      this.selectedNawNrChange.emit(this.selectedNawNr);\r\n    }\r\n  }\r\n\r\n  public editAddress(addr: Address): void {\r\n    if (!this.readonly) {\r\n      this.addressToEdit = <Address><unknown>this._boFactory.makeWithRawBackendData(Address, addr);\r\n      this.showEditAddressDialog = true;\r\n    }\r\n  }\r\n}\r\n"]}
|
|
@@ -1,11 +1,13 @@
|
|
|
1
|
-
import { Directive, EventEmitter, Input, Output } from
|
|
2
|
-
import { NULL_RELATION_OBJECT } from
|
|
3
|
-
import { RelationKind } from
|
|
1
|
+
import { Directive, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { NULL_RELATION_OBJECT } from '@colijnit/relationapi/build/model/nul-relation-object';
|
|
3
|
+
import { RelationKind } from '@colijnit/relationapi/build/enum/relation-kind.enum';
|
|
4
4
|
export class RelationBaseComponent {
|
|
5
5
|
constructor() {
|
|
6
6
|
this.relKind = RelationKind;
|
|
7
7
|
this.relationChange = new EventEmitter();
|
|
8
|
+
this.inputChangeForSuggestions = new EventEmitter();
|
|
8
9
|
this._relation = NULL_RELATION_OBJECT;
|
|
10
|
+
this.suggestionRequest = {};
|
|
9
11
|
}
|
|
10
12
|
set relation(value) {
|
|
11
13
|
if (value) {
|
|
@@ -28,6 +30,7 @@ RelationBaseComponent.decorators = [
|
|
|
28
30
|
];
|
|
29
31
|
RelationBaseComponent.propDecorators = {
|
|
30
32
|
relation: [{ type: Input }],
|
|
31
|
-
relationChange: [{ type: Output }]
|
|
33
|
+
relationChange: [{ type: Output }],
|
|
34
|
+
inputChangeForSuggestions: [{ type: Output }]
|
|
32
35
|
};
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVsYXRpb24tYmFzZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90cmFuc2FjdGlvbi9zcmMvbGliL2NvbXBvbmVudC9yZWxhdGlvbi9yZWxhdGlvbi1iYXNlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3JFLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLHVEQUF1RCxDQUFDO0FBRzNGLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxxREFBcUQsQ0FBQztBQUlqRixNQUFNLE9BQWdCLHFCQUFxQjtJQUQzQztRQUVrQixZQUFPLEdBQXdCLFlBQVksQ0FBQztRQWVyRCxtQkFBYyxHQUFrQyxJQUFJLFlBQVksRUFBbUIsQ0FBQztRQUdwRiw4QkFBeUIsR0FBNkMsSUFBSSxZQUFZLEVBQThCLENBQUM7UUFNcEgsY0FBUyxHQUFvQixvQkFBb0IsQ0FBQztRQUVoRCxzQkFBaUIsR0FBK0IsRUFBRSxDQUFDO0lBTS9ELENBQUM7SUE5QkMsSUFDVyxRQUFRLENBQUMsS0FBc0I7UUFDeEMsSUFBSSxLQUFLLEVBQUU7WUFDVCxJQUFJLENBQUMsU0FBUyxHQUFHLEtBQUssQ0FBQztZQUN2QixJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7U0FDcEI7SUFDSCxDQUFDO0lBRUQsSUFBVyxRQUFRO1FBQ2pCLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQztJQUN4QixDQUFDO0lBUUQsSUFBVyxrQkFBa0I7UUFDM0IsT0FBTyxJQUFJLENBQUMsU0FBUyxJQUFJLElBQUksQ0FBQyxTQUErQixDQUFDO0lBQ2hFLENBQUM7SUFNRCxtQ0FBbUM7SUFDekIsV0FBVztJQUVyQixDQUFDOzs7WUFqQ0YsU0FBUzs7O3VCQUlQLEtBQUs7NkJBWUwsTUFBTTt3Q0FHTixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtEaXJlY3RpdmUsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7TlVMTF9SRUxBVElPTl9PQkpFQ1R9IGZyb20gJ0Bjb2xpam5pdC9yZWxhdGlvbmFwaS9idWlsZC9tb2RlbC9udWwtcmVsYXRpb24tb2JqZWN0JztcclxuaW1wb3J0IHtDdXN0b21lckZ1bGxPYmplY3R9IGZyb20gJ0Bjb2xpam5pdC9yZWxhdGlvbmFwaS9idWlsZC9tb2RlbC9jdXN0b21lci1mdWxsLW9iamVjdC5ibyc7XHJcbmltcG9ydCB7UmVsYXRpb25BbnlUeXBlfSBmcm9tICdAY29saWpuaXQvcmVsYXRpb25hcGkvYnVpbGQvbW9kZWwvcmVsYXRpb24tYW55LXR5cGUnO1xyXG5pbXBvcnQge1JlbGF0aW9uS2luZH0gZnJvbSAnQGNvbGlqbml0L3JlbGF0aW9uYXBpL2J1aWxkL2VudW0vcmVsYXRpb24ta2luZC5lbnVtJztcclxuaW1wb3J0IHtSZWxhdGlvblN1Z2dlc3Rpb25zUmVxdWVzdH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlL3JlbGF0aW9uLXN1Z2dlc3Rpb25zLXJlcXVlc3QuaW50ZXJmYWNlJztcclxuXHJcbkBEaXJlY3RpdmUoKVxyXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgUmVsYXRpb25CYXNlQ29tcG9uZW50IHtcclxuICBwdWJsaWMgcmVhZG9ubHkgcmVsS2luZDogdHlwZW9mIFJlbGF0aW9uS2luZCA9IFJlbGF0aW9uS2luZDtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgc2V0IHJlbGF0aW9uKHZhbHVlOiBSZWxhdGlvbkFueVR5cGUpIHtcclxuICAgIGlmICh2YWx1ZSkge1xyXG4gICAgICB0aGlzLl9yZWxhdGlvbiA9IHZhbHVlO1xyXG4gICAgICB0aGlzLnJlbGF0aW9uU2V0KCk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0IHJlbGF0aW9uKCk6IFJlbGF0aW9uQW55VHlwZSB7XHJcbiAgICByZXR1cm4gdGhpcy5fcmVsYXRpb247XHJcbiAgfVxyXG5cclxuICBAT3V0cHV0KClcclxuICBwdWJsaWMgcmVsYXRpb25DaGFuZ2U6IEV2ZW50RW1pdHRlcjxSZWxhdGlvbkFueVR5cGU+ID0gbmV3IEV2ZW50RW1pdHRlcjxSZWxhdGlvbkFueVR5cGU+KCk7XHJcblxyXG4gIEBPdXRwdXQoKVxyXG4gIHB1YmxpYyBpbnB1dENoYW5nZUZvclN1Z2dlc3Rpb25zOiBFdmVudEVtaXR0ZXI8UmVsYXRpb25TdWdnZXN0aW9uc1JlcXVlc3Q+ID0gbmV3IEV2ZW50RW1pdHRlcjxSZWxhdGlvblN1Z2dlc3Rpb25zUmVxdWVzdD4oKTtcclxuXHJcbiAgcHVibGljIGdldCByZWxhdGlvbkFzQ3VzdG9tZXIoKTogQ3VzdG9tZXJGdWxsT2JqZWN0IHtcclxuICAgIHJldHVybiB0aGlzLl9yZWxhdGlvbiAmJiB0aGlzLl9yZWxhdGlvbiBhcyBDdXN0b21lckZ1bGxPYmplY3Q7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIF9yZWxhdGlvbjogUmVsYXRpb25BbnlUeXBlID0gTlVMTF9SRUxBVElPTl9PQkpFQ1Q7XHJcblxyXG4gIHByb3RlY3RlZCBzdWdnZXN0aW9uUmVxdWVzdDogUmVsYXRpb25TdWdnZXN0aW9uc1JlcXVlc3QgPSB7fTtcclxuXHJcbiAgLy8gb3ZlcnJpZGRlbiBieSBkZXNjZW5kYW50IGNsYXNzZXNcclxuICBwcm90ZWN0ZWQgcmVsYXRpb25TZXQoKTogdm9pZCB7XHJcblxyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -17,6 +17,12 @@ export class RelationContactDetailsComponent extends RelationBaseComponent {
|
|
|
17
17
|
showClass() {
|
|
18
18
|
return true;
|
|
19
19
|
}
|
|
20
|
+
handlePhoneChange() {
|
|
21
|
+
this._updateSuggestionGeneralRequest();
|
|
22
|
+
}
|
|
23
|
+
handleEmailChange() {
|
|
24
|
+
this._updateSuggestionGeneralRequest();
|
|
25
|
+
}
|
|
20
26
|
preparePrimaryEmail() {
|
|
21
27
|
if (this.relation) {
|
|
22
28
|
this.emailAddress = this.relation.getLowestSequenceOfContactOptionsWithType(CommunicationType.Email);
|
|
@@ -43,14 +49,33 @@ export class RelationContactDetailsComponent extends RelationBaseComponent {
|
|
|
43
49
|
this.preparePrimaryEmail();
|
|
44
50
|
this.preparePrimaryPhone();
|
|
45
51
|
}
|
|
52
|
+
_updateSuggestionGeneralRequest() {
|
|
53
|
+
this.suggestionRequest.general =
|
|
54
|
+
(this.phoneNumber.value ? this.phoneNumber.value : "") + (this.emailAddress.value ? " " : "") + (this.emailAddress.value ? this.emailAddress.value : "");
|
|
55
|
+
this.inputChangeForSuggestions.next(this.suggestionRequest);
|
|
56
|
+
}
|
|
46
57
|
}
|
|
47
58
|
RelationContactDetailsComponent.decorators = [
|
|
48
59
|
{ type: Component, args: [{
|
|
49
60
|
selector: "co-relation-contact-details",
|
|
50
61
|
template: `
|
|
51
62
|
<div class="default-data-row">
|
|
52
|
-
<co-input-text *ngIf="showPhone"
|
|
53
|
-
|
|
63
|
+
<co-input-text *ngIf="showPhone"
|
|
64
|
+
[(model)]="phoneNumber.value"
|
|
65
|
+
[readonly]="readonly"
|
|
66
|
+
[digitsOnly]="true"
|
|
67
|
+
[placeholder]="'PHONE_NO' | localize"
|
|
68
|
+
[required]="true"
|
|
69
|
+
(modelChange)="handlePhoneChange()"
|
|
70
|
+
></co-input-text>
|
|
71
|
+
<co-input-text
|
|
72
|
+
[(model)]="emailAddress.value"
|
|
73
|
+
[readonly]="readonly"
|
|
74
|
+
[placeholder]="'EMAIL_ADDRESS' | localize"
|
|
75
|
+
[type]="'email'"
|
|
76
|
+
[required]="true"
|
|
77
|
+
(modelChange)="handleEmailChange()"
|
|
78
|
+
></co-input-text>
|
|
54
79
|
</div>
|
|
55
80
|
<div class="default-data-row" *ngIf="relationKind === relKind.Customer">
|
|
56
81
|
<co-input-checkbox [readonly]="readonly" [label]="'INVITE_TO_ACCOUNT' | localize" [(model)]="inviteToAccount"></co-input-checkbox>
|
|
@@ -65,4 +90,4 @@ RelationContactDetailsComponent.propDecorators = {
|
|
|
65
90
|
relationKind: [{ type: Input }],
|
|
66
91
|
showClass: [{ type: HostBinding, args: ["class.co-relation-contact-details",] }]
|
|
67
92
|
};
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
93
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relation-contact-details.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/relation/relation-contact-details/relation-contact-details.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, HostBinding, Input, ViewEncapsulation} from '@angular/core';\r\nimport {ContactOption} from '@colijnit/relationapi/build/model/contact-option.bo';\r\nimport {RelationBaseComponent} from '../relation-base.component';\r\nimport {CommunicationType} from '@colijnit/relationapi/build/enum/communication-type.enum';\r\nimport {isNill} from '@colijnit/ioneconnector/build/utils/function/is-nill.function';\r\nimport {RelationKind} from '@colijnit/relationapi/build/enum/relation-kind.enum';\r\n\r\n@Component({\r\n  selector: \"co-relation-contact-details\",\r\n  template: `\r\n    <div class=\"default-data-row\">\r\n      <co-input-text *ngIf=\"showPhone\"\r\n                     [(model)]=\"phoneNumber.value\"\r\n                     [readonly]=\"readonly\"\r\n                     [digitsOnly]=\"true\" \r\n                     [placeholder]=\"'PHONE_NO' | localize\"\r\n                     [required]=\"true\"\r\n                     (modelChange)=\"handlePhoneChange()\"\r\n      ></co-input-text>\r\n      <co-input-text\r\n          [(model)]=\"emailAddress.value\"\r\n          [readonly]=\"readonly\" \r\n          [placeholder]=\"'EMAIL_ADDRESS' | localize\"\r\n          [type]=\"'email'\" \r\n          [required]=\"true\"\r\n          (modelChange)=\"handleEmailChange()\"\r\n      ></co-input-text>\r\n    </div>\r\n    <div class=\"default-data-row\" *ngIf=\"relationKind === relKind.Customer\">\r\n      <co-input-checkbox [readonly]=\"readonly\" [label]=\"'INVITE_TO_ACCOUNT' | localize\" [(model)]=\"inviteToAccount\"></co-input-checkbox>\r\n    </div>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class RelationContactDetailsComponent extends RelationBaseComponent {\r\n\r\n  @Input()\r\n  public readonly: boolean = false;\r\n\r\n  @Input()\r\n  public showPhone: boolean = true;\r\n\r\n  @Input()\r\n  public relationKind: RelationKind = RelationKind.Customer;\r\n\r\n  @HostBinding(\"class.co-relation-contact-details\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public emailAddress: ContactOption = new ContactOption();\r\n  public phoneNumber: ContactOption = new ContactOption();\r\n  public inviteToAccount: boolean = false;\r\n\r\n  public handlePhoneChange(): void {\r\n    this._updateSuggestionGeneralRequest();\r\n  }\r\n\r\n  public handleEmailChange(): void {\r\n    this._updateSuggestionGeneralRequest();\r\n  }\r\n\r\n  public preparePrimaryEmail(): void {\r\n    if (this.relation) {\r\n      this.emailAddress = this.relation.getLowestSequenceOfContactOptionsWithType(CommunicationType.Email);\r\n      if (isNill(this.emailAddress)) {\r\n        this.emailAddress = new ContactOption();\r\n        this.emailAddress.type = CommunicationType.Email;\r\n        this.emailAddress.sequence = 0;\r\n        this.relation.addContactOption(this.emailAddress);\r\n      }\r\n    }\r\n  }\r\n\r\n  public preparePrimaryPhone(): void {\r\n    if (this.relation) {\r\n      this.phoneNumber = this.relation.getLowestSequenceOfContactOptionsWithType(CommunicationType.Telephone);\r\n      if (isNill(this.phoneNumber)) {\r\n        this.phoneNumber = new ContactOption();\r\n        this.phoneNumber.type = CommunicationType.Telephone;\r\n        this.phoneNumber.sequence = 0;\r\n        this.relation.addContactOption(this.phoneNumber);\r\n      }\r\n    }\r\n  }\r\n\r\n  protected relationSet() {\r\n    this.preparePrimaryEmail();\r\n    this.preparePrimaryPhone();\r\n  }\r\n\r\n  private _updateSuggestionGeneralRequest(): void {\r\n    this.suggestionRequest.general =\r\n        (this.phoneNumber.value ? this.phoneNumber.value : \"\") + (this.emailAddress.value ? \" \" : \"\") + (this.emailAddress.value ? this.emailAddress.value : \"\");\r\n    this.inputChangeForSuggestions.next(this.suggestionRequest);\r\n  }\r\n\r\n}\r\n"]}
|