@colijnit/relation 256.1.0 → 256.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-relation.umd.js +235 -241
- package/bundles/colijnit-relation.umd.js.map +1 -1
- package/colijnit-relation.d.ts +7 -8
- package/colijnit-relation.metadata.json +1 -1
- package/esm2015/colijnit-relation.js +8 -9
- package/esm2015/lib/component/relation/relation.component.js +146 -42
- package/esm2015/lib/component/relation-address/relation-address.component.js +3 -3
- package/esm2015/lib/component/relation-address-tile/relation-address-tile.component.js +3 -3
- package/esm2015/lib/component/relation-addresses/relation-addresses.component.js +6 -7
- package/esm2015/lib/component/relation-contact-options/relation-contact-option.component.js +3 -1
- package/esm2015/lib/component/relation-contact-options/relation-contact-options.component.js +6 -2
- package/esm2015/lib/component/relation-contact-options/relation-contact-options.module.js +4 -3
- package/esm2015/lib/component/relation-preferences/relation-preferences.component.js +2 -2
- package/esm2015/lib/component/relation-title/relation-title.component.js +4 -3
- package/esm2015/lib/enum/icon.enum.js +2 -1
- package/esm2015/lib/model/icon-svg.js +2 -1
- package/esm2015/lib/relation-version.js +4 -4
- package/esm2015/lib/res/dictionary/dictionaries.js +3 -3
- package/esm2015/lib/service/error.service.js +5 -5
- package/esm2015/lib/service/relation-base.service.js +1 -1
- package/esm2015/lib/service/relation-settings.service.js +5 -5
- package/fesm2015/colijnit-relation.js +272 -225
- package/fesm2015/colijnit-relation.js.map +1 -1
- package/lib/component/relation/relation.component.d.ts +14 -1
- package/lib/component/relation/style/_layout.scss +66 -2
- package/lib/component/relation/style/_material-definition.scss +2 -2
- package/lib/component/relation-address/relation-address.component.d.ts +2 -2
- package/lib/component/relation-address-tile/style/_layout.scss +34 -2
- package/lib/component/relation-address-tile/style/_material-definition.scss +1 -1
- package/lib/component/relation-addresses/style/_layout.scss +7 -0
- package/lib/component/relation-addresses/style/_material-definition.scss +1 -1
- package/lib/component/relation-contact-options/relation-contact-option.component.d.ts +1 -0
- package/lib/component/relation-contact-options/relation-contact-options.component.d.ts +2 -0
- package/lib/enum/icon.enum.d.ts +1 -0
- package/lib/res/dictionary/dictionaries.d.ts +68 -1
- package/lib/service/error.service.d.ts +2 -2
- package/lib/service/relation-settings.service.d.ts +2 -2
- package/lib/style/_variables.scss +1 -1
- package/package.json +1 -1
- package/esm2015/lib/service/dictionary.service.js +0 -68
- package/lib/service/dictionary.service.d.ts +0 -18
|
@@ -3,20 +3,19 @@
|
|
|
3
3
|
*/
|
|
4
4
|
export * from './public_api';
|
|
5
5
|
export { RelationBaseComponent as ɵl } from './lib/component/base/relation-base.component';
|
|
6
|
-
export { RelationLoaderComponent as
|
|
6
|
+
export { RelationLoaderComponent as ɵp } from './lib/component/base/relation-loader.component';
|
|
7
7
|
export { RelationScreenConfigBaseComponent as ɵk } from './lib/component/base/relation-screen-config-base.component';
|
|
8
|
-
export { RelationContactOptionListComponent as
|
|
9
|
-
export { RelationContactOptionComponent as
|
|
10
|
-
export { RelationContactOptionsOtherTypesPopupComponent as
|
|
11
|
-
export { DictionaryService as ɵd } from './lib/service/dictionary.service';
|
|
8
|
+
export { RelationContactOptionListComponent as ɵn } from './lib/component/relation-contact-options/relation-contact-option-list.component';
|
|
9
|
+
export { RelationContactOptionComponent as ɵm } from './lib/component/relation-contact-options/relation-contact-option.component';
|
|
10
|
+
export { RelationContactOptionsOtherTypesPopupComponent as ɵo } from './lib/component/relation-contact-options/relation-contact-options-other-types-popup.component';
|
|
12
11
|
export { ErrorService as ɵe } from './lib/service/error.service';
|
|
13
|
-
export { IconCacheService as
|
|
12
|
+
export { IconCacheService as ɵi } from './lib/service/icon-cache.service';
|
|
14
13
|
export { RelationBaseService as ɵh } from './lib/service/relation-base.service';
|
|
15
14
|
export { RelationConnectorAdapterService as ɵb } from './lib/service/relation-connector-adapter.service';
|
|
16
15
|
export { RelationConnectorService as ɵg } from './lib/service/relation-connector.service';
|
|
17
16
|
export { RelationEventService as ɵf } from './lib/service/relation-event.service';
|
|
18
17
|
export { RelationScreenConfigurationService as ɵa } from './lib/service/relation-screen-configuration.service';
|
|
19
18
|
export { RelationSettingsService as ɵc } from './lib/service/relation-settings.service';
|
|
20
|
-
export { RelationDictionaryService as
|
|
21
|
-
export { RelationLocalizePipe as
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
export { RelationDictionaryService as ɵd } from './lib/translation/relation-dictionary.service';
|
|
20
|
+
export { RelationLocalizePipe as ɵj } from './lib/translation/relation-localize.pipe';
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29saWpuaXQtcmVsYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wcm9qZWN0cy9yZWxhdGlvbi9zcmMvY29saWpuaXQtcmVsYXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQztBQUU3QixPQUFPLEVBQUMscUJBQXFCLElBQUksRUFBRSxFQUFDLE1BQU0sOENBQThDLENBQUM7QUFDekYsT0FBTyxFQUFDLHVCQUF1QixJQUFJLEVBQUUsRUFBQyxNQUFNLGdEQUFnRCxDQUFDO0FBQzdGLE9BQU8sRUFBQyxpQ0FBaUMsSUFBSSxFQUFFLEVBQUMsTUFBTSw0REFBNEQsQ0FBQztBQUNuSCxPQUFPLEVBQUMsa0NBQWtDLElBQUksRUFBRSxFQUFDLE1BQU0saUZBQWlGLENBQUM7QUFDekksT0FBTyxFQUFDLDhCQUE4QixJQUFJLEVBQUUsRUFBQyxNQUFNLDRFQUE0RSxDQUFDO0FBQ2hJLE9BQU8sRUFBQyw4Q0FBOEMsSUFBSSxFQUFFLEVBQUMsTUFBTSwrRkFBK0YsQ0FBQztBQUNuSyxPQUFPLEVBQUMsWUFBWSxJQUFJLEVBQUUsRUFBQyxNQUFNLDZCQUE2QixDQUFDO0FBQy9ELE9BQU8sRUFBQyxnQkFBZ0IsSUFBSSxFQUFFLEVBQUMsTUFBTSxrQ0FBa0MsQ0FBQztBQUN4RSxPQUFPLEVBQUMsbUJBQW1CLElBQUksRUFBRSxFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDOUUsT0FBTyxFQUFDLCtCQUErQixJQUFJLEVBQUUsRUFBQyxNQUFNLGtEQUFrRCxDQUFDO0FBQ3ZHLE9BQU8sRUFBQyx3QkFBd0IsSUFBSSxFQUFFLEVBQUMsTUFBTSwwQ0FBMEMsQ0FBQztBQUN4RixPQUFPLEVBQUMsb0JBQW9CLElBQUksRUFBRSxFQUFDLE1BQU0sc0NBQXNDLENBQUM7QUFDaEYsT0FBTyxFQUFDLGtDQUFrQyxJQUFJLEVBQUUsRUFBQyxNQUFNLHFEQUFxRCxDQUFDO0FBQzdHLE9BQU8sRUFBQyx1QkFBdUIsSUFBSSxFQUFFLEVBQUMsTUFBTSx5Q0FBeUMsQ0FBQztBQUN0RixPQUFPLEVBQUMseUJBQXlCLElBQUksRUFBRSxFQUFDLE1BQU0sK0NBQStDLENBQUM7QUFDOUYsT0FBTyxFQUFDLG9CQUFvQixJQUFJLEVBQUUsRUFBQyxNQUFNLDBDQUEwQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpY19hcGknO1xuXG5leHBvcnQge1JlbGF0aW9uQmFzZUNvbXBvbmVudCBhcyDJtWx9IGZyb20gJy4vbGliL2NvbXBvbmVudC9iYXNlL3JlbGF0aW9uLWJhc2UuY29tcG9uZW50JztcbmV4cG9ydCB7UmVsYXRpb25Mb2FkZXJDb21wb25lbnQgYXMgybVwfSBmcm9tICcuL2xpYi9jb21wb25lbnQvYmFzZS9yZWxhdGlvbi1sb2FkZXIuY29tcG9uZW50JztcbmV4cG9ydCB7UmVsYXRpb25TY3JlZW5Db25maWdCYXNlQ29tcG9uZW50IGFzIMm1a30gZnJvbSAnLi9saWIvY29tcG9uZW50L2Jhc2UvcmVsYXRpb24tc2NyZWVuLWNvbmZpZy1iYXNlLmNvbXBvbmVudCc7XG5leHBvcnQge1JlbGF0aW9uQ29udGFjdE9wdGlvbkxpc3RDb21wb25lbnQgYXMgybVufSBmcm9tICcuL2xpYi9jb21wb25lbnQvcmVsYXRpb24tY29udGFjdC1vcHRpb25zL3JlbGF0aW9uLWNvbnRhY3Qtb3B0aW9uLWxpc3QuY29tcG9uZW50JztcbmV4cG9ydCB7UmVsYXRpb25Db250YWN0T3B0aW9uQ29tcG9uZW50IGFzIMm1bX0gZnJvbSAnLi9saWIvY29tcG9uZW50L3JlbGF0aW9uLWNvbnRhY3Qtb3B0aW9ucy9yZWxhdGlvbi1jb250YWN0LW9wdGlvbi5jb21wb25lbnQnO1xuZXhwb3J0IHtSZWxhdGlvbkNvbnRhY3RPcHRpb25zT3RoZXJUeXBlc1BvcHVwQ29tcG9uZW50IGFzIMm1b30gZnJvbSAnLi9saWIvY29tcG9uZW50L3JlbGF0aW9uLWNvbnRhY3Qtb3B0aW9ucy9yZWxhdGlvbi1jb250YWN0LW9wdGlvbnMtb3RoZXItdHlwZXMtcG9wdXAuY29tcG9uZW50JztcbmV4cG9ydCB7RXJyb3JTZXJ2aWNlIGFzIMm1ZX0gZnJvbSAnLi9saWIvc2VydmljZS9lcnJvci5zZXJ2aWNlJztcbmV4cG9ydCB7SWNvbkNhY2hlU2VydmljZSBhcyDJtWl9IGZyb20gJy4vbGliL3NlcnZpY2UvaWNvbi1jYWNoZS5zZXJ2aWNlJztcbmV4cG9ydCB7UmVsYXRpb25CYXNlU2VydmljZSBhcyDJtWh9IGZyb20gJy4vbGliL3NlcnZpY2UvcmVsYXRpb24tYmFzZS5zZXJ2aWNlJztcbmV4cG9ydCB7UmVsYXRpb25Db25uZWN0b3JBZGFwdGVyU2VydmljZSBhcyDJtWJ9IGZyb20gJy4vbGliL3NlcnZpY2UvcmVsYXRpb24tY29ubmVjdG9yLWFkYXB0ZXIuc2VydmljZSc7XG5leHBvcnQge1JlbGF0aW9uQ29ubmVjdG9yU2VydmljZSBhcyDJtWd9IGZyb20gJy4vbGliL3NlcnZpY2UvcmVsYXRpb24tY29ubmVjdG9yLnNlcnZpY2UnO1xuZXhwb3J0IHtSZWxhdGlvbkV2ZW50U2VydmljZSBhcyDJtWZ9IGZyb20gJy4vbGliL3NlcnZpY2UvcmVsYXRpb24tZXZlbnQuc2VydmljZSc7XG5leHBvcnQge1JlbGF0aW9uU2NyZWVuQ29uZmlndXJhdGlvblNlcnZpY2UgYXMgybVhfSBmcm9tICcuL2xpYi9zZXJ2aWNlL3JlbGF0aW9uLXNjcmVlbi1jb25maWd1cmF0aW9uLnNlcnZpY2UnO1xuZXhwb3J0IHtSZWxhdGlvblNldHRpbmdzU2VydmljZSBhcyDJtWN9IGZyb20gJy4vbGliL3NlcnZpY2UvcmVsYXRpb24tc2V0dGluZ3Muc2VydmljZSc7XG5leHBvcnQge1JlbGF0aW9uRGljdGlvbmFyeVNlcnZpY2UgYXMgybVkfSBmcm9tICcuL2xpYi90cmFuc2xhdGlvbi9yZWxhdGlvbi1kaWN0aW9uYXJ5LnNlcnZpY2UnO1xuZXhwb3J0IHtSZWxhdGlvbkxvY2FsaXplUGlwZSBhcyDJtWp9IGZyb20gJy4vbGliL3RyYW5zbGF0aW9uL3JlbGF0aW9uLWxvY2FsaXplLnBpcGUnOyJdfQ==
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
1
2
|
import { Component, HostBinding, Input, ViewEncapsulation } from '@angular/core';
|
|
2
3
|
import { BaseModuleScreenConfigService, CoreComponentsTranslationService } from '@colijnit/corecomponents_v12';
|
|
3
4
|
import { RelationEventService } from '../../service/relation-event.service';
|
|
@@ -6,14 +7,21 @@ import { RelationSettingsService } from '../../service/relation-settings.service
|
|
|
6
7
|
import { RelationService } from '../../service/relation.service';
|
|
7
8
|
import { RelationConnectorService } from '../../service/relation-connector.service';
|
|
8
9
|
import { RelationScreenConfigurationService } from '../../service/relation-screen-configuration.service';
|
|
10
|
+
import { IconCacheService } from "../../service/icon-cache.service";
|
|
11
|
+
import { Icon } from "../../enum/icon.enum";
|
|
9
12
|
export class RelationComponent {
|
|
10
|
-
constructor(relationEventService, _translationService, _settingsService, _relationConnectorService, _relationService) {
|
|
13
|
+
constructor(relationEventService, _translationService, _settingsService, _relationConnectorService, _relationService, iconCacheService) {
|
|
11
14
|
this.relationEventService = relationEventService;
|
|
12
15
|
this._translationService = _translationService;
|
|
13
16
|
this._settingsService = _settingsService;
|
|
14
17
|
this._relationConnectorService = _relationConnectorService;
|
|
15
18
|
this._relationService = _relationService;
|
|
19
|
+
this.iconCacheService = iconCacheService;
|
|
20
|
+
this.icons = Icon;
|
|
16
21
|
this.loadRelationFromLoginResponse = false;
|
|
22
|
+
this.forceReadOnly = true;
|
|
23
|
+
this.customerPortal = false;
|
|
24
|
+
this.collection = [];
|
|
17
25
|
this._subs = [];
|
|
18
26
|
const dictionaries = new Dictionaries();
|
|
19
27
|
this._translationService.setTranslation(dictionaries[this._settingsService.dictionaryKey]);
|
|
@@ -25,60 +33,153 @@ export class RelationComponent {
|
|
|
25
33
|
if (this.loadRelationFromLoginResponse) {
|
|
26
34
|
this._relationService.relationId = this._relationConnectorService.loginResponse.relationId;
|
|
27
35
|
}
|
|
28
|
-
this._subs.push(this.relationEventService.relationLoaded.subscribe((relation) => {
|
|
36
|
+
this._subs.push(this.relationEventService.relationLoaded.subscribe((relation) => __awaiter(this, void 0, void 0, function* () {
|
|
29
37
|
if (relation && relation.relationId) {
|
|
30
38
|
this.relation = relation;
|
|
39
|
+
yield this.getTitleCollection();
|
|
40
|
+
this.relationTitle = this.getTitleForRelation(this.relation);
|
|
31
41
|
}
|
|
32
|
-
}));
|
|
42
|
+
})));
|
|
33
43
|
}
|
|
34
44
|
ngOnDestroy() {
|
|
35
45
|
this._subs.forEach(s => s.unsubscribe());
|
|
36
46
|
}
|
|
47
|
+
handleSaveClick() {
|
|
48
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
49
|
+
const success = yield this._relationService.saveRelation();
|
|
50
|
+
if (success) {
|
|
51
|
+
this.forceReadOnly = true;
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
getTitleCollection() {
|
|
56
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
57
|
+
this.collection = yield this._relationConnectorService.getTitles();
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
getTitleForRelation(relation) {
|
|
61
|
+
let title = this.collection.find(title => title.titleId === relation.titleId);
|
|
62
|
+
if (title) {
|
|
63
|
+
return title.description;
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
return "";
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
getGenderLabel(gender) {
|
|
70
|
+
switch (gender) {
|
|
71
|
+
case 'M':
|
|
72
|
+
return 'MALE';
|
|
73
|
+
case 'V':
|
|
74
|
+
return 'FEMALE';
|
|
75
|
+
case 'O':
|
|
76
|
+
return 'Unspecified';
|
|
77
|
+
default:
|
|
78
|
+
return '';
|
|
79
|
+
}
|
|
80
|
+
}
|
|
37
81
|
}
|
|
38
82
|
RelationComponent.decorators = [
|
|
39
83
|
{ type: Component, args: [{
|
|
40
84
|
selector: 'co-relation',
|
|
41
85
|
template: `
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
<co-relation-avatar [relation]="relation" [canChangeAvatar]="true"></co-relation-avatar>
|
|
67
|
-
</div>
|
|
68
|
-
</div>
|
|
69
|
-
<div class="relation-section">
|
|
70
|
-
<div class="relation-section-label" [textContent]="'CONTACT_OPTIONS' | reLocalize"></div>
|
|
86
|
+
<co-relation-loader></co-relation-loader>
|
|
87
|
+
<ng-container *ngIf="relation">
|
|
88
|
+
<div class="relation-section">
|
|
89
|
+
<div class="relation-section-label" [textContent]="'YOUR_DATA' | reLocalize"></div>
|
|
90
|
+
<div class="relation-account-data" *ngIf="!forceReadOnly">
|
|
91
|
+
<div class="relation-account-data-wrapper">
|
|
92
|
+
<div class="relation-data-row">
|
|
93
|
+
<co-relation-title class="relation-data-field-default" [collection]="collection"
|
|
94
|
+
[(relation)]="relation"></co-relation-title>
|
|
95
|
+
<co-relation-initials class="relation-data-field-default" [(relation)]="relation"></co-relation-initials>
|
|
96
|
+
</div>
|
|
97
|
+
<div class="relation-data-row">
|
|
98
|
+
<co-relation-first-name [(relation)]="relation"></co-relation-first-name>
|
|
99
|
+
<co-relation-prefix-name [(relation)]="relation"></co-relation-prefix-name>
|
|
100
|
+
<co-relation-last-name [(relation)]="relation"></co-relation-last-name>
|
|
101
|
+
</div>
|
|
102
|
+
<div class="relation-data-row">
|
|
103
|
+
<co-relation-gender class="relation-data-field-default" [(relation)]="relation"></co-relation-gender>
|
|
104
|
+
</div>
|
|
105
|
+
<div class="relation-data-row">
|
|
106
|
+
<co-relation-language class="relation-data-field-default" [(relation)]="relation"></co-relation-language>
|
|
107
|
+
</div>
|
|
108
|
+
<div class="relation-data-column">
|
|
109
|
+
<div class="relation-section-sub-label" [textContent]="'CONTACT_OPTIONS' | reLocalize"></div>
|
|
71
110
|
<co-relation-contact-options [(relation)]="relation"></co-relation-contact-options>
|
|
111
|
+
</div>
|
|
112
|
+
<div class="save-editable-wrapper" *ngIf="!forceReadOnly">
|
|
113
|
+
<co-button class="save-button"
|
|
114
|
+
[iconData]="iconCacheService.getIcon(icons.CheckDuotone)"
|
|
115
|
+
(click)="handleSaveClick()"
|
|
116
|
+
></co-button>
|
|
117
|
+
<co-button class="close-button"
|
|
118
|
+
[iconData]="iconCacheService.getIcon(icons.Crossskinny)"
|
|
119
|
+
(click)="forceReadOnly = true"
|
|
120
|
+
></co-button>
|
|
121
|
+
</div>
|
|
72
122
|
</div>
|
|
73
|
-
<
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
<div class="
|
|
79
|
-
|
|
123
|
+
<co-relation-avatar [relation]="relation" [canChangeAvatar]="true"></co-relation-avatar>
|
|
124
|
+
</div>
|
|
125
|
+
<div class="relation-account-data" *ngIf="forceReadOnly">
|
|
126
|
+
<div class="relation-account-data-wrapper non-editable">
|
|
127
|
+
<div class="relation-data-row">
|
|
128
|
+
<div class="non-editable-column">
|
|
129
|
+
<label class="label" [textContent]="'TITLES' | reLocalize"></label>
|
|
130
|
+
<span class="value" [textContent]="relationTitle"></span>
|
|
131
|
+
</div>
|
|
132
|
+
<div class="non-editable-column">
|
|
133
|
+
<label class="label" [textContent]="'INITIALS' | reLocalize"></label>
|
|
134
|
+
<span class="value" [textContent]="relation.initials"></span>
|
|
135
|
+
</div>
|
|
136
|
+
</div>
|
|
137
|
+
<div class="relation-data-row">
|
|
138
|
+
<div class="non-editable-column">
|
|
139
|
+
<label class="label" [textContent]="'NAME' | reLocalize"></label>
|
|
140
|
+
<span
|
|
141
|
+
class="value"
|
|
142
|
+
[textContent]="relation.firstName + (relation.prefix ? ' ' + relation.prefix : '') + ' ' + relation.familyName">
|
|
143
|
+
</span>
|
|
144
|
+
</div>
|
|
145
|
+
</div>
|
|
146
|
+
<div class="relation-data-row">
|
|
147
|
+
<div class="non-editable-column">
|
|
148
|
+
<label class="label" [textContent]="'GENDER' | reLocalize"></label>
|
|
149
|
+
<span class="value" [textContent]="getGenderLabel(relation.gender) | reLocalize"></span>
|
|
150
|
+
</div>
|
|
151
|
+
<div class="non-editable-column">
|
|
152
|
+
<label class="label" [textContent]="'LANGUAGE' | reLocalize"></label>
|
|
153
|
+
<span class="value" [textContent]="relation.language"></span>
|
|
154
|
+
</div>
|
|
155
|
+
</div>
|
|
156
|
+
<div class="relation-data-row">
|
|
157
|
+
<div class="non-editable-column">
|
|
158
|
+
<label class="label" [textContent]="'EMAIL' | reLocalize"></label>
|
|
159
|
+
<span class="value" [textContent]="relation.primaryEmail"></span>
|
|
160
|
+
</div>
|
|
161
|
+
<div class="non-editable-column">
|
|
162
|
+
<label class="label" [textContent]="'PHONE' | reLocalize"></label>
|
|
163
|
+
<span class="value" [textContent]="relation.primaryPhoneOrMobileNumber"></span>
|
|
164
|
+
</div>
|
|
165
|
+
</div>
|
|
80
166
|
</div>
|
|
81
|
-
|
|
167
|
+
<co-relation-avatar [relation]="relation" [canChangeAvatar]="false"></co-relation-avatar>
|
|
168
|
+
</div>
|
|
169
|
+
<div class="switch-editable" *ngIf="forceReadOnly" (click)="forceReadOnly = false">
|
|
170
|
+
<span [textContent]="'EDIT' | reLocalize"></span>
|
|
171
|
+
</div>
|
|
172
|
+
</div>
|
|
173
|
+
<div class="relation-section">
|
|
174
|
+
<div class="relation-section-label" [textContent]="'ADDRESSES' | reLocalize"></div>
|
|
175
|
+
<co-relation-addresses [(relation)]="relation"></co-relation-addresses>
|
|
176
|
+
</div>
|
|
177
|
+
<div class="relation-section">
|
|
178
|
+
<div class="relation-section-label" [textContent]="'PRIVACY_PREFERENCES' | reLocalize"></div>
|
|
179
|
+
<co-relation-preferences [(relation)]="relation"></co-relation-preferences>
|
|
180
|
+
</div>
|
|
181
|
+
|
|
182
|
+
</ng-container>
|
|
82
183
|
`,
|
|
83
184
|
providers: [
|
|
84
185
|
{ provide: BaseModuleScreenConfigService, useExisting: RelationScreenConfigurationService }
|
|
@@ -91,10 +192,13 @@ RelationComponent.ctorParameters = () => [
|
|
|
91
192
|
{ type: CoreComponentsTranslationService },
|
|
92
193
|
{ type: RelationSettingsService },
|
|
93
194
|
{ type: RelationConnectorService },
|
|
94
|
-
{ type: RelationService }
|
|
195
|
+
{ type: RelationService },
|
|
196
|
+
{ type: IconCacheService }
|
|
95
197
|
];
|
|
96
198
|
RelationComponent.propDecorators = {
|
|
97
199
|
loadRelationFromLoginResponse: [{ type: Input }],
|
|
200
|
+
forceReadOnly: [{ type: Input }],
|
|
201
|
+
customerPortal: [{ type: Input }],
|
|
98
202
|
showClass: [{ type: HostBinding, args: ['class.co-relation',] }]
|
|
99
203
|
};
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relation.component.js","sourceRoot":"","sources":["../../../../../../projects/relation/src/lib/component/relation/relation.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,WAAW,EAAE,KAAK,EAAqB,iBAAiB,EAAC,MAAM,eAAe,CAAC;AAClG,OAAO,EAAC,6BAA6B,EAAE,gCAAgC,EAAC,MAAM,8BAA8B,CAAC;AAC7G,OAAO,EAAC,oBAAoB,EAAC,MAAM,sCAAsC,CAAC;AAC1E,OAAO,EAAC,YAAY,EAAC,MAAM,mCAAmC,CAAC;AAC/D,OAAO,EAAC,uBAAuB,EAAC,MAAM,yCAAyC,CAAC;AAGhF,OAAO,EAAC,eAAe,EAAC,MAAM,gCAAgC,CAAC;AAC/D,OAAO,EAAC,wBAAwB,EAAC,MAAM,0CAA0C,CAAC;AAClF,OAAO,EAAC,kCAAkC,EAAC,MAAM,qDAAqD,CAAC;AAmDvG,MAAM,OAAO,iBAAiB;IAY5B,YACY,oBAA0C,EAC5C,mBAAqD,EACrD,gBAAyC,EACzC,yBAAmD,EACnD,gBAAiC;QAJ/B,yBAAoB,GAApB,oBAAoB,CAAsB;QAC5C,wBAAmB,GAAnB,mBAAmB,CAAkC;QACrD,qBAAgB,GAAhB,gBAAgB,CAAyB;QACzC,8BAAyB,GAAzB,yBAAyB,CAA0B;QACnD,qBAAgB,GAAhB,gBAAgB,CAAiB;QAfpC,kCAA6B,GAAY,KAAK,CAAC;QAQ9C,UAAK,GAAmB,EAAE,CAAC;QASjC,MAAM,YAAY,GAAiB,IAAI,YAAY,EAAE,CAAC;QACtD,IAAI,CAAC,mBAAmB,CAAC,cAAc,CAAC,YAAY,CAAC,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC,CAAC;IAC7F,CAAC;IAhBM,SAAS;QACd,OAAO,IAAI,CAAC;IACd,CAAC;IAgBD,QAAQ;QACN,IAAI,IAAI,CAAC,6BAA6B,EAAE;YACtC,IAAI,CAAC,gBAAgB,CAAC,UAAU,GAAG,IAAI,CAAC,yBAAyB,CAAC,aAAa,CAAC,UAAU,CAAC;SAC5F;QACD,IAAI,CAAC,KAAK,CAAC,IAAI,CACb,IAAI,CAAC,oBAAoB,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC,QAAyB,EAAE,EAAE;YAC/E,IAAI,QAAQ,IAAI,QAAQ,CAAC,UAAU,EAAE;gBACnC,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;aAC1B;QACH,CAAC,CAAC,CACH,CAAA;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;IAC3C,CAAC;;;YAvFF,SAAS,SAAC;gBACT,QAAQ,EAAE,aAAa;gBACvB,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAyCT;gBACD,SAAS,EAAE;oBACT,EAAC,OAAO,EAAE,6BAA6B,EAAE,WAAW,EAAE,kCAAkC,EAAC;iBAC1F;gBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACtC;;;YAzDO,oBAAoB;YADW,gCAAgC;YAG/D,uBAAuB;YAIvB,wBAAwB;YADxB,eAAe;;;4CAsDpB,KAAK;wBAGL,WAAW,SAAC,mBAAmB","sourcesContent":["import {Component, HostBinding, Input, OnDestroy, OnInit, ViewEncapsulation} from '@angular/core';\r\nimport {BaseModuleScreenConfigService, CoreComponentsTranslationService} from '@colijnit/corecomponents_v12';\r\nimport {RelationEventService} from '../../service/relation-event.service';\r\nimport {Dictionaries} from '../../res/dictionary/dictionaries';\r\nimport {RelationSettingsService} from '../../service/relation-settings.service';\r\nimport {RelationAnyType} from '@colijnit/relationapi/build/model/relation-any-type';\r\nimport {Subscription} from 'rxjs';\r\nimport {RelationService} from '../../service/relation.service';\r\nimport {RelationConnectorService} from '../../service/relation-connector.service';\r\nimport {RelationScreenConfigurationService} from '../../service/relation-screen-configuration.service';\r\n\r\n@Component({\r\n  selector: 'co-relation',\r\n  template: `\r\n      <co-relation-loader></co-relation-loader>\r\n      <ng-container *ngIf=\"relation\">\r\n          <div class=\"relation-section\">\r\n              <div class=\"relation-section-label\" [textContent]=\"'YOUR_DATA' | reLocalize\"></div>\r\n              <div class=\"relation-account-data\">\r\n                  <div class=\"relation-account-data-wrapper\">\r\n                      <div class=\"relation-data-row\">\r\n                          <co-relation-title class=\"relation-data-field-default\" [(relation)]=\"relation\"></co-relation-title>\r\n                      </div>\r\n                      <div class=\"relation-data-row\">\r\n                          <co-relation-first-name [(relation)]=\"relation\"></co-relation-first-name>\r\n                          <co-relation-prefix-name [(relation)]=\"relation\"></co-relation-prefix-name>\r\n                          <co-relation-last-name [(relation)]=\"relation\"></co-relation-last-name>\r\n                      </div>\r\n                      <div class=\"relation-data-row\">\r\n                          <co-relation-initials class=\"relation-data-field-default\" [(relation)]=\"relation\"></co-relation-initials>\r\n                      </div>\r\n                      <div class=\"relation-data-row\">\r\n                          <co-relation-gender class=\"relation-data-field-default\" [(relation)]=\"relation\"></co-relation-gender>\r\n                      </div>\r\n                      <div class=\"relation-data-row\">\r\n                          <co-relation-language class=\"relation-data-field-default\" [(relation)]=\"relation\"></co-relation-language>\r\n                      </div>\r\n                  </div>\r\n                  <co-relation-avatar [relation]=\"relation\" [canChangeAvatar]=\"true\"></co-relation-avatar>\r\n              </div>\r\n          </div>\r\n          <div class=\"relation-section\">\r\n              <div class=\"relation-section-label\" [textContent]=\"'CONTACT_OPTIONS' | reLocalize\"></div>\r\n              <co-relation-contact-options [(relation)]=\"relation\"></co-relation-contact-options>\r\n          </div>\r\n          <div class=\"relation-section\">\r\n              <div class=\"relation-section-label\" [textContent]=\"'PRIVACY_PREFERENCES' | reLocalize\"></div>\r\n              <co-relation-preferences [(relation)]=\"relation\"></co-relation-preferences>\r\n          </div>\r\n          <div class=\"relation-section\">\r\n              <div class=\"relation-section-label\" [textContent]=\"'ADDRESSES' | reLocalize\"></div>\r\n              <co-relation-addresses [(relation)]=\"relation\"></co-relation-addresses>\r\n          </div>\r\n      </ng-container>\r\n  `,\r\n  providers: [\r\n    {provide: BaseModuleScreenConfigService, useExisting: RelationScreenConfigurationService}\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class RelationComponent implements OnInit, OnDestroy {\r\n  @Input()\r\n  public loadRelationFromLoginResponse: boolean = false;\r\n\r\n  @HostBinding('class.co-relation')\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public relation: RelationAnyType;\r\n  private _subs: Subscription[] = [];\r\n\r\n  constructor(\r\n    protected relationEventService: RelationEventService,\r\n    private _translationService: CoreComponentsTranslationService,\r\n    private _settingsService: RelationSettingsService,\r\n    private _relationConnectorService: RelationConnectorService,\r\n    private _relationService: RelationService\r\n  ) {\r\n    const dictionaries: Dictionaries = new Dictionaries();\r\n    this._translationService.setTranslation(dictionaries[this._settingsService.dictionaryKey]);\r\n  }\r\n\r\n  ngOnInit() {\r\n    if (this.loadRelationFromLoginResponse) {\r\n      this._relationService.relationId = this._relationConnectorService.loginResponse.relationId;\r\n    }\r\n    this._subs.push(\r\n      this.relationEventService.relationLoaded.subscribe((relation: RelationAnyType) => {\r\n        if (relation && relation.relationId) {\r\n          this.relation = relation;\r\n        }\r\n      })\r\n    )\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this._subs.forEach(s => s.unsubscribe());\r\n  }\r\n}\r\n"]}
|
|
204
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relation.component.js","sourceRoot":"","sources":["../../../../../../projects/relation/src/lib/component/relation/relation.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, HostBinding, Input, OnDestroy, OnInit, ViewEncapsulation} from '@angular/core';\r\nimport {BaseModuleScreenConfigService, CoreComponentsTranslationService} from '@colijnit/corecomponents_v12';\r\nimport {RelationEventService} from '../../service/relation-event.service';\r\nimport {Dictionaries} from '../../res/dictionary/dictionaries';\r\nimport {RelationSettingsService} from '../../service/relation-settings.service';\r\nimport {RelationAnyType} from '@colijnit/relationapi/build/model/relation-any-type';\r\nimport {Subscription} from 'rxjs';\r\nimport {RelationService} from '../../service/relation.service';\r\nimport {RelationConnectorService} from '../../service/relation-connector.service';\r\nimport {RelationScreenConfigurationService} from '../../service/relation-screen-configuration.service';\r\nimport {Title} from \"@colijnit/mainapi/build/model/title.bo\";\r\nimport {IconCacheService} from \"../../service/icon-cache.service\";\r\nimport {Icon} from \"../../enum/icon.enum\";\r\n\r\n@Component({\r\n  selector: 'co-relation',\r\n  template: `\r\n    <co-relation-loader></co-relation-loader>\r\n    <ng-container *ngIf=\"relation\">\r\n      <div class=\"relation-section\">\r\n        <div class=\"relation-section-label\" [textContent]=\"'YOUR_DATA' | reLocalize\"></div>\r\n        <div class=\"relation-account-data\" *ngIf=\"!forceReadOnly\">\r\n          <div class=\"relation-account-data-wrapper\">\r\n            <div class=\"relation-data-row\">\r\n              <co-relation-title class=\"relation-data-field-default\" [collection]=\"collection\"\r\n                                 [(relation)]=\"relation\"></co-relation-title>\r\n              <co-relation-initials class=\"relation-data-field-default\" [(relation)]=\"relation\"></co-relation-initials>\r\n            </div>\r\n            <div class=\"relation-data-row\">\r\n              <co-relation-first-name [(relation)]=\"relation\"></co-relation-first-name>\r\n              <co-relation-prefix-name [(relation)]=\"relation\"></co-relation-prefix-name>\r\n              <co-relation-last-name [(relation)]=\"relation\"></co-relation-last-name>\r\n            </div>\r\n            <div class=\"relation-data-row\">\r\n              <co-relation-gender class=\"relation-data-field-default\" [(relation)]=\"relation\"></co-relation-gender>\r\n            </div>\r\n            <div class=\"relation-data-row\">\r\n              <co-relation-language class=\"relation-data-field-default\" [(relation)]=\"relation\"></co-relation-language>\r\n            </div>\r\n            <div class=\"relation-data-column\">\r\n              <div class=\"relation-section-sub-label\" [textContent]=\"'CONTACT_OPTIONS' | reLocalize\"></div>\r\n              <co-relation-contact-options [(relation)]=\"relation\"></co-relation-contact-options>\r\n            </div>\r\n            <div class=\"save-editable-wrapper\" *ngIf=\"!forceReadOnly\">\r\n              <co-button class=\"save-button\"\r\n                         [iconData]=\"iconCacheService.getIcon(icons.CheckDuotone)\"\r\n                         (click)=\"handleSaveClick()\"\r\n              ></co-button>\r\n              <co-button class=\"close-button\"\r\n                         [iconData]=\"iconCacheService.getIcon(icons.Crossskinny)\"\r\n                         (click)=\"forceReadOnly = true\"\r\n              ></co-button>\r\n            </div>\r\n          </div>\r\n          <co-relation-avatar [relation]=\"relation\" [canChangeAvatar]=\"true\"></co-relation-avatar>\r\n        </div>\r\n        <div class=\"relation-account-data\" *ngIf=\"forceReadOnly\">\r\n          <div class=\"relation-account-data-wrapper non-editable\">\r\n            <div class=\"relation-data-row\">\r\n              <div class=\"non-editable-column\">\r\n                <label class=\"label\" [textContent]=\"'TITLES' | reLocalize\"></label>\r\n                <span class=\"value\" [textContent]=\"relationTitle\"></span>\r\n              </div>\r\n              <div class=\"non-editable-column\">\r\n                <label class=\"label\" [textContent]=\"'INITIALS' | reLocalize\"></label>\r\n                <span class=\"value\" [textContent]=\"relation.initials\"></span>\r\n              </div>\r\n            </div>\r\n            <div class=\"relation-data-row\">\r\n              <div class=\"non-editable-column\">\r\n                <label class=\"label\" [textContent]=\"'NAME' | reLocalize\"></label>\r\n                <span\r\n                  class=\"value\"\r\n                  [textContent]=\"relation.firstName + (relation.prefix ? ' ' + relation.prefix : '') + ' ' + relation.familyName\">\r\n                      </span>\r\n              </div>\r\n            </div>\r\n            <div class=\"relation-data-row\">\r\n              <div class=\"non-editable-column\">\r\n                <label class=\"label\" [textContent]=\"'GENDER' | reLocalize\"></label>\r\n                <span class=\"value\" [textContent]=\"getGenderLabel(relation.gender) | reLocalize\"></span>\r\n              </div>\r\n              <div class=\"non-editable-column\">\r\n                <label class=\"label\" [textContent]=\"'LANGUAGE' | reLocalize\"></label>\r\n                <span class=\"value\" [textContent]=\"relation.language\"></span>\r\n              </div>\r\n            </div>\r\n            <div class=\"relation-data-row\">\r\n              <div class=\"non-editable-column\">\r\n                <label class=\"label\" [textContent]=\"'EMAIL' | reLocalize\"></label>\r\n                <span class=\"value\" [textContent]=\"relation.primaryEmail\"></span>\r\n              </div>\r\n              <div class=\"non-editable-column\">\r\n                <label class=\"label\" [textContent]=\"'PHONE' | reLocalize\"></label>\r\n                <span class=\"value\" [textContent]=\"relation.primaryPhoneOrMobileNumber\"></span>\r\n              </div>\r\n            </div>\r\n          </div>\r\n          <co-relation-avatar [relation]=\"relation\" [canChangeAvatar]=\"false\"></co-relation-avatar>\r\n        </div>\r\n        <div class=\"switch-editable\" *ngIf=\"forceReadOnly\" (click)=\"forceReadOnly = false\">\r\n          <span [textContent]=\"'EDIT' | reLocalize\"></span>\r\n        </div>\r\n      </div>\r\n      <div class=\"relation-section\">\r\n        <div class=\"relation-section-label\" [textContent]=\"'ADDRESSES' | reLocalize\"></div>\r\n        <co-relation-addresses [(relation)]=\"relation\"></co-relation-addresses>\r\n      </div>\r\n      <div class=\"relation-section\">\r\n        <div class=\"relation-section-label\" [textContent]=\"'PRIVACY_PREFERENCES' | reLocalize\"></div>\r\n        <co-relation-preferences [(relation)]=\"relation\"></co-relation-preferences>\r\n      </div>\r\n\r\n    </ng-container>\r\n  `,\r\n  providers: [\r\n    {provide: BaseModuleScreenConfigService, useExisting: RelationScreenConfigurationService}\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class RelationComponent implements OnInit, OnDestroy {\r\n  public readonly icons: typeof Icon = Icon;\r\n\r\n  @Input()\r\n  public loadRelationFromLoginResponse: boolean = false;\r\n\r\n  @Input()\r\n  public forceReadOnly: boolean = true;\r\n\r\n  @Input()\r\n  public customerPortal: boolean = false;\r\n\r\n  @HostBinding('class.co-relation')\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public relation: RelationAnyType;\r\n  public relationTitle: string;\r\n  public collection: Title[] = [];\r\n  private _subs: Subscription[] = [];\r\n\r\n  constructor(\r\n    protected relationEventService: RelationEventService,\r\n    private _translationService: CoreComponentsTranslationService,\r\n    private _settingsService: RelationSettingsService,\r\n    private _relationConnectorService: RelationConnectorService,\r\n    private _relationService: RelationService,\r\n    public iconCacheService: IconCacheService\r\n  ) {\r\n    const dictionaries: Dictionaries = new Dictionaries();\r\n    this._translationService.setTranslation(dictionaries[this._settingsService.dictionaryKey]);\r\n  }\r\n\r\n  ngOnInit() {\r\n    if (this.loadRelationFromLoginResponse) {\r\n      this._relationService.relationId = this._relationConnectorService.loginResponse.relationId;\r\n    }\r\n    this._subs.push(\r\n      this.relationEventService.relationLoaded.subscribe(async (relation: RelationAnyType) => {\r\n        if (relation && relation.relationId) {\r\n          this.relation = relation;\r\n          await this.getTitleCollection();\r\n          this.relationTitle = this.getTitleForRelation(this.relation);\r\n        }\r\n      })\r\n    )\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this._subs.forEach(s => s.unsubscribe());\r\n  }\r\n\r\n  public async handleSaveClick(): Promise<void> {\r\n    const success: boolean = await this._relationService.saveRelation();\r\n    if (success) {\r\n      this.forceReadOnly = true;\r\n    }\r\n  }\r\n\r\n  public async getTitleCollection(): Promise<void> {\r\n    this.collection = await this._relationConnectorService.getTitles();\r\n  }\r\n\r\n  public getTitleForRelation(relation: RelationAnyType): string {\r\n    let title: Title = this.collection.find(title => title.titleId === relation.titleId);\r\n    if (title) {\r\n      return title.description;\r\n    } else {\r\n      return \"\";\r\n    }\r\n  }\r\n\r\n  public getGenderLabel(gender: string): string {\r\n    switch (gender) {\r\n      case 'M':\r\n        return 'MALE';\r\n      case 'V':\r\n        return 'FEMALE';\r\n      case 'O':\r\n        return 'Unspecified';\r\n      default:\r\n        return '';\r\n    }\r\n  }\r\n}\r\n"]}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { __awaiter } from "tslib";
|
|
2
2
|
import { Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation } from '@angular/core';
|
|
3
3
|
import { Address } from '@colijnit/relationapi/build/model/address.bo';
|
|
4
|
-
import { DictionaryService } from '../../service/dictionary.service';
|
|
5
4
|
import { FormMasterService } from '@colijnit/corecomponents_v12';
|
|
6
5
|
import { RelationService } from '../../service/relation.service';
|
|
7
6
|
import { RelationConnectorService } from '../../service/relation-connector.service';
|
|
8
7
|
import { isNill } from '@colijnit/ioneconnector/build/utils/function/is-nill.function';
|
|
9
8
|
import { StringUtils } from '@colijnit/ioneconnector/build/utils/string-utils';
|
|
9
|
+
import { RelationDictionaryService } from '../../translation/relation-dictionary.service';
|
|
10
10
|
export class RelationAddressComponent {
|
|
11
11
|
constructor(_dictionary, _relationConnectorService, _formMasterService, relationService) {
|
|
12
12
|
this._dictionary = _dictionary;
|
|
@@ -152,7 +152,7 @@ RelationAddressComponent.decorators = [
|
|
|
152
152
|
},] }
|
|
153
153
|
];
|
|
154
154
|
RelationAddressComponent.ctorParameters = () => [
|
|
155
|
-
{ type:
|
|
155
|
+
{ type: RelationDictionaryService },
|
|
156
156
|
{ type: RelationConnectorService },
|
|
157
157
|
{ type: FormMasterService },
|
|
158
158
|
{ type: RelationService }
|
|
@@ -163,4 +163,4 @@ RelationAddressComponent.propDecorators = {
|
|
|
163
163
|
addressChange: [{ type: Output }],
|
|
164
164
|
showClass: [{ type: HostBinding, args: ["class.co-relation-address",] }]
|
|
165
165
|
};
|
|
166
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relation-address.component.js","sourceRoot":"","sources":["../../../../../../projects/relation/src/lib/component/relation-address/relation-address.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewEncapsulation} from '@angular/core';\r\nimport {RelationAddressCfgNames} from '../../interface/relation-address-cfg-names.interface';\r\nimport {Address} from '@colijnit/relationapi/build/model/address.bo';\r\nimport {Country} from '@colijnit/ioneconnector/build/model/country.bo';\r\nimport {DictionaryService} from '../../service/dictionary.service';\r\nimport {FormMasterService} from '@colijnit/corecomponents_v12';\r\nimport {RelationService} from '../../service/relation.service';\r\nimport {RelationConnectorService} from '../../service/relation-connector.service';\r\nimport {isNill} from '@colijnit/ioneconnector/build/utils/function/is-nill.function';\r\nimport {StringUtils} from '@colijnit/ioneconnector/build/utils/string-utils';\r\nimport {GetPostalCodeRetrievalOutputParams} from '@colijnit/mainapi/build/model/get-postal-code-retrieval-output-params';\r\n\r\n@Component({\r\n  selector: 'co-relation-address',\r\n  template: `\r\n      <div class=\"relation-address-data-row\">\r\n          <co-input-text\r\n                  [(model)]=\"address.postalCode\"\r\n                  [placeholder]=\"'POSTAL_CODE' | reLocalize\"\r\n                  (blur)=\"checkForPostalCodeCheckError()\"\r\n                  (modelChange)=\"handlePostalCodeChange()\"\r\n                  required\r\n          ></co-input-text>\r\n          <co-input-text class=\"default-width\"\r\n                         [(model)]=\"address.houseNo\"\r\n                         [placeholder]=\"'HOUSE_NO' | reLocalize\"\r\n                         [digitsOnly]=\"true\"\r\n                         (blur)=\"checkForPostalCodeCheckError()\"\r\n                         (modelChange)=\"changeHouseNo()\"\r\n                         required\r\n          ></co-input-text>\r\n          <co-input-text\r\n                  [(model)]=\"address.houseNoAddition\"\r\n                  [placeholder]=\"'HOUSE_NO_ADDITION' | reLocalize\"\r\n          ></co-input-text>\r\n      </div>\r\n      <div class=\"relation-address-data-row\">\r\n          <co-input-text\r\n                  [(model)]=\"address.streetName\"\r\n                  [placeholder]=\"'STREET' | reLocalize\" required\r\n                  (modelChange)=\"handleStreetChange()\"></co-input-text>\r\n          <co-input-text\r\n                  [(model)]=\"address.city\"\r\n                  [placeholder]=\"'CITY' | reLocalize\" required\r\n                  (modelChange)=\"handleCityChange()\"></co-input-text>\r\n      </div>\r\n      <div class=\"relation-address-data-row default single\">\r\n          <co-list-of-values\r\n                  [model]=\"countryModel\"\r\n                  [collection]=\"countries\"\r\n                  [displayField]=\"'description'\"\r\n                  [label]=\"'COUNTRY' | reLocalize\"\r\n                  [required]=\"true\"\r\n                  (modelChange)=\"handleCountryChange($event)\"\r\n          ></co-list-of-values>\r\n      </div>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class RelationAddressComponent implements OnInit {\r\n  @Input()\r\n  public configNames: RelationAddressCfgNames;\r\n\r\n  @Input()\r\n  public set address(value: Address) {\r\n    this._address = value;\r\n    this._setSelectedAddress();\r\n  }\r\n\r\n  public get address(): Address {\r\n    return this._address;\r\n  }\r\n\r\n  @Output()\r\n  public addressChange: EventEmitter<Address> = new EventEmitter<Address>();\r\n\r\n  @HostBinding(\"class.co-relation-address\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  public countries: Country[] = [];\r\n  public fields: Object = {text: \"description\", value: \"code\"};\r\n  public countryModel: Country;\r\n\r\n  public postalCodeCheckErrorMessage: string = \"\";\r\n  private _prevPostalCodeForCheck: string = \"\";\r\n  private _prevHouseNoForCheck: number;\r\n  private _address: Address = new Address();\r\n\r\n  public constructor(\r\n    private _dictionary: DictionaryService,\r\n    private _relationConnectorService: RelationConnectorService,\r\n    private _formMasterService: FormMasterService,\r\n    protected relationService: RelationService\r\n  ) {\r\n  }\r\n\r\n  async ngOnInit(): Promise<void> {\r\n    this._relationConnectorService.getCountries().then((countries: Country[]) => {\r\n      this.countries = countries;\r\n      this._setSelectedAddress();\r\n    });\r\n  }\r\n\r\n  public async checkForPostalCodeCheckError(): Promise<void> {\r\n    if (!this.address.postalCode || isNill(this.address.houseNo)) {\r\n      this.postalCodeCheckErrorMessage = \"\";\r\n      return;\r\n    }\r\n\r\n    if (this._prevPostalCodeForCheck !== this.address.postalCode || this._prevHouseNoForCheck !== this.address.houseNo) {\r\n      this._prevPostalCodeForCheck = this.address.postalCode;\r\n      this._prevHouseNoForCheck = this.address.houseNo;\r\n      const postalCodeResponse: GetPostalCodeRetrievalOutputParams = await this._relationConnectorService.getPostalCodeRetrieval((this.address.postalCode ? this.address.postalCode : \"\"),\r\n        StringUtils.ParseString(this.address.houseNo));\r\n      if (postalCodeResponse && postalCodeResponse.isBadAddress) {\r\n        this.postalCodeCheckErrorMessage = this._dictionary.get(\"UNKNOWN_ADDRESS_CHECK_IT\");\r\n      } else if (postalCodeResponse.status && postalCodeResponse.status.toLowerCase().indexOf(\"fout\") < 0) {\r\n        this.postalCodeCheckErrorMessage = \"\";\r\n        this.address.streetName = postalCodeResponse.street;\r\n        this.address.city = postalCodeResponse.city;\r\n      }\r\n    }\r\n  }\r\n\r\n  public changeHouseNo(): void {\r\n    if (this.address) {\r\n      this.address.houseNo = Number(this.address.houseNo);\r\n      // this.suggestionRequest.houseNr = this.address.houseNo;\r\n      // this.inputChangeForSuggestions.next(this.suggestionRequest);\r\n    }\r\n  }\r\n\r\n  public handleCountryChange(country: Country): void {\r\n    this.countryModel = country;\r\n    if (this.address) {\r\n      this.address.countryId = this.countryModel.code;\r\n      // this.suggestionRequest.country = country.description;\r\n      // this.inputChangeForSuggestions.next(this.suggestionRequest);\r\n    }\r\n  }\r\n\r\n  public handlePostalCodeChange(): void {\r\n    if (this.address) {\r\n      // this.suggestionRequest.postalCode = this.address.postalCode;\r\n      // this.inputChangeForSuggestions.next(this.suggestionRequest);\r\n    }\r\n  }\r\n\r\n  public handleStreetChange(): void {\r\n    if (this.address) {\r\n      // this.suggestionRequest.street = this.address.streetName;\r\n      // this.inputChangeForSuggestions.next(this.suggestionRequest);\r\n    }\r\n  }\r\n\r\n  public handleCityChange(): void {\r\n    if (this.address) {\r\n      // this.suggestionRequest.city = this.address.city;\r\n      // this.inputChangeForSuggestions.next(this.suggestionRequest);\r\n    }\r\n  }\r\n\r\n  private _setSelectedAddress(): void {\r\n    if (!this.address || !this.countries) {\r\n      return;\r\n    }\r\n    if (!this.address.countryId) {\r\n      this.address.countryId = \"NL\";\r\n    }\r\n    this.countryModel = this.countries.find(c => c.code === this.address.countryId);\r\n  }\r\n} \r\n"]}
|
|
166
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relation-address.component.js","sourceRoot":"","sources":["../../../../../../projects/relation/src/lib/component/relation-address/relation-address.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewEncapsulation} from '@angular/core';\r\nimport {RelationAddressCfgNames} from '../../interface/relation-address-cfg-names.interface';\r\nimport {Address} from '@colijnit/relationapi/build/model/address.bo';\r\nimport {Country} from '@colijnit/ioneconnector/build/model/country.bo';\r\nimport {FormMasterService} from '@colijnit/corecomponents_v12';\r\nimport {RelationService} from '../../service/relation.service';\r\nimport {RelationConnectorService} from '../../service/relation-connector.service';\r\nimport {isNill} from '@colijnit/ioneconnector/build/utils/function/is-nill.function';\r\nimport {StringUtils} from '@colijnit/ioneconnector/build/utils/string-utils';\r\nimport {GetPostalCodeRetrievalOutputParams} from '@colijnit/mainapi/build/model/get-postal-code-retrieval-output-params';\r\nimport {RelationDictionaryService} from '../../translation/relation-dictionary.service';\r\n\r\n@Component({\r\n  selector: 'co-relation-address',\r\n  template: `\r\n      <div class=\"relation-address-data-row\">\r\n          <co-input-text\r\n                  [(model)]=\"address.postalCode\"\r\n                  [placeholder]=\"'POSTAL_CODE' | reLocalize\"\r\n                  (blur)=\"checkForPostalCodeCheckError()\"\r\n                  (modelChange)=\"handlePostalCodeChange()\"\r\n                  required\r\n          ></co-input-text>\r\n          <co-input-text class=\"default-width\"\r\n                         [(model)]=\"address.houseNo\"\r\n                         [placeholder]=\"'HOUSE_NO' | reLocalize\"\r\n                         [digitsOnly]=\"true\"\r\n                         (blur)=\"checkForPostalCodeCheckError()\"\r\n                         (modelChange)=\"changeHouseNo()\"\r\n                         required\r\n          ></co-input-text>\r\n          <co-input-text\r\n                  [(model)]=\"address.houseNoAddition\"\r\n                  [placeholder]=\"'HOUSE_NO_ADDITION' | reLocalize\"\r\n          ></co-input-text>\r\n      </div>\r\n      <div class=\"relation-address-data-row\">\r\n          <co-input-text\r\n                  [(model)]=\"address.streetName\"\r\n                  [placeholder]=\"'STREET' | reLocalize\" required\r\n                  (modelChange)=\"handleStreetChange()\"></co-input-text>\r\n          <co-input-text\r\n                  [(model)]=\"address.city\"\r\n                  [placeholder]=\"'CITY' | reLocalize\" required\r\n                  (modelChange)=\"handleCityChange()\"></co-input-text>\r\n      </div>\r\n      <div class=\"relation-address-data-row default single\">\r\n          <co-list-of-values\r\n                  [model]=\"countryModel\"\r\n                  [collection]=\"countries\"\r\n                  [displayField]=\"'description'\"\r\n                  [label]=\"'COUNTRY' | reLocalize\"\r\n                  [required]=\"true\"\r\n                  (modelChange)=\"handleCountryChange($event)\"\r\n          ></co-list-of-values>\r\n      </div>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class RelationAddressComponent implements OnInit {\r\n  @Input()\r\n  public configNames: RelationAddressCfgNames;\r\n\r\n  @Input()\r\n  public set address(value: Address) {\r\n    this._address = value;\r\n    this._setSelectedAddress();\r\n  }\r\n\r\n  public get address(): Address {\r\n    return this._address;\r\n  }\r\n\r\n  @Output()\r\n  public addressChange: EventEmitter<Address> = new EventEmitter<Address>();\r\n\r\n  @HostBinding(\"class.co-relation-address\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  public countries: Country[] = [];\r\n  public fields: Object = {text: \"description\", value: \"code\"};\r\n  public countryModel: Country;\r\n\r\n  public postalCodeCheckErrorMessage: string = \"\";\r\n  private _prevPostalCodeForCheck: string = \"\";\r\n  private _prevHouseNoForCheck: number;\r\n  private _address: Address = new Address();\r\n\r\n  public constructor(\r\n    private _dictionary: RelationDictionaryService,\r\n    private _relationConnectorService: RelationConnectorService,\r\n    private _formMasterService: FormMasterService,\r\n    protected relationService: RelationService\r\n  ) {\r\n  }\r\n\r\n  async ngOnInit(): Promise<void> {\r\n    this._relationConnectorService.getCountries().then((countries: Country[]) => {\r\n      this.countries = countries;\r\n      this._setSelectedAddress();\r\n    });\r\n  }\r\n\r\n  public async checkForPostalCodeCheckError(): Promise<void> {\r\n    if (!this.address.postalCode || isNill(this.address.houseNo)) {\r\n      this.postalCodeCheckErrorMessage = \"\";\r\n      return;\r\n    }\r\n\r\n    if (this._prevPostalCodeForCheck !== this.address.postalCode || this._prevHouseNoForCheck !== this.address.houseNo) {\r\n      this._prevPostalCodeForCheck = this.address.postalCode;\r\n      this._prevHouseNoForCheck = this.address.houseNo;\r\n      const postalCodeResponse: GetPostalCodeRetrievalOutputParams = await this._relationConnectorService.getPostalCodeRetrieval((this.address.postalCode ? this.address.postalCode : \"\"),\r\n        StringUtils.ParseString(this.address.houseNo));\r\n      if (postalCodeResponse && postalCodeResponse.isBadAddress) {\r\n        this.postalCodeCheckErrorMessage = this._dictionary.get(\"UNKNOWN_ADDRESS_CHECK_IT\");\r\n      } else if (postalCodeResponse.status && postalCodeResponse.status.toLowerCase().indexOf(\"fout\") < 0) {\r\n        this.postalCodeCheckErrorMessage = \"\";\r\n        this.address.streetName = postalCodeResponse.street;\r\n        this.address.city = postalCodeResponse.city;\r\n      }\r\n    }\r\n  }\r\n\r\n  public changeHouseNo(): void {\r\n    if (this.address) {\r\n      this.address.houseNo = Number(this.address.houseNo);\r\n      // this.suggestionRequest.houseNr = this.address.houseNo;\r\n      // this.inputChangeForSuggestions.next(this.suggestionRequest);\r\n    }\r\n  }\r\n\r\n  public handleCountryChange(country: Country): void {\r\n    this.countryModel = country;\r\n    if (this.address) {\r\n      this.address.countryId = this.countryModel.code;\r\n      // this.suggestionRequest.country = country.description;\r\n      // this.inputChangeForSuggestions.next(this.suggestionRequest);\r\n    }\r\n  }\r\n\r\n  public handlePostalCodeChange(): void {\r\n    if (this.address) {\r\n      // this.suggestionRequest.postalCode = this.address.postalCode;\r\n      // this.inputChangeForSuggestions.next(this.suggestionRequest);\r\n    }\r\n  }\r\n\r\n  public handleStreetChange(): void {\r\n    if (this.address) {\r\n      // this.suggestionRequest.street = this.address.streetName;\r\n      // this.inputChangeForSuggestions.next(this.suggestionRequest);\r\n    }\r\n  }\r\n\r\n  public handleCityChange(): void {\r\n    if (this.address) {\r\n      // this.suggestionRequest.city = this.address.city;\r\n      // this.inputChangeForSuggestions.next(this.suggestionRequest);\r\n    }\r\n  }\r\n\r\n  private _setSelectedAddress(): void {\r\n    if (!this.address || !this.countries) {\r\n      return;\r\n    }\r\n    if (!this.address.countryId) {\r\n      this.address.countryId = \"NL\";\r\n    }\r\n    this.countryModel = this.countries.find(c => c.code === this.address.countryId);\r\n  }\r\n} \r\n"]}
|
|
@@ -37,10 +37,10 @@ RelationAddressTileComponent.decorators = [
|
|
|
37
37
|
<span class="relation-address-name" [textContent]="address.addressName"></span>
|
|
38
38
|
<span class="relation-address-address" [textContent]="address.displayAddress"></span>
|
|
39
39
|
<span class="relation-address-postal" [textContent]="address.displayPostal"></span>
|
|
40
|
-
|
|
40
|
+
<!--span class="relation-address-country" [textContent]="address.displayCountry"></span-->
|
|
41
41
|
</div>
|
|
42
42
|
<div class="relation-address-edit" (click)="handleEditAddressClick($event)">
|
|
43
|
-
<co-icon class="relation-address-edit-icon" [iconData]="iconCacheService.getIcon(icons.
|
|
43
|
+
<co-icon class="relation-address-edit-icon" [iconData]="iconCacheService.getIcon(icons.PencilRegular)"></co-icon>
|
|
44
44
|
</div>
|
|
45
45
|
</co-tile-select>
|
|
46
46
|
</ng-container>
|
|
@@ -69,4 +69,4 @@ RelationAddressTileComponent.propDecorators = {
|
|
|
69
69
|
addAddressClicked: [{ type: Output }],
|
|
70
70
|
editAddressClicked: [{ type: Output }]
|
|
71
71
|
};
|
|
72
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVsYXRpb24tYWRkcmVzcy10aWxlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3JlbGF0aW9uL3NyYy9saWIvY29tcG9uZW50L3JlbGF0aW9uLWFkZHJlc3MtdGlsZS9yZWxhdGlvbi1hZGRyZXNzLXRpbGUuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsWUFBWSxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLGlCQUFpQixFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRXJHLE9BQU8sRUFBQyxJQUFJLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUMxQyxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxrQ0FBa0MsQ0FBQztBQThCbEUsTUFBTSxPQUFPLDRCQUE0QjtJQTJCdkMsWUFBbUIsZ0JBQWtDO1FBQWxDLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7UUExQnJDLFVBQUssR0FBZ0IsSUFBSSxDQUFDO1FBR25DLGNBQVMsR0FBWSxJQUFJLENBQUM7UUFNMUIsYUFBUSxHQUFZLEtBQUssQ0FBQztRQUcxQixhQUFRLEdBQVksS0FBSyxDQUFDO1FBRzFCLGlCQUFZLEdBQVksS0FBSyxDQUFDO1FBRzlCLG1CQUFjLEdBQTBCLElBQUksWUFBWSxFQUFXLENBQUM7UUFHcEUsc0JBQWlCLEdBQXVCLElBQUksWUFBWSxFQUFRLENBQUM7UUFHakUsdUJBQWtCLEdBQTBCLElBQUksWUFBWSxFQUFXLENBQUM7SUFHL0UsQ0FBQztJQUVNLHNCQUFzQixDQUFDLEtBQWlCO1FBQzdDLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUN2QixLQUFLLENBQUMsZUFBZSxFQUFFLENBQUM7UUFDeEIsS0FBSyxDQUFDLHdCQUF3QixFQUFFLENBQUM7UUFDakMsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDN0MsQ0FBQztJQUVNLG9CQUFvQixDQUFDLE9BQWdCO1FBQzFDLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ2xCLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDO1lBQ3JCLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1NBQ25DO0lBQ0gsQ0FBQzs7O1lBdEVGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsMEJBQTBCO2dCQUNwQyxRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBdUJUO2dCQUNELGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO2FBQ3RDOzs7WUE3Qk8sZ0JBQWdCOzs7d0JBaUNyQixXQUFXLFNBQUMsZ0NBQWdDO3NCQUc1QyxLQUFLO3VCQUdMLEtBQUs7dUJBR0wsS0FBSzsyQkFHTCxLQUFLOzZCQUdMLE1BQU07Z0NBR04sTUFBTTtpQ0FHTixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSG9zdEJpbmRpbmcsIElucHV0LCBPdXRwdXQsIFZpZXdFbmNhcHN1bGF0aW9ufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHtBZGRyZXNzfSBmcm9tICdAY29saWpuaXQvcmVsYXRpb25hcGkvYnVpbGQvbW9kZWwvYWRkcmVzcy5ibyc7XHJcbmltcG9ydCB7SWNvbn0gZnJvbSAnLi4vLi4vZW51bS9pY29uLmVudW0nO1xyXG5pbXBvcnQge0ljb25DYWNoZVNlcnZpY2V9IGZyb20gJy4uLy4uL3NlcnZpY2UvaWNvbi1jYWNoZS5zZXJ2aWNlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiBcImNvLXJlbGF0aW9uLWFkZHJlc3MtdGlsZVwiLFxyXG4gIHRlbXBsYXRlOiBgXHJcbiAgICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCIhYWN0QXNBZGRUaWxlXCI+XHJcbiAgICAgICAgICA8Y28tdGlsZS1zZWxlY3QgW3NlbGVjdGVkXT1cInNlbGVjdGVkXCIgW3JlYWRvbmx5XT1cInJlYWRvbmx5XCIgKHNlbGVjdGVkQ2hhbmdlKT1cImhhbmRsZVNlbGVjdGVkQ2hhbmdlKGFkZHJlc3MpXCI+XHJcbiAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cInJlbGF0aW9uLWNvbnRlbnQtd3JhcHBlclwiPlxyXG4gICAgICAgICAgICAgICAgICA8c3BhbiBjbGFzcz1cInJlbGF0aW9uLWFkZHJlc3MtdHlwZVwiIFt0ZXh0Q29udGVudF09XCJhZGRyZXNzLmRpc3BsYXlUeXBlIHwgcmVMb2NhbGl6ZVwiPjwvc3Bhbj5cclxuICAgICAgICAgICAgICAgICAgPHNwYW4gY2xhc3M9XCJyZWxhdGlvbi1hZGRyZXNzLW5hbWVcIiBbdGV4dENvbnRlbnRdPVwiYWRkcmVzcy5hZGRyZXNzTmFtZVwiPjwvc3Bhbj5cclxuICAgICAgICAgICAgICAgICAgPHNwYW4gY2xhc3M9XCJyZWxhdGlvbi1hZGRyZXNzLWFkZHJlc3NcIiBbdGV4dENvbnRlbnRdPVwiYWRkcmVzcy5kaXNwbGF5QWRkcmVzc1wiPjwvc3Bhbj5cclxuICAgICAgICAgICAgICAgICAgPHNwYW4gY2xhc3M9XCJyZWxhdGlvbi1hZGRyZXNzLXBvc3RhbFwiIFt0ZXh0Q29udGVudF09XCJhZGRyZXNzLmRpc3BsYXlQb3N0YWxcIj48L3NwYW4+
|
|
72
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVsYXRpb24tYWRkcmVzcy10aWxlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3JlbGF0aW9uL3NyYy9saWIvY29tcG9uZW50L3JlbGF0aW9uLWFkZHJlc3MtdGlsZS9yZWxhdGlvbi1hZGRyZXNzLXRpbGUuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsWUFBWSxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLGlCQUFpQixFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRXJHLE9BQU8sRUFBQyxJQUFJLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUMxQyxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxrQ0FBa0MsQ0FBQztBQThCbEUsTUFBTSxPQUFPLDRCQUE0QjtJQTJCdkMsWUFBbUIsZ0JBQWtDO1FBQWxDLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7UUExQnJDLFVBQUssR0FBZ0IsSUFBSSxDQUFDO1FBR25DLGNBQVMsR0FBWSxJQUFJLENBQUM7UUFNMUIsYUFBUSxHQUFZLEtBQUssQ0FBQztRQUcxQixhQUFRLEdBQVksS0FBSyxDQUFDO1FBRzFCLGlCQUFZLEdBQVksS0FBSyxDQUFDO1FBRzlCLG1CQUFjLEdBQTBCLElBQUksWUFBWSxFQUFXLENBQUM7UUFHcEUsc0JBQWlCLEdBQXVCLElBQUksWUFBWSxFQUFRLENBQUM7UUFHakUsdUJBQWtCLEdBQTBCLElBQUksWUFBWSxFQUFXLENBQUM7SUFHL0UsQ0FBQztJQUVNLHNCQUFzQixDQUFDLEtBQWlCO1FBQzdDLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUN2QixLQUFLLENBQUMsZUFBZSxFQUFFLENBQUM7UUFDeEIsS0FBSyxDQUFDLHdCQUF3QixFQUFFLENBQUM7UUFDakMsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDN0MsQ0FBQztJQUVNLG9CQUFvQixDQUFDLE9BQWdCO1FBQzFDLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ2xCLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDO1lBQ3JCLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1NBQ25DO0lBQ0gsQ0FBQzs7O1lBdEVGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsMEJBQTBCO2dCQUNwQyxRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBdUJUO2dCQUNELGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO2FBQ3RDOzs7WUE3Qk8sZ0JBQWdCOzs7d0JBaUNyQixXQUFXLFNBQUMsZ0NBQWdDO3NCQUc1QyxLQUFLO3VCQUdMLEtBQUs7dUJBR0wsS0FBSzsyQkFHTCxLQUFLOzZCQUdMLE1BQU07Z0NBR04sTUFBTTtpQ0FHTixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSG9zdEJpbmRpbmcsIElucHV0LCBPdXRwdXQsIFZpZXdFbmNhcHN1bGF0aW9ufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHtBZGRyZXNzfSBmcm9tICdAY29saWpuaXQvcmVsYXRpb25hcGkvYnVpbGQvbW9kZWwvYWRkcmVzcy5ibyc7XHJcbmltcG9ydCB7SWNvbn0gZnJvbSAnLi4vLi4vZW51bS9pY29uLmVudW0nO1xyXG5pbXBvcnQge0ljb25DYWNoZVNlcnZpY2V9IGZyb20gJy4uLy4uL3NlcnZpY2UvaWNvbi1jYWNoZS5zZXJ2aWNlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiBcImNvLXJlbGF0aW9uLWFkZHJlc3MtdGlsZVwiLFxyXG4gIHRlbXBsYXRlOiBgXHJcbiAgICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCIhYWN0QXNBZGRUaWxlXCI+XHJcbiAgICAgICAgICA8Y28tdGlsZS1zZWxlY3QgW3NlbGVjdGVkXT1cInNlbGVjdGVkXCIgW3JlYWRvbmx5XT1cInJlYWRvbmx5XCIgKHNlbGVjdGVkQ2hhbmdlKT1cImhhbmRsZVNlbGVjdGVkQ2hhbmdlKGFkZHJlc3MpXCI+XHJcbiAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cInJlbGF0aW9uLWNvbnRlbnQtd3JhcHBlclwiPlxyXG4gICAgICAgICAgICAgICAgICA8c3BhbiBjbGFzcz1cInJlbGF0aW9uLWFkZHJlc3MtdHlwZVwiIFt0ZXh0Q29udGVudF09XCJhZGRyZXNzLmRpc3BsYXlUeXBlIHwgcmVMb2NhbGl6ZVwiPjwvc3Bhbj5cclxuICAgICAgICAgICAgICAgICAgPHNwYW4gY2xhc3M9XCJyZWxhdGlvbi1hZGRyZXNzLW5hbWVcIiBbdGV4dENvbnRlbnRdPVwiYWRkcmVzcy5hZGRyZXNzTmFtZVwiPjwvc3Bhbj5cclxuICAgICAgICAgICAgICAgICAgPHNwYW4gY2xhc3M9XCJyZWxhdGlvbi1hZGRyZXNzLWFkZHJlc3NcIiBbdGV4dENvbnRlbnRdPVwiYWRkcmVzcy5kaXNwbGF5QWRkcmVzc1wiPjwvc3Bhbj5cclxuICAgICAgICAgICAgICAgICAgPHNwYW4gY2xhc3M9XCJyZWxhdGlvbi1hZGRyZXNzLXBvc3RhbFwiIFt0ZXh0Q29udGVudF09XCJhZGRyZXNzLmRpc3BsYXlQb3N0YWxcIj48L3NwYW4+XHJcbiAgICAgICAgICAgICAgICAgIDwhLS1zcGFuIGNsYXNzPVwicmVsYXRpb24tYWRkcmVzcy1jb3VudHJ5XCIgW3RleHRDb250ZW50XT1cImFkZHJlc3MuZGlzcGxheUNvdW50cnlcIj48L3NwYW4tLT5cclxuICAgICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVwicmVsYXRpb24tYWRkcmVzcy1lZGl0XCIgKGNsaWNrKT1cImhhbmRsZUVkaXRBZGRyZXNzQ2xpY2soJGV2ZW50KVwiPlxyXG4gICAgICAgICAgICAgICAgICA8Y28taWNvbiBjbGFzcz1cInJlbGF0aW9uLWFkZHJlc3MtZWRpdC1pY29uXCIgW2ljb25EYXRhXT1cImljb25DYWNoZVNlcnZpY2UuZ2V0SWNvbihpY29ucy5QZW5jaWxSZWd1bGFyKVwiPjwvY28taWNvbj5cclxuICAgICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgIDwvY28tdGlsZS1zZWxlY3Q+XHJcbiAgICAgIDwvbmctY29udGFpbmVyPlxyXG4gICAgICA8bmctY29udGFpbmVyICpuZ0lmPVwiYWN0QXNBZGRUaWxlICYmICFyZWFkb25seVwiPlxyXG4gICAgICAgICAgPGNvLXRpbGUgKGNsaWNrKT1cImFkZEFkZHJlc3NDbGlja2VkLmVtaXQoKVwiPlxyXG4gICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJyZWxhdGlvbi1jb250ZW50LXdyYXBwZXJcIj5cclxuICAgICAgICAgICAgICAgICAgPGNvLWljb24gY2xhc3M9XCJyZWxhdGlvbi1hZGRyZXNzLWljb25cIiBbaWNvbkRhdGFdPVwiaWNvbkNhY2hlU2VydmljZS5nZXRJY29uKGljb25zLlBsdXNTaW1wbGUpXCI+PC9jby1pY29uPlxyXG4gICAgICAgICAgICAgICAgICA8c3BhbiBbdGV4dENvbnRlbnRdPVwiJ0FERFJFU1NfQUREJyB8IHJlTG9jYWxpemVcIj48L3NwYW4+XHJcbiAgICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICA8L2NvLXRpbGU+XHJcbiAgICAgIDwvbmctY29udGFpbmVyPlxyXG4gIGAsXHJcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZVxyXG59KVxyXG5leHBvcnQgY2xhc3MgUmVsYXRpb25BZGRyZXNzVGlsZUNvbXBvbmVudCB7XHJcbiAgcHVibGljIHJlYWRvbmx5IGljb25zOiB0eXBlb2YgSWNvbiA9IEljb247XHJcblxyXG4gIEBIb3N0QmluZGluZyhcImNsYXNzLmNvLXJlbGF0aW9uLWFkZHJlc3MtdGlsZVwiKVxyXG4gIHB1YmxpYyBzaG93Q2xhc3M6IGJvb2xlYW4gPSB0cnVlO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBhZGRyZXNzOiBBZGRyZXNzO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyByZWFkb25seTogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBzZWxlY3RlZDogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBhY3RBc0FkZFRpbGU6IGJvb2xlYW4gPSBmYWxzZTtcclxuXHJcbiAgQE91dHB1dCgpXHJcbiAgcHVibGljIHNlbGVjdGVkQ2hhbmdlOiBFdmVudEVtaXR0ZXI8QWRkcmVzcz4gPSBuZXcgRXZlbnRFbWl0dGVyPEFkZHJlc3M+KCk7XHJcblxyXG4gIEBPdXRwdXQoKVxyXG4gIHB1YmxpYyBhZGRBZGRyZXNzQ2xpY2tlZDogRXZlbnRFbWl0dGVyPHZvaWQ+ID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xyXG5cclxuICBAT3V0cHV0KClcclxuICBwdWJsaWMgZWRpdEFkZHJlc3NDbGlja2VkOiBFdmVudEVtaXR0ZXI8QWRkcmVzcz4gPSBuZXcgRXZlbnRFbWl0dGVyPEFkZHJlc3M+KCk7XHJcblxyXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBpY29uQ2FjaGVTZXJ2aWNlOiBJY29uQ2FjaGVTZXJ2aWNlKSB7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgaGFuZGxlRWRpdEFkZHJlc3NDbGljayhldmVudDogTW91c2VFdmVudCk6IHZvaWQge1xyXG4gICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcclxuICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xyXG4gICAgZXZlbnQuc3RvcEltbWVkaWF0ZVByb3BhZ2F0aW9uKCk7XHJcbiAgICB0aGlzLmVkaXRBZGRyZXNzQ2xpY2tlZC5uZXh0KHRoaXMuYWRkcmVzcyk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgaGFuZGxlU2VsZWN0ZWRDaGFuZ2UoYWRkcmVzczogQWRkcmVzcyk6IHZvaWQge1xyXG4gICAgaWYgKCF0aGlzLnJlYWRvbmx5KSB7XHJcbiAgICAgIHRoaXMuc2VsZWN0ZWQgPSB0cnVlO1xyXG4gICAgICB0aGlzLnNlbGVjdGVkQ2hhbmdlLmVtaXQoYWRkcmVzcyk7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -83,7 +83,7 @@ RelationAddressesComponent.decorators = [
|
|
|
83
83
|
selector: 'co-relation-addresses',
|
|
84
84
|
template: `
|
|
85
85
|
<div class="relation-addresses-label" [textContent]="'DELIVERY_ADDRESS' | reLocalize"></div>
|
|
86
|
-
<
|
|
86
|
+
<div class="address-tile-wrapper" *ngIf="deliveryAddresses && deliveryAddresses.length > 0">
|
|
87
87
|
<co-relation-address-tile #carouselItem *ngFor="let address of deliveryAddresses; let index = index"
|
|
88
88
|
[address]="address"
|
|
89
89
|
[readonly]="readonly"
|
|
@@ -91,7 +91,7 @@ RelationAddressesComponent.decorators = [
|
|
|
91
91
|
(editAddressClicked)="editAddress($event)"
|
|
92
92
|
(selectedChange)="changeAddress($event)"
|
|
93
93
|
></co-relation-address-tile>
|
|
94
|
-
</
|
|
94
|
+
</div>
|
|
95
95
|
<div class="default-data-row" *ngIf="!readonly">
|
|
96
96
|
<div class="relation-address-new" (click)="showNewAddressDialog(addressType.DeliveryAddress)">
|
|
97
97
|
<co-icon class="relation-address-icon" [iconData]="iconCacheService.getIcon(icons.ArrowPointRight)"></co-icon>
|
|
@@ -99,7 +99,7 @@ RelationAddressesComponent.decorators = [
|
|
|
99
99
|
</div>
|
|
100
100
|
</div>
|
|
101
101
|
<div class="relation-addresses-label" [textContent]="'INVOICE_ADDRESS' | reLocalize"></div>
|
|
102
|
-
<
|
|
102
|
+
<div class="address-tile-wrapper" *ngIf="invoiceAddresses && invoiceAddresses.length > 0">
|
|
103
103
|
<co-relation-address-tile #carouselItem *ngFor="let address of invoiceAddresses; let index = index"
|
|
104
104
|
[address]="address"
|
|
105
105
|
[readonly]="readonly"
|
|
@@ -107,7 +107,7 @@ RelationAddressesComponent.decorators = [
|
|
|
107
107
|
(editAddressClicked)="editAddress($event)"
|
|
108
108
|
(selectedChange)="changeAddress($event)"
|
|
109
109
|
></co-relation-address-tile>
|
|
110
|
-
</
|
|
110
|
+
</div>
|
|
111
111
|
<div class="default-data-row" *ngIf="!readonly">
|
|
112
112
|
<div class="relation-address-new" (click)="showNewAddressDialog(addressType.BillingAddress)">
|
|
113
113
|
<co-icon class="relation-address-icon" [iconData]="iconCacheService.getIcon(icons.ArrowPointRight)"></co-icon>
|
|
@@ -117,8 +117,7 @@ RelationAddressesComponent.decorators = [
|
|
|
117
117
|
<co-dialog class="dialog-relation-addresses-create-address" *ngIf="showEditAddressDialog"
|
|
118
118
|
[footerTemplate]="templateFooter"
|
|
119
119
|
[headerTemplate]="templateHeader"
|
|
120
|
-
(closeClick)="showEditAddressDialog = false"
|
|
121
|
-
>
|
|
120
|
+
(closeClick)="showEditAddressDialog = false">
|
|
122
121
|
<co-form>
|
|
123
122
|
<co-relation-address
|
|
124
123
|
[(address)]="addressToEdit"
|
|
@@ -155,4 +154,4 @@ RelationAddressesComponent.ctorParameters = () => [
|
|
|
155
154
|
RelationAddressesComponent.propDecorators = {
|
|
156
155
|
showClass: [{ type: HostBinding, args: ['class.co-relation-addresses',] }]
|
|
157
156
|
};
|
|
158
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relation-addresses.component.js","sourceRoot":"","sources":["../../../../../../projects/relation/src/lib/component/relation-addresses/relation-addresses.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, HostBinding, ViewEncapsulation} from '@angular/core';\r\nimport {Address} from '@colijnit/relationapi/build/model/address.bo';\r\nimport {AddressType} from '@colijnit/relationapi/build/enum/address-type.enum';\r\nimport {RelationScreenConfigBaseComponent} from '../base/relation-screen-config-base.component';\r\nimport {BusinessObjectFactory} from '@colijnit/ioneconnector/build/service/business-object-factory';\r\nimport {FormMasterService} from '@colijnit/corecomponents_v12';\r\nimport {RelationService} from '../../service/relation.service';\r\nimport {IconCacheService} from '../../service/icon-cache.service';\r\nimport {RelationConnectorService} from '../../service/relation-connector.service';\r\nimport {RelationEventService} from '../../service/relation-event.service';\r\n\r\n@Component({\r\n  selector: 'co-relation-addresses',\r\n  template: `\r\n      <div class=\"relation-addresses-label\" [textContent]=\"'DELIVERY_ADDRESS' | reLocalize\"></div>\r\n      <co-carousel *ngIf=\"deliveryAddresses && deliveryAddresses.length > 0\">\r\n          <co-relation-address-tile #carouselItem *ngFor=\"let address of deliveryAddresses; let index = index\"\r\n                                    [address]=\"address\"\r\n                                    [readonly]=\"readonly\"\r\n                                    [selected]=\"address.sequence === 0\"\r\n                                    (editAddressClicked)=\"editAddress($event)\"\r\n                                    (selectedChange)=\"changeAddress($event)\"\r\n          ></co-relation-address-tile>\r\n      </co-carousel>\r\n      <div class=\"default-data-row\" *ngIf=\"!readonly\">\r\n          <div class=\"relation-address-new\" (click)=\"showNewAddressDialog(addressType.DeliveryAddress)\">\r\n              <co-icon class=\"relation-address-icon\" [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\"></co-icon>\r\n              <div [textContent]=\"'ADDRESS_ADD' | reLocalize\"></div>\r\n          </div>\r\n      </div>\r\n      <div class=\"relation-addresses-label\" [textContent]=\"'INVOICE_ADDRESS' | reLocalize\"></div>\r\n      <co-carousel *ngIf=\"invoiceAddresses && invoiceAddresses.length > 0\">\r\n          <co-relation-address-tile #carouselItem *ngFor=\"let address of invoiceAddresses; 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 class=\"default-data-row\" *ngIf=\"!readonly\">\r\n          <div class=\"relation-address-new\" (click)=\"showNewAddressDialog(addressType.BillingAddress)\">\r\n              <co-icon class=\"relation-address-icon\" [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\"></co-icon>\r\n              <div [textContent]=\"'ADDRESS_ADD' | reLocalize\"></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                      [(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' | reLocalize\"></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 RelationScreenConfigBaseComponent {\r\n  public readonly addressType: typeof AddressType = AddressType;\r\n\r\n  @HostBinding('class.co-relation-addresses')\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public deliveryAddresses: Address[] = [];\r\n  public invoiceAddresses: Address[] = [];\r\n  public addressToEdit: Address;\r\n  public selectedNawNr: number;\r\n  public showEditAddressDialog: boolean = false;\r\n\r\n  private _boFactory: BusinessObjectFactory = new BusinessObjectFactory();\r\n\r\n  constructor(\r\n    public relationService: RelationService,\r\n    public iconCacheService: IconCacheService,\r\n    protected relationConnectorService: RelationConnectorService,\r\n    protected relationEventService: RelationEventService,\r\n    private _formMasterService: FormMasterService\r\n  ) {\r\n    super(relationService, iconCacheService, relationConnectorService, relationEventService);\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    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.relationChange.next(this.relation);\r\n    this._setAddresses();\r\n    this.showEditAddressDialog = false;\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 showNewAddressDialog(type: AddressType): void {\r\n    this.addressToEdit = new Address();\r\n    this.addressToEdit.addressType = type;\r\n    this.showEditAddressDialog = true;\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  protected relationSet() {\r\n    this._setAddresses();\r\n  }\r\n\r\n  private _setAddresses(): void {\r\n    this.deliveryAddresses = this.relation.addresses.filter(a => a.isActive && a.addressType === AddressType.DeliveryAddress);\r\n    this.invoiceAddresses = this.relation.addresses.filter(a => a.isActive && a.addressType === AddressType.BillingAddress);\r\n  }\r\n} \r\n"]}
|
|
157
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relation-addresses.component.js","sourceRoot":"","sources":["../../../../../../projects/relation/src/lib/component/relation-addresses/relation-addresses.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, HostBinding, ViewEncapsulation} from '@angular/core';\r\nimport {Address} from '@colijnit/relationapi/build/model/address.bo';\r\nimport {AddressType} from '@colijnit/relationapi/build/enum/address-type.enum';\r\nimport {RelationScreenConfigBaseComponent} from '../base/relation-screen-config-base.component';\r\nimport {BusinessObjectFactory} from '@colijnit/ioneconnector/build/service/business-object-factory';\r\nimport {FormMasterService} from '@colijnit/corecomponents_v12';\r\nimport {RelationService} from '../../service/relation.service';\r\nimport {IconCacheService} from '../../service/icon-cache.service';\r\nimport {RelationConnectorService} from '../../service/relation-connector.service';\r\nimport {RelationEventService} from '../../service/relation-event.service';\r\n\r\n@Component({\r\n  selector: 'co-relation-addresses',\r\n  template: `\r\n      <div class=\"relation-addresses-label\" [textContent]=\"'DELIVERY_ADDRESS' | reLocalize\"></div>\r\n      <div class=\"address-tile-wrapper\" *ngIf=\"deliveryAddresses && deliveryAddresses.length > 0\">\r\n          <co-relation-address-tile #carouselItem *ngFor=\"let address of deliveryAddresses; let index = index\"\r\n                                    [address]=\"address\"\r\n                                    [readonly]=\"readonly\"\r\n                                    [selected]=\"address.sequence === 0\"\r\n                                    (editAddressClicked)=\"editAddress($event)\"\r\n                                    (selectedChange)=\"changeAddress($event)\"\r\n          ></co-relation-address-tile>\r\n      </div>\r\n      <div class=\"default-data-row\" *ngIf=\"!readonly\">\r\n          <div class=\"relation-address-new\" (click)=\"showNewAddressDialog(addressType.DeliveryAddress)\">\r\n              <co-icon class=\"relation-address-icon\" [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\"></co-icon>\r\n              <div [textContent]=\"'ADDRESS_ADD' | reLocalize\"></div>\r\n          </div>\r\n      </div>\r\n      <div class=\"relation-addresses-label\" [textContent]=\"'INVOICE_ADDRESS' | reLocalize\"></div>\r\n      <div class=\"address-tile-wrapper\" *ngIf=\"invoiceAddresses && invoiceAddresses.length > 0\">\r\n          <co-relation-address-tile #carouselItem *ngFor=\"let address of invoiceAddresses; 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      </div>\r\n      <div class=\"default-data-row\" *ngIf=\"!readonly\">\r\n          <div class=\"relation-address-new\" (click)=\"showNewAddressDialog(addressType.BillingAddress)\">\r\n              <co-icon class=\"relation-address-icon\" [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\"></co-icon>\r\n              <div [textContent]=\"'ADDRESS_ADD' | reLocalize\"></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          <co-form>\r\n              <co-relation-address\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' | reLocalize\"></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 RelationScreenConfigBaseComponent {\r\n  public readonly addressType: typeof AddressType = AddressType;\r\n\r\n  @HostBinding('class.co-relation-addresses')\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public deliveryAddresses: Address[] = [];\r\n  public invoiceAddresses: Address[] = [];\r\n  public addressToEdit: Address;\r\n  public selectedNawNr: number;\r\n  public showEditAddressDialog: boolean = false;\r\n\r\n  private _boFactory: BusinessObjectFactory = new BusinessObjectFactory();\r\n\r\n  constructor(\r\n    public relationService: RelationService,\r\n    public iconCacheService: IconCacheService,\r\n    protected relationConnectorService: RelationConnectorService,\r\n    protected relationEventService: RelationEventService,\r\n    private _formMasterService: FormMasterService\r\n  ) {\r\n    super(relationService, iconCacheService, relationConnectorService, relationEventService);\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    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.relationChange.next(this.relation);\r\n    this._setAddresses();\r\n    this.showEditAddressDialog = false;\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 showNewAddressDialog(type: AddressType): void {\r\n    this.addressToEdit = new Address();\r\n    this.addressToEdit.addressType = type;\r\n    this.showEditAddressDialog = true;\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  protected relationSet() {\r\n    this._setAddresses();\r\n  }\r\n\r\n  private _setAddresses(): void {\r\n    this.deliveryAddresses = this.relation.addresses.filter(a => a.isActive && a.addressType === AddressType.DeliveryAddress);\r\n    this.invoiceAddresses = this.relation.addresses.filter(a => a.isActive && a.addressType === AddressType.BillingAddress);\r\n  }\r\n}\r\n"]}
|