@colijnit/relation 256.1.1 → 256.1.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (40) hide show
  1. package/bundles/colijnit-relation.umd.js +232 -242
  2. package/bundles/colijnit-relation.umd.js.map +1 -1
  3. package/colijnit-relation-256.1.2.tgz +0 -0
  4. package/colijnit-relation.d.ts +11 -13
  5. package/colijnit-relation.metadata.json +1 -1
  6. package/esm2015/colijnit-relation.js +12 -14
  7. package/esm2015/lib/component/relation/relation.component.js +146 -42
  8. package/esm2015/lib/component/relation-address/relation-address.component.js +3 -3
  9. package/esm2015/lib/component/relation-address-tile/relation-address-tile.component.js +3 -3
  10. package/esm2015/lib/component/relation-addresses/relation-addresses.component.js +6 -7
  11. package/esm2015/lib/component/relation-preferences/relation-preferences.component.js +2 -2
  12. package/esm2015/lib/component/relation-title/relation-title.component.js +4 -3
  13. package/esm2015/lib/enum/icon.enum.js +2 -1
  14. package/esm2015/lib/model/icon-svg.js +2 -1
  15. package/esm2015/lib/relation-version.js +4 -4
  16. package/esm2015/lib/res/dictionary/dictionaries.js +3 -3
  17. package/esm2015/lib/service/error.service.js +5 -5
  18. package/esm2015/lib/service/relation-base.service.js +1 -1
  19. package/esm2015/lib/service/relation-settings.service.js +5 -5
  20. package/esm2015/public_api.js +2 -1
  21. package/fesm2015/colijnit-relation.js +263 -223
  22. package/fesm2015/colijnit-relation.js.map +1 -1
  23. package/lib/component/relation/relation.component.d.ts +14 -1
  24. package/lib/component/relation/style/_layout.scss +66 -2
  25. package/lib/component/relation/style/_material-definition.scss +2 -2
  26. package/lib/component/relation-address/relation-address.component.d.ts +2 -2
  27. package/lib/component/relation-address-tile/style/_layout.scss +34 -2
  28. package/lib/component/relation-address-tile/style/_material-definition.scss +1 -1
  29. package/lib/component/relation-addresses/style/_layout.scss +7 -0
  30. package/lib/component/relation-addresses/style/_material-definition.scss +1 -1
  31. package/lib/enum/icon.enum.d.ts +1 -0
  32. package/lib/res/dictionary/dictionaries.d.ts +45 -1
  33. package/lib/service/error.service.d.ts +2 -2
  34. package/lib/service/relation-settings.service.d.ts +2 -2
  35. package/lib/style/_variables.scss +1 -1
  36. package/package.json +1 -1
  37. package/public_api.d.ts +1 -0
  38. package/colijnit-relation-256.1.0.tgz +0 -0
  39. package/esm2015/lib/service/dictionary.service.js +0 -68
  40. package/lib/service/dictionary.service.d.ts +0 -18
@@ -2,21 +2,19 @@
2
2
  * Generated bundle index. Do not edit.
3
3
  */
4
4
  export * from './public_api';
5
- export { RelationBaseComponent as ɵl } from './lib/component/base/relation-base.component';
6
- export { RelationLoaderComponent as ɵq } from './lib/component/base/relation-loader.component';
7
- export { RelationScreenConfigBaseComponent as ɵk } from './lib/component/base/relation-screen-config-base.component';
8
- export { RelationContactOptionListComponent as ɵo } from './lib/component/relation-contact-options/relation-contact-option-list.component';
9
- export { RelationContactOptionComponent as ɵn } from './lib/component/relation-contact-options/relation-contact-option.component';
10
- export { RelationContactOptionsOtherTypesPopupComponent as ɵp } from './lib/component/relation-contact-options/relation-contact-options-other-types-popup.component';
11
- export { DictionaryService as ɵd } from './lib/service/dictionary.service';
12
- export { ErrorService as ɵe } from './lib/service/error.service';
13
- export { IconCacheService as ɵm } from './lib/service/icon-cache.service';
14
- export { RelationBaseService as ɵh } from './lib/service/relation-base.service';
5
+ export { RelationBaseComponent as ɵk } from './lib/component/base/relation-base.component';
6
+ export { RelationLoaderComponent as ɵo } from './lib/component/base/relation-loader.component';
7
+ export { RelationScreenConfigBaseComponent as ɵj } from './lib/component/base/relation-screen-config-base.component';
8
+ export { RelationContactOptionListComponent as ɵm } from './lib/component/relation-contact-options/relation-contact-option-list.component';
9
+ export { RelationContactOptionComponent as ɵl } from './lib/component/relation-contact-options/relation-contact-option.component';
10
+ export { RelationContactOptionsOtherTypesPopupComponent as ɵn } from './lib/component/relation-contact-options/relation-contact-options-other-types-popup.component';
11
+ export { ErrorService as ɵd } from './lib/service/error.service';
12
+ export { IconCacheService as ɵh } from './lib/service/icon-cache.service';
13
+ export { RelationBaseService as ɵg } from './lib/service/relation-base.service';
15
14
  export { RelationConnectorAdapterService as ɵb } from './lib/service/relation-connector-adapter.service';
16
- export { RelationConnectorService as ɵg } from './lib/service/relation-connector.service';
17
- export { RelationEventService as ɵf } from './lib/service/relation-event.service';
15
+ export { RelationConnectorService as ɵf } from './lib/service/relation-connector.service';
16
+ export { RelationEventService as ɵe } 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 ɵj } from './lib/translation/relation-dictionary.service';
21
19
  export { RelationLocalizePipe as ɵi } from './lib/translation/relation-localize.pipe';
22
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29saWpuaXQtcmVsYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wcm9qZWN0cy9yZWxhdGlvbi9zcmMvY29saWpuaXQtcmVsYXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQztBQUU3QixPQUFPLEVBQUMscUJBQXFCLElBQUksRUFBRSxFQUFDLE1BQU0sOENBQThDLENBQUM7QUFDekYsT0FBTyxFQUFDLHVCQUF1QixJQUFJLEVBQUUsRUFBQyxNQUFNLGdEQUFnRCxDQUFDO0FBQzdGLE9BQU8sRUFBQyxpQ0FBaUMsSUFBSSxFQUFFLEVBQUMsTUFBTSw0REFBNEQsQ0FBQztBQUNuSCxPQUFPLEVBQUMsa0NBQWtDLElBQUksRUFBRSxFQUFDLE1BQU0saUZBQWlGLENBQUM7QUFDekksT0FBTyxFQUFDLDhCQUE4QixJQUFJLEVBQUUsRUFBQyxNQUFNLDRFQUE0RSxDQUFDO0FBQ2hJLE9BQU8sRUFBQyw4Q0FBOEMsSUFBSSxFQUFFLEVBQUMsTUFBTSwrRkFBK0YsQ0FBQztBQUNuSyxPQUFPLEVBQUMsaUJBQWlCLElBQUksRUFBRSxFQUFDLE1BQU0sa0NBQWtDLENBQUM7QUFDekUsT0FBTyxFQUFDLFlBQVksSUFBSSxFQUFFLEVBQUMsTUFBTSw2QkFBNkIsQ0FBQztBQUMvRCxPQUFPLEVBQUMsZ0JBQWdCLElBQUksRUFBRSxFQUFDLE1BQU0sa0NBQWtDLENBQUM7QUFDeEUsT0FBTyxFQUFDLG1CQUFtQixJQUFJLEVBQUUsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQzlFLE9BQU8sRUFBQywrQkFBK0IsSUFBSSxFQUFFLEVBQUMsTUFBTSxrREFBa0QsQ0FBQztBQUN2RyxPQUFPLEVBQUMsd0JBQXdCLElBQUksRUFBRSxFQUFDLE1BQU0sMENBQTBDLENBQUM7QUFDeEYsT0FBTyxFQUFDLG9CQUFvQixJQUFJLEVBQUUsRUFBQyxNQUFNLHNDQUFzQyxDQUFDO0FBQ2hGLE9BQU8sRUFBQyxrQ0FBa0MsSUFBSSxFQUFFLEVBQUMsTUFBTSxxREFBcUQsQ0FBQztBQUM3RyxPQUFPLEVBQUMsdUJBQXVCLElBQUksRUFBRSxFQUFDLE1BQU0seUNBQXlDLENBQUM7QUFDdEYsT0FBTyxFQUFDLHlCQUF5QixJQUFJLEVBQUUsRUFBQyxNQUFNLCtDQUErQyxDQUFDO0FBQzlGLE9BQU8sRUFBQyxvQkFBb0IsSUFBSSxFQUFFLEVBQUMsTUFBTSwwQ0FBMEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWNfYXBpJztcblxuZXhwb3J0IHtSZWxhdGlvbkJhc2VDb21wb25lbnQgYXMgybVsfSBmcm9tICcuL2xpYi9jb21wb25lbnQvYmFzZS9yZWxhdGlvbi1iYXNlLmNvbXBvbmVudCc7XG5leHBvcnQge1JlbGF0aW9uTG9hZGVyQ29tcG9uZW50IGFzIMm1cX0gZnJvbSAnLi9saWIvY29tcG9uZW50L2Jhc2UvcmVsYXRpb24tbG9hZGVyLmNvbXBvbmVudCc7XG5leHBvcnQge1JlbGF0aW9uU2NyZWVuQ29uZmlnQmFzZUNvbXBvbmVudCBhcyDJtWt9IGZyb20gJy4vbGliL2NvbXBvbmVudC9iYXNlL3JlbGF0aW9uLXNjcmVlbi1jb25maWctYmFzZS5jb21wb25lbnQnO1xuZXhwb3J0IHtSZWxhdGlvbkNvbnRhY3RPcHRpb25MaXN0Q29tcG9uZW50IGFzIMm1b30gZnJvbSAnLi9saWIvY29tcG9uZW50L3JlbGF0aW9uLWNvbnRhY3Qtb3B0aW9ucy9yZWxhdGlvbi1jb250YWN0LW9wdGlvbi1saXN0LmNvbXBvbmVudCc7XG5leHBvcnQge1JlbGF0aW9uQ29udGFjdE9wdGlvbkNvbXBvbmVudCBhcyDJtW59IGZyb20gJy4vbGliL2NvbXBvbmVudC9yZWxhdGlvbi1jb250YWN0LW9wdGlvbnMvcmVsYXRpb24tY29udGFjdC1vcHRpb24uY29tcG9uZW50JztcbmV4cG9ydCB7UmVsYXRpb25Db250YWN0T3B0aW9uc090aGVyVHlwZXNQb3B1cENvbXBvbmVudCBhcyDJtXB9IGZyb20gJy4vbGliL2NvbXBvbmVudC9yZWxhdGlvbi1jb250YWN0LW9wdGlvbnMvcmVsYXRpb24tY29udGFjdC1vcHRpb25zLW90aGVyLXR5cGVzLXBvcHVwLmNvbXBvbmVudCc7XG5leHBvcnQge0RpY3Rpb25hcnlTZXJ2aWNlIGFzIMm1ZH0gZnJvbSAnLi9saWIvc2VydmljZS9kaWN0aW9uYXJ5LnNlcnZpY2UnO1xuZXhwb3J0IHtFcnJvclNlcnZpY2UgYXMgybVlfSBmcm9tICcuL2xpYi9zZXJ2aWNlL2Vycm9yLnNlcnZpY2UnO1xuZXhwb3J0IHtJY29uQ2FjaGVTZXJ2aWNlIGFzIMm1bX0gZnJvbSAnLi9saWIvc2VydmljZS9pY29uLWNhY2hlLnNlcnZpY2UnO1xuZXhwb3J0IHtSZWxhdGlvbkJhc2VTZXJ2aWNlIGFzIMm1aH0gZnJvbSAnLi9saWIvc2VydmljZS9yZWxhdGlvbi1iYXNlLnNlcnZpY2UnO1xuZXhwb3J0IHtSZWxhdGlvbkNvbm5lY3RvckFkYXB0ZXJTZXJ2aWNlIGFzIMm1Yn0gZnJvbSAnLi9saWIvc2VydmljZS9yZWxhdGlvbi1jb25uZWN0b3ItYWRhcHRlci5zZXJ2aWNlJztcbmV4cG9ydCB7UmVsYXRpb25Db25uZWN0b3JTZXJ2aWNlIGFzIMm1Z30gZnJvbSAnLi9saWIvc2VydmljZS9yZWxhdGlvbi1jb25uZWN0b3Iuc2VydmljZSc7XG5leHBvcnQge1JlbGF0aW9uRXZlbnRTZXJ2aWNlIGFzIMm1Zn0gZnJvbSAnLi9saWIvc2VydmljZS9yZWxhdGlvbi1ldmVudC5zZXJ2aWNlJztcbmV4cG9ydCB7UmVsYXRpb25TY3JlZW5Db25maWd1cmF0aW9uU2VydmljZSBhcyDJtWF9IGZyb20gJy4vbGliL3NlcnZpY2UvcmVsYXRpb24tc2NyZWVuLWNvbmZpZ3VyYXRpb24uc2VydmljZSc7XG5leHBvcnQge1JlbGF0aW9uU2V0dGluZ3NTZXJ2aWNlIGFzIMm1Y30gZnJvbSAnLi9saWIvc2VydmljZS9yZWxhdGlvbi1zZXR0aW5ncy5zZXJ2aWNlJztcbmV4cG9ydCB7UmVsYXRpb25EaWN0aW9uYXJ5U2VydmljZSBhcyDJtWp9IGZyb20gJy4vbGliL3RyYW5zbGF0aW9uL3JlbGF0aW9uLWRpY3Rpb25hcnkuc2VydmljZSc7XG5leHBvcnQge1JlbGF0aW9uTG9jYWxpemVQaXBlIGFzIMm1aX0gZnJvbSAnLi9saWIvdHJhbnNsYXRpb24vcmVsYXRpb24tbG9jYWxpemUucGlwZSc7Il19
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29saWpuaXQtcmVsYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wcm9qZWN0cy9yZWxhdGlvbi9zcmMvY29saWpuaXQtcmVsYXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQztBQUU3QixPQUFPLEVBQUMscUJBQXFCLElBQUksRUFBRSxFQUFDLE1BQU0sOENBQThDLENBQUM7QUFDekYsT0FBTyxFQUFDLHVCQUF1QixJQUFJLEVBQUUsRUFBQyxNQUFNLGdEQUFnRCxDQUFDO0FBQzdGLE9BQU8sRUFBQyxpQ0FBaUMsSUFBSSxFQUFFLEVBQUMsTUFBTSw0REFBNEQsQ0FBQztBQUNuSCxPQUFPLEVBQUMsa0NBQWtDLElBQUksRUFBRSxFQUFDLE1BQU0saUZBQWlGLENBQUM7QUFDekksT0FBTyxFQUFDLDhCQUE4QixJQUFJLEVBQUUsRUFBQyxNQUFNLDRFQUE0RSxDQUFDO0FBQ2hJLE9BQU8sRUFBQyw4Q0FBOEMsSUFBSSxFQUFFLEVBQUMsTUFBTSwrRkFBK0YsQ0FBQztBQUNuSyxPQUFPLEVBQUMsWUFBWSxJQUFJLEVBQUUsRUFBQyxNQUFNLDZCQUE2QixDQUFDO0FBQy9ELE9BQU8sRUFBQyxnQkFBZ0IsSUFBSSxFQUFFLEVBQUMsTUFBTSxrQ0FBa0MsQ0FBQztBQUN4RSxPQUFPLEVBQUMsbUJBQW1CLElBQUksRUFBRSxFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDOUUsT0FBTyxFQUFDLCtCQUErQixJQUFJLEVBQUUsRUFBQyxNQUFNLGtEQUFrRCxDQUFDO0FBQ3ZHLE9BQU8sRUFBQyx3QkFBd0IsSUFBSSxFQUFFLEVBQUMsTUFBTSwwQ0FBMEMsQ0FBQztBQUN4RixPQUFPLEVBQUMsb0JBQW9CLElBQUksRUFBRSxFQUFDLE1BQU0sc0NBQXNDLENBQUM7QUFDaEYsT0FBTyxFQUFDLGtDQUFrQyxJQUFJLEVBQUUsRUFBQyxNQUFNLHFEQUFxRCxDQUFDO0FBQzdHLE9BQU8sRUFBQyx1QkFBdUIsSUFBSSxFQUFFLEVBQUMsTUFBTSx5Q0FBeUMsQ0FBQztBQUN0RixPQUFPLEVBQUMsb0JBQW9CLElBQUksRUFBRSxFQUFDLE1BQU0sMENBQTBDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljX2FwaSc7XG5cbmV4cG9ydCB7UmVsYXRpb25CYXNlQ29tcG9uZW50IGFzIMm1a30gZnJvbSAnLi9saWIvY29tcG9uZW50L2Jhc2UvcmVsYXRpb24tYmFzZS5jb21wb25lbnQnO1xuZXhwb3J0IHtSZWxhdGlvbkxvYWRlckNvbXBvbmVudCBhcyDJtW99IGZyb20gJy4vbGliL2NvbXBvbmVudC9iYXNlL3JlbGF0aW9uLWxvYWRlci5jb21wb25lbnQnO1xuZXhwb3J0IHtSZWxhdGlvblNjcmVlbkNvbmZpZ0Jhc2VDb21wb25lbnQgYXMgybVqfSBmcm9tICcuL2xpYi9jb21wb25lbnQvYmFzZS9yZWxhdGlvbi1zY3JlZW4tY29uZmlnLWJhc2UuY29tcG9uZW50JztcbmV4cG9ydCB7UmVsYXRpb25Db250YWN0T3B0aW9uTGlzdENvbXBvbmVudCBhcyDJtW19IGZyb20gJy4vbGliL2NvbXBvbmVudC9yZWxhdGlvbi1jb250YWN0LW9wdGlvbnMvcmVsYXRpb24tY29udGFjdC1vcHRpb24tbGlzdC5jb21wb25lbnQnO1xuZXhwb3J0IHtSZWxhdGlvbkNvbnRhY3RPcHRpb25Db21wb25lbnQgYXMgybVsfSBmcm9tICcuL2xpYi9jb21wb25lbnQvcmVsYXRpb24tY29udGFjdC1vcHRpb25zL3JlbGF0aW9uLWNvbnRhY3Qtb3B0aW9uLmNvbXBvbmVudCc7XG5leHBvcnQge1JlbGF0aW9uQ29udGFjdE9wdGlvbnNPdGhlclR5cGVzUG9wdXBDb21wb25lbnQgYXMgybVufSBmcm9tICcuL2xpYi9jb21wb25lbnQvcmVsYXRpb24tY29udGFjdC1vcHRpb25zL3JlbGF0aW9uLWNvbnRhY3Qtb3B0aW9ucy1vdGhlci10eXBlcy1wb3B1cC5jb21wb25lbnQnO1xuZXhwb3J0IHtFcnJvclNlcnZpY2UgYXMgybVkfSBmcm9tICcuL2xpYi9zZXJ2aWNlL2Vycm9yLnNlcnZpY2UnO1xuZXhwb3J0IHtJY29uQ2FjaGVTZXJ2aWNlIGFzIMm1aH0gZnJvbSAnLi9saWIvc2VydmljZS9pY29uLWNhY2hlLnNlcnZpY2UnO1xuZXhwb3J0IHtSZWxhdGlvbkJhc2VTZXJ2aWNlIGFzIMm1Z30gZnJvbSAnLi9saWIvc2VydmljZS9yZWxhdGlvbi1iYXNlLnNlcnZpY2UnO1xuZXhwb3J0IHtSZWxhdGlvbkNvbm5lY3RvckFkYXB0ZXJTZXJ2aWNlIGFzIMm1Yn0gZnJvbSAnLi9saWIvc2VydmljZS9yZWxhdGlvbi1jb25uZWN0b3ItYWRhcHRlci5zZXJ2aWNlJztcbmV4cG9ydCB7UmVsYXRpb25Db25uZWN0b3JTZXJ2aWNlIGFzIMm1Zn0gZnJvbSAnLi9saWIvc2VydmljZS9yZWxhdGlvbi1jb25uZWN0b3Iuc2VydmljZSc7XG5leHBvcnQge1JlbGF0aW9uRXZlbnRTZXJ2aWNlIGFzIMm1ZX0gZnJvbSAnLi9saWIvc2VydmljZS9yZWxhdGlvbi1ldmVudC5zZXJ2aWNlJztcbmV4cG9ydCB7UmVsYXRpb25TY3JlZW5Db25maWd1cmF0aW9uU2VydmljZSBhcyDJtWF9IGZyb20gJy4vbGliL3NlcnZpY2UvcmVsYXRpb24tc2NyZWVuLWNvbmZpZ3VyYXRpb24uc2VydmljZSc7XG5leHBvcnQge1JlbGF0aW9uU2V0dGluZ3NTZXJ2aWNlIGFzIMm1Y30gZnJvbSAnLi9saWIvc2VydmljZS9yZWxhdGlvbi1zZXR0aW5ncy5zZXJ2aWNlJztcbmV4cG9ydCB7UmVsYXRpb25Mb2NhbGl6ZVBpcGUgYXMgybVpfSBmcm9tICcuL2xpYi90cmFuc2xhdGlvbi9yZWxhdGlvbi1sb2NhbGl6ZS5waXBlJzsiXX0=
@@ -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
- <co-relation-loader></co-relation-loader>
43
- <ng-container *ngIf="relation">
44
- <div class="relation-section">
45
- <div class="relation-section-label" [textContent]="'YOUR_DATA' | reLocalize"></div>
46
- <div class="relation-account-data">
47
- <div class="relation-account-data-wrapper">
48
- <div class="relation-data-row">
49
- <co-relation-title class="relation-data-field-default" [(relation)]="relation"></co-relation-title>
50
- </div>
51
- <div class="relation-data-row">
52
- <co-relation-first-name [(relation)]="relation"></co-relation-first-name>
53
- <co-relation-prefix-name [(relation)]="relation"></co-relation-prefix-name>
54
- <co-relation-last-name [(relation)]="relation"></co-relation-last-name>
55
- </div>
56
- <div class="relation-data-row">
57
- <co-relation-initials class="relation-data-field-default" [(relation)]="relation"></co-relation-initials>
58
- </div>
59
- <div class="relation-data-row">
60
- <co-relation-gender class="relation-data-field-default" [(relation)]="relation"></co-relation-gender>
61
- </div>
62
- <div class="relation-data-row">
63
- <co-relation-language class="relation-data-field-default" [(relation)]="relation"></co-relation-language>
64
- </div>
65
- </div>
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
- <div class="relation-section">
74
- <div class="relation-section-label" [textContent]="'PRIVACY_PREFERENCES' | reLocalize"></div>
75
- <co-relation-preferences [(relation)]="relation"></co-relation-preferences>
76
- </div>
77
- <div class="relation-section">
78
- <div class="relation-section-label" [textContent]="'ADDRESSES' | reLocalize"></div>
79
- <co-relation-addresses [(relation)]="relation"></co-relation-addresses>
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
- </ng-container>
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: DictionaryService },
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
- <span class="relation-address-country" [textContent]="address.displayCountry"></span>
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.PencilRoundOpen)"></co-icon>
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+XHJcbiAgICAgICAgICAgICAgICAgIDxzcGFuIGNsYXNzPVwicmVsYXRpb24tYWRkcmVzcy1jb3VudHJ5XCIgW3RleHRDb250ZW50XT1cImFkZHJlc3MuZGlzcGxheUNvdW50cnlcIj48L3NwYW4+XHJcbiAgICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cInJlbGF0aW9uLWFkZHJlc3MtZWRpdFwiIChjbGljayk9XCJoYW5kbGVFZGl0QWRkcmVzc0NsaWNrKCRldmVudClcIj5cclxuICAgICAgICAgICAgICAgICAgPGNvLWljb24gY2xhc3M9XCJyZWxhdGlvbi1hZGRyZXNzLWVkaXQtaWNvblwiIFtpY29uRGF0YV09XCJpY29uQ2FjaGVTZXJ2aWNlLmdldEljb24oaWNvbnMuUGVuY2lsUm91bmRPcGVuKVwiPjwvY28taWNvbj5cclxuICAgICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgIDwvY28tdGlsZS1zZWxlY3Q+XHJcbiAgICAgIDwvbmctY29udGFpbmVyPlxyXG4gICAgICA8bmctY29udGFpbmVyICpuZ0lmPVwiYWN0QXNBZGRUaWxlICYmICFyZWFkb25seVwiPlxyXG4gICAgICAgICAgPGNvLXRpbGUgKGNsaWNrKT1cImFkZEFkZHJlc3NDbGlja2VkLmVtaXQoKVwiPlxyXG4gICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJyZWxhdGlvbi1jb250ZW50LXdyYXBwZXJcIj5cclxuICAgICAgICAgICAgICAgICAgPGNvLWljb24gY2xhc3M9XCJyZWxhdGlvbi1hZGRyZXNzLWljb25cIiBbaWNvbkRhdGFdPVwiaWNvbkNhY2hlU2VydmljZS5nZXRJY29uKGljb25zLlBsdXNTaW1wbGUpXCI+PC9jby1pY29uPlxyXG4gICAgICAgICAgICAgICAgICA8c3BhbiBbdGV4dENvbnRlbnRdPVwiJ0FERFJFU1NfQUREJyB8IHJlTG9jYWxpemVcIj48L3NwYW4+XHJcbiAgICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICA8L2NvLXRpbGU+XHJcbiAgICAgIDwvbmctY29udGFpbmVyPlxyXG4gIGAsXHJcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZVxyXG59KVxyXG5leHBvcnQgY2xhc3MgUmVsYXRpb25BZGRyZXNzVGlsZUNvbXBvbmVudCB7XHJcbiAgcHVibGljIHJlYWRvbmx5IGljb25zOiB0eXBlb2YgSWNvbiA9IEljb247XHJcblxyXG4gIEBIb3N0QmluZGluZyhcImNsYXNzLmNvLXJlbGF0aW9uLWFkZHJlc3MtdGlsZVwiKVxyXG4gIHB1YmxpYyBzaG93Q2xhc3M6IGJvb2xlYW4gPSB0cnVlO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBhZGRyZXNzOiBBZGRyZXNzO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyByZWFkb25seTogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBzZWxlY3RlZDogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBhY3RBc0FkZFRpbGU6IGJvb2xlYW4gPSBmYWxzZTtcclxuXHJcbiAgQE91dHB1dCgpXHJcbiAgcHVibGljIHNlbGVjdGVkQ2hhbmdlOiBFdmVudEVtaXR0ZXI8QWRkcmVzcz4gPSBuZXcgRXZlbnRFbWl0dGVyPEFkZHJlc3M+KCk7XHJcblxyXG4gIEBPdXRwdXQoKVxyXG4gIHB1YmxpYyBhZGRBZGRyZXNzQ2xpY2tlZDogRXZlbnRFbWl0dGVyPHZvaWQ+ID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xyXG5cclxuICBAT3V0cHV0KClcclxuICBwdWJsaWMgZWRpdEFkZHJlc3NDbGlja2VkOiBFdmVudEVtaXR0ZXI8QWRkcmVzcz4gPSBuZXcgRXZlbnRFbWl0dGVyPEFkZHJlc3M+KCk7XHJcblxyXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBpY29uQ2FjaGVTZXJ2aWNlOiBJY29uQ2FjaGVTZXJ2aWNlKSB7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgaGFuZGxlRWRpdEFkZHJlc3NDbGljayhldmVudDogTW91c2VFdmVudCk6IHZvaWQge1xyXG4gICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcclxuICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xyXG4gICAgZXZlbnQuc3RvcEltbWVkaWF0ZVByb3BhZ2F0aW9uKCk7XHJcbiAgICB0aGlzLmVkaXRBZGRyZXNzQ2xpY2tlZC5uZXh0KHRoaXMuYWRkcmVzcyk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgaGFuZGxlU2VsZWN0ZWRDaGFuZ2UoYWRkcmVzczogQWRkcmVzcyk6IHZvaWQge1xyXG4gICAgaWYgKCF0aGlzLnJlYWRvbmx5KSB7XHJcbiAgICAgIHRoaXMuc2VsZWN0ZWQgPSB0cnVlO1xyXG4gICAgICB0aGlzLnNlbGVjdGVkQ2hhbmdlLmVtaXQoYWRkcmVzcyk7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
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
- <co-carousel *ngIf="deliveryAddresses && deliveryAddresses.length > 0">
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
- </co-carousel>
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
- <co-carousel *ngIf="invoiceAddresses && invoiceAddresses.length > 0">
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
- </co-carousel>
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"]}