@colijnit/relation 260.1.0 → 260.1.1

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/README.md +24 -24
  2. package/bundles/colijnit-relation.umd.js +409 -228
  3. package/bundles/colijnit-relation.umd.js.map +1 -1
  4. package/colijnit-relation.d.ts +3 -1
  5. package/colijnit-relation.metadata.json +1 -1
  6. package/esm2015/colijnit-relation.js +4 -2
  7. package/esm2015/lib/component/relation/relation.component.js +26 -18
  8. package/esm2015/lib/component/relation/relation.module.js +8 -3
  9. package/esm2015/lib/component/relation-avatar/relation-avatar.component.js +8 -4
  10. package/esm2015/lib/component/relation-contact-options/relation-contact-option-list.component.js +23 -8
  11. package/esm2015/lib/component/relation-contact-options/relation-contact-option.component.js +13 -3
  12. package/esm2015/lib/component/relation-contact-options/relation-contact-options.component.js +10 -6
  13. package/esm2015/lib/component/relation-documents/relation-documents.component.js +97 -0
  14. package/esm2015/lib/component/relation-documents/relation-documents.module.js +24 -0
  15. package/esm2015/lib/component/relation-first-name/relation-first-name.component.js +14 -4
  16. package/esm2015/lib/component/relation-gender/relation-gender.component.js +8 -3
  17. package/esm2015/lib/component/relation-initials/relation-initials.component.js +14 -4
  18. package/esm2015/lib/component/relation-language/relation-language.component.js +14 -4
  19. package/esm2015/lib/component/relation-language/relation-language.module.js +4 -3
  20. package/esm2015/lib/component/relation-last-name/relation-last-name.component.js +14 -4
  21. package/esm2015/lib/component/relation-prefix-name/relation-prefix-name.component.js +14 -4
  22. package/esm2015/lib/component/relation-title/relation-title.component.js +14 -4
  23. package/esm2015/lib/component/relation-title/relation-title.module.js +4 -3
  24. package/esm2015/lib/enum/icon.enum.js +3 -1
  25. package/esm2015/lib/model/icon-svg.js +3 -1
  26. package/esm2015/lib/relation-version.js +3 -3
  27. package/esm2015/lib/res/dictionary/dictionaries.js +5 -5
  28. package/fesm2015/colijnit-relation.js +504 -284
  29. package/fesm2015/colijnit-relation.js.map +1 -1
  30. package/lib/component/relation/relation.component.d.ts +2 -0
  31. package/lib/component/relation-contact-options/relation-contact-option-list.component.d.ts +2 -0
  32. package/lib/component/relation-contact-options/relation-contact-option.component.d.ts +3 -0
  33. package/lib/component/relation-contact-options/style/_layout.scss +98 -44
  34. package/lib/component/relation-contact-options/style/_material-definition.scss +2 -1
  35. package/lib/component/relation-contact-options/style/_theme.scss +21 -0
  36. package/lib/component/relation-documents/relation-documents.component.d.ts +18 -0
  37. package/lib/component/relation-documents/relation-documents.module.d.ts +2 -0
  38. package/lib/enum/icon.enum.d.ts +2 -0
  39. package/lib/res/dictionary/dictionaries.d.ts +35 -0
  40. package/package.json +1 -1
@@ -3,11 +3,13 @@
3
3
  */
4
4
  export * from './public_api';
5
5
  export { RelationBaseComponent as ɵk } from './lib/component/base/relation-base.component';
6
- export { RelationLoaderComponent as ɵo } from './lib/component/base/relation-loader.component';
6
+ export { RelationLoaderComponent as ɵq } from './lib/component/base/relation-loader.component';
7
7
  export { RelationScreenConfigBaseComponent as ɵj } from './lib/component/base/relation-screen-config-base.component';
8
8
  export { RelationContactOptionListComponent as ɵm } from './lib/component/relation-contact-options/relation-contact-option-list.component';
9
9
  export { RelationContactOptionComponent as ɵl } from './lib/component/relation-contact-options/relation-contact-option.component';
10
10
  export { RelationContactOptionsOtherTypesPopupComponent as ɵn } from './lib/component/relation-contact-options/relation-contact-options-other-types-popup.component';
11
+ export { RelationDocumentsComponent as ɵp } from './lib/component/relation-documents/relation-documents.component';
12
+ export { RelationDocumentsModule as ɵo } from './lib/component/relation-documents/relation-documents.module';
11
13
  export { ErrorService as ɵd } from './lib/service/error.service';
12
14
  export { IconCacheService as ɵh } from './lib/service/icon-cache.service';
13
15
  export { RelationBaseService as ɵg } from './lib/service/relation-base.service';
@@ -17,4 +19,4 @@ export { RelationEventService as ɵe } from './lib/service/relation-event.servic
17
19
  export { RelationScreenConfigurationService as ɵa } from './lib/service/relation-screen-configuration.service';
18
20
  export { RelationSettingsService as ɵc } from './lib/service/relation-settings.service';
19
21
  export { RelationLocalizePipe as ɵi } from './lib/translation/relation-localize.pipe';
20
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29saWpuaXQtcmVsYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wcm9qZWN0cy9yZWxhdGlvbi9zcmMvY29saWpuaXQtcmVsYXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQztBQUU3QixPQUFPLEVBQUMscUJBQXFCLElBQUksRUFBRSxFQUFDLE1BQU0sOENBQThDLENBQUM7QUFDekYsT0FBTyxFQUFDLHVCQUF1QixJQUFJLEVBQUUsRUFBQyxNQUFNLGdEQUFnRCxDQUFDO0FBQzdGLE9BQU8sRUFBQyxpQ0FBaUMsSUFBSSxFQUFFLEVBQUMsTUFBTSw0REFBNEQsQ0FBQztBQUNuSCxPQUFPLEVBQUMsa0NBQWtDLElBQUksRUFBRSxFQUFDLE1BQU0saUZBQWlGLENBQUM7QUFDekksT0FBTyxFQUFDLDhCQUE4QixJQUFJLEVBQUUsRUFBQyxNQUFNLDRFQUE0RSxDQUFDO0FBQ2hJLE9BQU8sRUFBQyw4Q0FBOEMsSUFBSSxFQUFFLEVBQUMsTUFBTSwrRkFBK0YsQ0FBQztBQUNuSyxPQUFPLEVBQUMsWUFBWSxJQUFJLEVBQUUsRUFBQyxNQUFNLDZCQUE2QixDQUFDO0FBQy9ELE9BQU8sRUFBQyxnQkFBZ0IsSUFBSSxFQUFFLEVBQUMsTUFBTSxrQ0FBa0MsQ0FBQztBQUN4RSxPQUFPLEVBQUMsbUJBQW1CLElBQUksRUFBRSxFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDOUUsT0FBTyxFQUFDLCtCQUErQixJQUFJLEVBQUUsRUFBQyxNQUFNLGtEQUFrRCxDQUFDO0FBQ3ZHLE9BQU8sRUFBQyx3QkFBd0IsSUFBSSxFQUFFLEVBQUMsTUFBTSwwQ0FBMEMsQ0FBQztBQUN4RixPQUFPLEVBQUMsb0JBQW9CLElBQUksRUFBRSxFQUFDLE1BQU0sc0NBQXNDLENBQUM7QUFDaEYsT0FBTyxFQUFDLGtDQUFrQyxJQUFJLEVBQUUsRUFBQyxNQUFNLHFEQUFxRCxDQUFDO0FBQzdHLE9BQU8sRUFBQyx1QkFBdUIsSUFBSSxFQUFFLEVBQUMsTUFBTSx5Q0FBeUMsQ0FBQztBQUN0RixPQUFPLEVBQUMsb0JBQW9CLElBQUksRUFBRSxFQUFDLE1BQU0sMENBQTBDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljX2FwaSc7XG5cbmV4cG9ydCB7UmVsYXRpb25CYXNlQ29tcG9uZW50IGFzIMm1a30gZnJvbSAnLi9saWIvY29tcG9uZW50L2Jhc2UvcmVsYXRpb24tYmFzZS5jb21wb25lbnQnO1xuZXhwb3J0IHtSZWxhdGlvbkxvYWRlckNvbXBvbmVudCBhcyDJtW99IGZyb20gJy4vbGliL2NvbXBvbmVudC9iYXNlL3JlbGF0aW9uLWxvYWRlci5jb21wb25lbnQnO1xuZXhwb3J0IHtSZWxhdGlvblNjcmVlbkNvbmZpZ0Jhc2VDb21wb25lbnQgYXMgybVqfSBmcm9tICcuL2xpYi9jb21wb25lbnQvYmFzZS9yZWxhdGlvbi1zY3JlZW4tY29uZmlnLWJhc2UuY29tcG9uZW50JztcbmV4cG9ydCB7UmVsYXRpb25Db250YWN0T3B0aW9uTGlzdENvbXBvbmVudCBhcyDJtW19IGZyb20gJy4vbGliL2NvbXBvbmVudC9yZWxhdGlvbi1jb250YWN0LW9wdGlvbnMvcmVsYXRpb24tY29udGFjdC1vcHRpb24tbGlzdC5jb21wb25lbnQnO1xuZXhwb3J0IHtSZWxhdGlvbkNvbnRhY3RPcHRpb25Db21wb25lbnQgYXMgybVsfSBmcm9tICcuL2xpYi9jb21wb25lbnQvcmVsYXRpb24tY29udGFjdC1vcHRpb25zL3JlbGF0aW9uLWNvbnRhY3Qtb3B0aW9uLmNvbXBvbmVudCc7XG5leHBvcnQge1JlbGF0aW9uQ29udGFjdE9wdGlvbnNPdGhlclR5cGVzUG9wdXBDb21wb25lbnQgYXMgybVufSBmcm9tICcuL2xpYi9jb21wb25lbnQvcmVsYXRpb24tY29udGFjdC1vcHRpb25zL3JlbGF0aW9uLWNvbnRhY3Qtb3B0aW9ucy1vdGhlci10eXBlcy1wb3B1cC5jb21wb25lbnQnO1xuZXhwb3J0IHtFcnJvclNlcnZpY2UgYXMgybVkfSBmcm9tICcuL2xpYi9zZXJ2aWNlL2Vycm9yLnNlcnZpY2UnO1xuZXhwb3J0IHtJY29uQ2FjaGVTZXJ2aWNlIGFzIMm1aH0gZnJvbSAnLi9saWIvc2VydmljZS9pY29uLWNhY2hlLnNlcnZpY2UnO1xuZXhwb3J0IHtSZWxhdGlvbkJhc2VTZXJ2aWNlIGFzIMm1Z30gZnJvbSAnLi9saWIvc2VydmljZS9yZWxhdGlvbi1iYXNlLnNlcnZpY2UnO1xuZXhwb3J0IHtSZWxhdGlvbkNvbm5lY3RvckFkYXB0ZXJTZXJ2aWNlIGFzIMm1Yn0gZnJvbSAnLi9saWIvc2VydmljZS9yZWxhdGlvbi1jb25uZWN0b3ItYWRhcHRlci5zZXJ2aWNlJztcbmV4cG9ydCB7UmVsYXRpb25Db25uZWN0b3JTZXJ2aWNlIGFzIMm1Zn0gZnJvbSAnLi9saWIvc2VydmljZS9yZWxhdGlvbi1jb25uZWN0b3Iuc2VydmljZSc7XG5leHBvcnQge1JlbGF0aW9uRXZlbnRTZXJ2aWNlIGFzIMm1ZX0gZnJvbSAnLi9saWIvc2VydmljZS9yZWxhdGlvbi1ldmVudC5zZXJ2aWNlJztcbmV4cG9ydCB7UmVsYXRpb25TY3JlZW5Db25maWd1cmF0aW9uU2VydmljZSBhcyDJtWF9IGZyb20gJy4vbGliL3NlcnZpY2UvcmVsYXRpb24tc2NyZWVuLWNvbmZpZ3VyYXRpb24uc2VydmljZSc7XG5leHBvcnQge1JlbGF0aW9uU2V0dGluZ3NTZXJ2aWNlIGFzIMm1Y30gZnJvbSAnLi9saWIvc2VydmljZS9yZWxhdGlvbi1zZXR0aW5ncy5zZXJ2aWNlJztcbmV4cG9ydCB7UmVsYXRpb25Mb2NhbGl6ZVBpcGUgYXMgybVpfSBmcm9tICcuL2xpYi90cmFuc2xhdGlvbi9yZWxhdGlvbi1sb2NhbGl6ZS5waXBlJzsiXX0=
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29saWpuaXQtcmVsYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wcm9qZWN0cy9yZWxhdGlvbi9zcmMvY29saWpuaXQtcmVsYXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQztBQUU3QixPQUFPLEVBQUMscUJBQXFCLElBQUksRUFBRSxFQUFDLE1BQU0sOENBQThDLENBQUM7QUFDekYsT0FBTyxFQUFDLHVCQUF1QixJQUFJLEVBQUUsRUFBQyxNQUFNLGdEQUFnRCxDQUFDO0FBQzdGLE9BQU8sRUFBQyxpQ0FBaUMsSUFBSSxFQUFFLEVBQUMsTUFBTSw0REFBNEQsQ0FBQztBQUNuSCxPQUFPLEVBQUMsa0NBQWtDLElBQUksRUFBRSxFQUFDLE1BQU0saUZBQWlGLENBQUM7QUFDekksT0FBTyxFQUFDLDhCQUE4QixJQUFJLEVBQUUsRUFBQyxNQUFNLDRFQUE0RSxDQUFDO0FBQ2hJLE9BQU8sRUFBQyw4Q0FBOEMsSUFBSSxFQUFFLEVBQUMsTUFBTSwrRkFBK0YsQ0FBQztBQUNuSyxPQUFPLEVBQUMsMEJBQTBCLElBQUksRUFBRSxFQUFDLE1BQU0saUVBQWlFLENBQUM7QUFDakgsT0FBTyxFQUFDLHVCQUF1QixJQUFJLEVBQUUsRUFBQyxNQUFNLDhEQUE4RCxDQUFDO0FBQzNHLE9BQU8sRUFBQyxZQUFZLElBQUksRUFBRSxFQUFDLE1BQU0sNkJBQTZCLENBQUM7QUFDL0QsT0FBTyxFQUFDLGdCQUFnQixJQUFJLEVBQUUsRUFBQyxNQUFNLGtDQUFrQyxDQUFDO0FBQ3hFLE9BQU8sRUFBQyxtQkFBbUIsSUFBSSxFQUFFLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUM5RSxPQUFPLEVBQUMsK0JBQStCLElBQUksRUFBRSxFQUFDLE1BQU0sa0RBQWtELENBQUM7QUFDdkcsT0FBTyxFQUFDLHdCQUF3QixJQUFJLEVBQUUsRUFBQyxNQUFNLDBDQUEwQyxDQUFDO0FBQ3hGLE9BQU8sRUFBQyxvQkFBb0IsSUFBSSxFQUFFLEVBQUMsTUFBTSxzQ0FBc0MsQ0FBQztBQUNoRixPQUFPLEVBQUMsa0NBQWtDLElBQUksRUFBRSxFQUFDLE1BQU0scURBQXFELENBQUM7QUFDN0csT0FBTyxFQUFDLHVCQUF1QixJQUFJLEVBQUUsRUFBQyxNQUFNLHlDQUF5QyxDQUFDO0FBQ3RGLE9BQU8sRUFBQyxvQkFBb0IsSUFBSSxFQUFFLEVBQUMsTUFBTSwwQ0FBMEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWNfYXBpJztcblxuZXhwb3J0IHtSZWxhdGlvbkJhc2VDb21wb25lbnQgYXMgybVrfSBmcm9tICcuL2xpYi9jb21wb25lbnQvYmFzZS9yZWxhdGlvbi1iYXNlLmNvbXBvbmVudCc7XG5leHBvcnQge1JlbGF0aW9uTG9hZGVyQ29tcG9uZW50IGFzIMm1cX0gZnJvbSAnLi9saWIvY29tcG9uZW50L2Jhc2UvcmVsYXRpb24tbG9hZGVyLmNvbXBvbmVudCc7XG5leHBvcnQge1JlbGF0aW9uU2NyZWVuQ29uZmlnQmFzZUNvbXBvbmVudCBhcyDJtWp9IGZyb20gJy4vbGliL2NvbXBvbmVudC9iYXNlL3JlbGF0aW9uLXNjcmVlbi1jb25maWctYmFzZS5jb21wb25lbnQnO1xuZXhwb3J0IHtSZWxhdGlvbkNvbnRhY3RPcHRpb25MaXN0Q29tcG9uZW50IGFzIMm1bX0gZnJvbSAnLi9saWIvY29tcG9uZW50L3JlbGF0aW9uLWNvbnRhY3Qtb3B0aW9ucy9yZWxhdGlvbi1jb250YWN0LW9wdGlvbi1saXN0LmNvbXBvbmVudCc7XG5leHBvcnQge1JlbGF0aW9uQ29udGFjdE9wdGlvbkNvbXBvbmVudCBhcyDJtWx9IGZyb20gJy4vbGliL2NvbXBvbmVudC9yZWxhdGlvbi1jb250YWN0LW9wdGlvbnMvcmVsYXRpb24tY29udGFjdC1vcHRpb24uY29tcG9uZW50JztcbmV4cG9ydCB7UmVsYXRpb25Db250YWN0T3B0aW9uc090aGVyVHlwZXNQb3B1cENvbXBvbmVudCBhcyDJtW59IGZyb20gJy4vbGliL2NvbXBvbmVudC9yZWxhdGlvbi1jb250YWN0LW9wdGlvbnMvcmVsYXRpb24tY29udGFjdC1vcHRpb25zLW90aGVyLXR5cGVzLXBvcHVwLmNvbXBvbmVudCc7XG5leHBvcnQge1JlbGF0aW9uRG9jdW1lbnRzQ29tcG9uZW50IGFzIMm1cH0gZnJvbSAnLi9saWIvY29tcG9uZW50L3JlbGF0aW9uLWRvY3VtZW50cy9yZWxhdGlvbi1kb2N1bWVudHMuY29tcG9uZW50JztcbmV4cG9ydCB7UmVsYXRpb25Eb2N1bWVudHNNb2R1bGUgYXMgybVvfSBmcm9tICcuL2xpYi9jb21wb25lbnQvcmVsYXRpb24tZG9jdW1lbnRzL3JlbGF0aW9uLWRvY3VtZW50cy5tb2R1bGUnO1xuZXhwb3J0IHtFcnJvclNlcnZpY2UgYXMgybVkfSBmcm9tICcuL2xpYi9zZXJ2aWNlL2Vycm9yLnNlcnZpY2UnO1xuZXhwb3J0IHtJY29uQ2FjaGVTZXJ2aWNlIGFzIMm1aH0gZnJvbSAnLi9saWIvc2VydmljZS9pY29uLWNhY2hlLnNlcnZpY2UnO1xuZXhwb3J0IHtSZWxhdGlvbkJhc2VTZXJ2aWNlIGFzIMm1Z30gZnJvbSAnLi9saWIvc2VydmljZS9yZWxhdGlvbi1iYXNlLnNlcnZpY2UnO1xuZXhwb3J0IHtSZWxhdGlvbkNvbm5lY3RvckFkYXB0ZXJTZXJ2aWNlIGFzIMm1Yn0gZnJvbSAnLi9saWIvc2VydmljZS9yZWxhdGlvbi1jb25uZWN0b3ItYWRhcHRlci5zZXJ2aWNlJztcbmV4cG9ydCB7UmVsYXRpb25Db25uZWN0b3JTZXJ2aWNlIGFzIMm1Zn0gZnJvbSAnLi9saWIvc2VydmljZS9yZWxhdGlvbi1jb25uZWN0b3Iuc2VydmljZSc7XG5leHBvcnQge1JlbGF0aW9uRXZlbnRTZXJ2aWNlIGFzIMm1ZX0gZnJvbSAnLi9saWIvc2VydmljZS9yZWxhdGlvbi1ldmVudC5zZXJ2aWNlJztcbmV4cG9ydCB7UmVsYXRpb25TY3JlZW5Db25maWd1cmF0aW9uU2VydmljZSBhcyDJtWF9IGZyb20gJy4vbGliL3NlcnZpY2UvcmVsYXRpb24tc2NyZWVuLWNvbmZpZ3VyYXRpb24uc2VydmljZSc7XG5leHBvcnQge1JlbGF0aW9uU2V0dGluZ3NTZXJ2aWNlIGFzIMm1Y30gZnJvbSAnLi9saWIvc2VydmljZS9yZWxhdGlvbi1zZXR0aW5ncy5zZXJ2aWNlJztcbmV4cG9ydCB7UmVsYXRpb25Mb2NhbGl6ZVBpcGUgYXMgybVpfSBmcm9tICcuL2xpYi90cmFuc2xhdGlvbi9yZWxhdGlvbi1sb2NhbGl6ZS5waXBlJzsiXX0=
@@ -1,6 +1,6 @@
1
1
  import { __awaiter } from "tslib";
2
- import { Component, HostBinding, Input, ViewEncapsulation } from '@angular/core';
3
- import { BaseModuleScreenConfigService, CoreComponentsTranslationService } from '@colijnit/corecomponents_v12';
2
+ import { Component, forwardRef, HostBinding, Input, ViewEncapsulation } from '@angular/core';
3
+ import { BaseModuleScreenConfigService, CoreComponentsTranslationService, SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME } from '@colijnit/corecomponents_v12';
4
4
  import { RelationEventService } from '../../service/relation-event.service';
5
5
  import { Dictionaries } from '../../res/dictionary/dictionaries';
6
6
  import { RelationSettingsService } from '../../service/relation-settings.service';
@@ -10,6 +10,7 @@ import { RelationScreenConfigurationService } from '../../service/relation-scree
10
10
  import { IconCacheService } from "../../service/icon-cache.service";
11
11
  import { Icon } from "../../enum/icon.enum";
12
12
  import { RelationKind } from "@colijnit/relationapi/build/enum/relation-kind.enum";
13
+ import { RelmanCfgName } from '../../enum/relman-cfg-name.enum';
13
14
  export class RelationComponent {
14
15
  constructor(relationEventService, _translationService, _settingsService, _relationConnectorService, _relationService, iconCacheService) {
15
16
  this.relationEventService = relationEventService;
@@ -19,6 +20,7 @@ export class RelationComponent {
19
20
  this._relationService = _relationService;
20
21
  this.iconCacheService = iconCacheService;
21
22
  this.icons = Icon;
23
+ this.relmanCfgNames = RelmanCfgName;
22
24
  this.loadRelationFromLoginResponse = false;
23
25
  this.forceReadOnly = true;
24
26
  this.customerPortal = false;
@@ -101,20 +103,20 @@ RelationComponent.decorators = [
101
103
  <div class="relation-account-data" *ngIf="!forceReadOnly">
102
104
  <div class="relation-account-data-wrapper">
103
105
  <div class="relation-data-row">
104
- <co-relation-title class="relation-data-field-default" [collection]="collection"
106
+ <co-relation-title class="relation-data-field-default" [collection]="collection" [screenConfigurationObject]="relmanCfgNames.TitleId"
105
107
  [(relation)]="relation"></co-relation-title>
106
- <co-relation-initials class="relation-data-field-default" [(relation)]="relation"></co-relation-initials>
108
+ <co-relation-initials class="relation-data-field-default" [(relation)]="relation" [screenConfigurationObject]="relmanCfgNames.Initials"></co-relation-initials>
107
109
  </div>
108
110
  <div class="relation-data-row">
109
- <co-relation-first-name [(relation)]="relation"></co-relation-first-name>
110
- <co-relation-prefix-name [(relation)]="relation"></co-relation-prefix-name>
111
- <co-relation-last-name [(relation)]="relation"></co-relation-last-name>
111
+ <co-relation-first-name [(relation)]="relation" [screenConfigurationObject]="relmanCfgNames.FirstName"></co-relation-first-name>
112
+ <co-relation-prefix-name [(relation)]="relation" [screenConfigurationObject]="relmanCfgNames.Prefix"></co-relation-prefix-name>
113
+ <co-relation-last-name [(relation)]="relation" [screenConfigurationObject]="relmanCfgNames.FamilyName"></co-relation-last-name>
112
114
  </div>
113
115
  <div class="relation-data-row">
114
- <co-relation-gender class="relation-data-field-default" [(relation)]="relation"></co-relation-gender>
116
+ <co-relation-gender class="relation-data-field-default" [(relation)]="relation" [screenConfigurationObject]="relmanCfgNames.Gender"></co-relation-gender>
115
117
  </div>
116
118
  <div class="relation-data-row">
117
- <co-relation-language class="relation-data-field-default" [(relation)]="relation"></co-relation-language>
119
+ <co-relation-language class="relation-data-field-default" [(relation)]="relation" [screenConfigurationObject]="relmanCfgNames.Language"></co-relation-language>
118
120
  </div>
119
121
  <div class="relation-data-column">
120
122
  <div class="relation-section-sub-label" [textContent]="'CONTACT_OPTIONS' | reLocalize"></div>
@@ -136,11 +138,11 @@ RelationComponent.decorators = [
136
138
  <div class="relation-account-data" *ngIf="forceReadOnly">
137
139
  <div class="relation-account-data-wrapper non-editable">
138
140
  <div class="relation-data-row">
139
- <div class="non-editable-column">
141
+ <div class="non-editable-column" [screenConfigurationObject]="relmanCfgNames.TitleId" screenConfigNativeElement>
140
142
  <label class="label" [textContent]="'TITLES' | reLocalize"></label>
141
143
  <span class="value" [textContent]="relationTitle"></span>
142
144
  </div>
143
- <div class="non-editable-column">
145
+ <div class="non-editable-column" [screenConfigurationObject]="relmanCfgNames.Initials" screenConfigNativeElement>
144
146
  <label class="label" [textContent]="'INITIALS' | reLocalize"></label>
145
147
  <span class="value" [textContent]="relation.initials"></span>
146
148
  </div>
@@ -155,11 +157,11 @@ RelationComponent.decorators = [
155
157
  </div>
156
158
  </div>
157
159
  <div class="relation-data-row">
158
- <div class="non-editable-column">
160
+ <div class="non-editable-column" [screenConfigurationObject]="relmanCfgNames.Gender" screenConfigNativeElement>
159
161
  <label class="label" [textContent]="'GENDER' | reLocalize"></label>
160
162
  <span class="value" [textContent]="getGenderLabel(relation.gender) | reLocalize"></span>
161
163
  </div>
162
- <div class="non-editable-column">
164
+ <div class="non-editable-column" [screenConfigurationObject]="relmanCfgNames.Language" screenConfigNativeElement>
163
165
  <label class="label" [textContent]="'LANGUAGE' | reLocalize"></label>
164
166
  <span class="value" [textContent]="relation.language"></span>
165
167
  </div>
@@ -181,19 +183,25 @@ RelationComponent.decorators = [
181
183
  <span [textContent]="'EDIT' | reLocalize"></span>
182
184
  </div>
183
185
  </div>
184
- <div class="relation-section">
186
+ <div class="relation-section" [screenConfigurationObject]="relmanCfgNames.AddressesHeader" screenConfigNativeElement>
185
187
  <div class="relation-section-label" [textContent]="'ADDRESSES' | reLocalize"></div>
186
188
  <co-relation-addresses [(relation)]="relation"></co-relation-addresses>
187
189
  </div>
188
- <div class="relation-section">
190
+ <div *ngIf="customerPortal" class="relation-section relation-documents">
191
+ <co-relation-documents [relation]="relation"></co-relation-documents>
192
+ </div>
193
+ <div class="relation-section" [screenConfigurationObject]="relmanCfgNames.PrivacyHeader" screenConfigNativeElement>
189
194
  <div class="relation-section-label" [textContent]="'PRIVACY_PREFERENCES' | reLocalize"></div>
190
195
  <co-relation-preferences [(relation)]="relation"></co-relation-preferences>
191
196
  </div>
192
-
193
197
  </ng-container>
194
198
  `,
195
199
  providers: [
196
- { provide: BaseModuleScreenConfigService, useExisting: RelationScreenConfigurationService }
200
+ { provide: BaseModuleScreenConfigService, useExisting: RelationScreenConfigurationService },
201
+ {
202
+ provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,
203
+ useExisting: forwardRef(() => RelationComponent)
204
+ }
197
205
  ],
198
206
  encapsulation: ViewEncapsulation.None
199
207
  },] }
@@ -212,4 +220,4 @@ RelationComponent.propDecorators = {
212
220
  customerPortal: [{ type: Input }],
213
221
  showClass: [{ type: HostBinding, args: ['class.co-relation',] }]
214
222
  };
215
- //# 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\nimport {RelationKind} from \"@colijnit/relationapi/build/enum/relation-kind.enum\";\r\nimport {CustomerFullObject} from \"@colijnit/relationapi/build/model/customer-full-object.bo\";\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  async ngOnInit() {\r\n    if (this.loadRelationFromLoginResponse && this._relationConnectorService.loginResponse) {\r\n      if (this._relationConnectorService.loginResponse.relationKind === RelationKind.ContactPerson) {\r\n        const customer: CustomerFullObject =  await this._relationService.getFirstCustomerForContact(this._relationConnectorService.loginResponse.relationId);\r\n        if (customer && (customer.relationId !== null && customer.relationId !== undefined)) {\r\n          this._relationService.relationId = customer.relationId;\r\n        }\r\n      } else {\r\n        this._relationService.relationId = this._relationConnectorService.loginResponse.relationId;\r\n      }\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"]}
223
+ //# 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, forwardRef, HostBinding, Input, OnDestroy, OnInit, ViewEncapsulation} from '@angular/core';\r\nimport {BaseModuleScreenConfigService, CoreComponentsTranslationService, SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} 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\nimport {RelationKind} from \"@colijnit/relationapi/build/enum/relation-kind.enum\";\r\nimport {CustomerFullObject} from \"@colijnit/relationapi/build/model/customer-full-object.bo\";\r\nimport {RelmanCfgName} from '../../enum/relman-cfg-name.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\" [screenConfigurationObject]=\"relmanCfgNames.TitleId\"\r\n                                 [(relation)]=\"relation\"></co-relation-title>\r\n              <co-relation-initials class=\"relation-data-field-default\" [(relation)]=\"relation\" [screenConfigurationObject]=\"relmanCfgNames.Initials\"></co-relation-initials>\r\n            </div>\r\n            <div class=\"relation-data-row\">\r\n              <co-relation-first-name [(relation)]=\"relation\" [screenConfigurationObject]=\"relmanCfgNames.FirstName\"></co-relation-first-name>\r\n              <co-relation-prefix-name  [(relation)]=\"relation\" [screenConfigurationObject]=\"relmanCfgNames.Prefix\"></co-relation-prefix-name>\r\n              <co-relation-last-name [(relation)]=\"relation\" [screenConfigurationObject]=\"relmanCfgNames.FamilyName\"></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\" [screenConfigurationObject]=\"relmanCfgNames.Gender\"></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\" [screenConfigurationObject]=\"relmanCfgNames.Language\"></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\" [screenConfigurationObject]=\"relmanCfgNames.TitleId\" screenConfigNativeElement>\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\" [screenConfigurationObject]=\"relmanCfgNames.Initials\" screenConfigNativeElement>\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\" [screenConfigurationObject]=\"relmanCfgNames.Gender\" screenConfigNativeElement>\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\" [screenConfigurationObject]=\"relmanCfgNames.Language\" screenConfigNativeElement>\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\" [screenConfigurationObject]=\"relmanCfgNames.AddressesHeader\" screenConfigNativeElement>\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 *ngIf=\"customerPortal\" class=\"relation-section relation-documents\">\r\n        <co-relation-documents [relation]=\"relation\"></co-relation-documents>\r\n      </div>\r\n      <div class=\"relation-section\" [screenConfigurationObject]=\"relmanCfgNames.PrivacyHeader\" screenConfigNativeElement>\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    </ng-container>\r\n  `,\r\n  providers: [\r\n    {provide: BaseModuleScreenConfigService, useExisting: RelationScreenConfigurationService},\r\n    {\r\n      provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n      useExisting: forwardRef(() => RelationComponent)\r\n    }\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  public readonly relmanCfgNames: typeof RelmanCfgName = RelmanCfgName;\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  async ngOnInit() {\r\n    if (this.loadRelationFromLoginResponse && this._relationConnectorService.loginResponse) {\r\n      if (this._relationConnectorService.loginResponse.relationKind === RelationKind.ContactPerson) {\r\n        const customer: CustomerFullObject =  await this._relationService.getFirstCustomerForContact(this._relationConnectorService.loginResponse.relationId);\r\n        if (customer && (customer.relationId !== null && customer.relationId !== undefined)) {\r\n          this._relationService.relationId = customer.relationId;\r\n        }\r\n      } else {\r\n        this._relationService.relationId = this._relationConnectorService.loginResponse.relationId;\r\n      }\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"]}
@@ -2,7 +2,7 @@ import { NgModule } from '@angular/core';
2
2
  import { CommonModule } from '@angular/common';
3
3
  import { RelationComponent } from './relation.component';
4
4
  import { RelationFirstNameModule } from '../relation-first-name/relation-first-name.module';
5
- import { BaseModuleScreenConfigService, BaseModuleService, ButtonModule, CoreComponentsTranslationModule, CoreDialogModule, LoaderModule } from '@colijnit/corecomponents_v12';
5
+ import { BaseModuleScreenConfigService, BaseModuleService, ButtonModule, CoreComponentsTranslationModule, CoreDialogModule, LoaderModule, ScreenConfigurationModule } from '@colijnit/corecomponents_v12';
6
6
  import { RelationLoaderComponent } from '../base/relation-loader.component';
7
7
  import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
8
8
  import { RelationPrefixNameModule } from '../relation-prefix-name/relation-prefix-name.module';
@@ -18,6 +18,8 @@ import { RelationAddressesModule } from '../relation-addresses/relation-addresse
18
18
  import { RelationService } from '../../service/relation.service';
19
19
  import { RelationScreenConfigurationService } from '../../service/relation-screen-configuration.service';
20
20
  import { RelationTranslationModule } from '../../translation/relation-translation.module';
21
+ import { FilesUploadModule } from "@colijnit/corecomponents";
22
+ import { RelationDocumentsModule } from "../relation-documents/relation-documents.module";
21
23
  export class RelationModule {
22
24
  }
23
25
  RelationModule.decorators = [
@@ -40,7 +42,10 @@ RelationModule.decorators = [
40
42
  RelationAvatarModule,
41
43
  RelationAddressesModule,
42
44
  CoreComponentsTranslationModule.forRoot(),
43
- RelationTranslationModule
45
+ RelationTranslationModule.forRoot(),
46
+ ScreenConfigurationModule,
47
+ FilesUploadModule,
48
+ RelationDocumentsModule
44
49
  ],
45
50
  declarations: [
46
51
  RelationLoaderComponent,
@@ -55,4 +60,4 @@ RelationModule.decorators = [
55
60
  ],
56
61
  },] }
57
62
  ];
58
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVsYXRpb24ubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcmVsYXRpb24vc3JjL2xpYi9jb21wb25lbnQvcmVsYXRpb24vcmVsYXRpb24ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxpQkFBaUIsRUFBQyxNQUFNLHNCQUFzQixDQUFDO0FBQ3ZELE9BQU8sRUFBQyx1QkFBdUIsRUFBQyxNQUFNLG1EQUFtRCxDQUFDO0FBQzFGLE9BQU8sRUFDTCw2QkFBNkIsRUFDN0IsaUJBQWlCLEVBQ2pCLFlBQVksRUFDWiwrQkFBK0IsRUFDL0IsZ0JBQWdCLEVBQ2hCLFlBQVksRUFDYixNQUFNLDhCQUE4QixDQUFDO0FBQ3RDLE9BQU8sRUFBQyx1QkFBdUIsRUFBQyxNQUFNLG1DQUFtQyxDQUFDO0FBQzFFLE9BQU8sRUFBQyx1QkFBdUIsRUFBQyxNQUFNLHNDQUFzQyxDQUFDO0FBQzdFLE9BQU8sRUFBQyx3QkFBd0IsRUFBQyxNQUFNLHFEQUFxRCxDQUFDO0FBQzdGLE9BQU8sRUFBQyxzQkFBc0IsRUFBQyxNQUFNLGlEQUFpRCxDQUFDO0FBQ3ZGLE9BQU8sRUFBQyxzQkFBc0IsRUFBQyxNQUFNLCtDQUErQyxDQUFDO0FBQ3JGLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLDJDQUEyQyxDQUFDO0FBQy9FLE9BQU8sRUFBQyxtQkFBbUIsRUFBQyxNQUFNLHlDQUF5QyxDQUFDO0FBQzVFLE9BQU8sRUFBQyx5QkFBeUIsRUFBQyxNQUFNLHFEQUFxRCxDQUFDO0FBQzlGLE9BQU8sRUFBQyxzQkFBc0IsRUFBQyxNQUFNLCtDQUErQyxDQUFDO0FBQ3JGLE9BQU8sRUFBQyw0QkFBNEIsRUFBQyxNQUFNLDZEQUE2RCxDQUFDO0FBQ3pHLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLDJDQUEyQyxDQUFDO0FBQy9FLE9BQU8sRUFBQyx1QkFBdUIsRUFBQyxNQUFNLGlEQUFpRCxDQUFDO0FBQ3hGLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUMvRCxPQUFPLEVBQUMsa0NBQWtDLEVBQUMsTUFBTSxxREFBcUQsQ0FBQztBQUN2RyxPQUFPLEVBQUMseUJBQXlCLEVBQUMsTUFBTSwrQ0FBK0MsQ0FBQztBQW1DeEYsTUFBTSxPQUFPLGNBQWM7OztZQWpDMUIsUUFBUSxTQUFDO2dCQUNSLE9BQU8sRUFBRTtvQkFDUCxZQUFZO29CQUNaLHVCQUF1QjtvQkFDdkIsZ0JBQWdCO29CQUNoQix1QkFBdUI7b0JBQ3ZCLFlBQVk7b0JBQ1osWUFBWTtvQkFDWix3QkFBd0I7b0JBQ3hCLHNCQUFzQjtvQkFDdEIsc0JBQXNCO29CQUN0QixvQkFBb0I7b0JBQ3BCLG1CQUFtQjtvQkFDbkIseUJBQXlCO29CQUN6QixzQkFBc0I7b0JBQ3RCLDRCQUE0QjtvQkFDNUIsb0JBQW9CO29CQUNwQix1QkFBdUI7b0JBQ3ZCLCtCQUErQixDQUFDLE9BQU8sRUFBRTtvQkFDekMseUJBQXlCO2lCQUMxQjtnQkFDRCxZQUFZLEVBQUU7b0JBQ1osdUJBQXVCO29CQUN2QixpQkFBaUI7aUJBQ2xCO2dCQUNELE9BQU8sRUFBRTtvQkFDUCxpQkFBaUI7aUJBQ2xCO2dCQUNELFNBQVMsRUFBRTtvQkFDVCxFQUFDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxXQUFXLEVBQUUsZUFBZSxFQUFDO29CQUMxRCxFQUFDLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxXQUFXLEVBQUUsa0NBQWtDLEVBQUM7aUJBQzFGO2FBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge05nTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7UmVsYXRpb25Db21wb25lbnR9IGZyb20gJy4vcmVsYXRpb24uY29tcG9uZW50JztcclxuaW1wb3J0IHtSZWxhdGlvbkZpcnN0TmFtZU1vZHVsZX0gZnJvbSAnLi4vcmVsYXRpb24tZmlyc3QtbmFtZS9yZWxhdGlvbi1maXJzdC1uYW1lLm1vZHVsZSc7XHJcbmltcG9ydCB7XHJcbiAgQmFzZU1vZHVsZVNjcmVlbkNvbmZpZ1NlcnZpY2UsXHJcbiAgQmFzZU1vZHVsZVNlcnZpY2UsXHJcbiAgQnV0dG9uTW9kdWxlLFxyXG4gIENvcmVDb21wb25lbnRzVHJhbnNsYXRpb25Nb2R1bGUsXHJcbiAgQ29yZURpYWxvZ01vZHVsZSxcclxuICBMb2FkZXJNb2R1bGVcclxufSBmcm9tICdAY29saWpuaXQvY29yZWNvbXBvbmVudHNfdjEyJztcclxuaW1wb3J0IHtSZWxhdGlvbkxvYWRlckNvbXBvbmVudH0gZnJvbSAnLi4vYmFzZS9yZWxhdGlvbi1sb2FkZXIuY29tcG9uZW50JztcclxuaW1wb3J0IHtCcm93c2VyQW5pbWF0aW9uc01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlci9hbmltYXRpb25zJztcclxuaW1wb3J0IHtSZWxhdGlvblByZWZpeE5hbWVNb2R1bGV9IGZyb20gJy4uL3JlbGF0aW9uLXByZWZpeC1uYW1lL3JlbGF0aW9uLXByZWZpeC1uYW1lLm1vZHVsZSc7XHJcbmltcG9ydCB7UmVsYXRpb25MYXN0TmFtZU1vZHVsZX0gZnJvbSAnLi4vcmVsYXRpb24tbGFzdC1uYW1lL3JlbGF0aW9uLWxhc3QtbmFtZS5tb2R1bGUnO1xyXG5pbXBvcnQge1JlbGF0aW9uSW5pdGlhbHNNb2R1bGV9IGZyb20gJy4uL3JlbGF0aW9uLWluaXRpYWxzL3JlbGF0aW9uLWluaXRpYWxzLm1vZHVsZSc7XHJcbmltcG9ydCB7UmVsYXRpb25HZW5kZXJNb2R1bGV9IGZyb20gJy4uL3JlbGF0aW9uLWdlbmRlci9yZWxhdGlvbi1nZW5kZXIubW9kdWxlJztcclxuaW1wb3J0IHtSZWxhdGlvblRpdGxlTW9kdWxlfSBmcm9tICcuLi9yZWxhdGlvbi10aXRsZS9yZWxhdGlvbi10aXRsZS5tb2R1bGUnO1xyXG5pbXBvcnQge1JlbGF0aW9uUHJlZmVyZW5jZXNNb2R1bGV9IGZyb20gJy4uL3JlbGF0aW9uLXByZWZlcmVuY2VzL3JlbGF0aW9uLXByZWZlcmVuY2VzLm1vZHVsZSc7XHJcbmltcG9ydCB7UmVsYXRpb25MYW5ndWFnZU1vZHVsZX0gZnJvbSAnLi4vcmVsYXRpb24tbGFuZ3VhZ2UvcmVsYXRpb24tbGFuZ3VhZ2UubW9kdWxlJztcclxuaW1wb3J0IHtSZWxhdGlvbkNvbnRhY3RPcHRpb25zTW9kdWxlfSBmcm9tICcuLi9yZWxhdGlvbi1jb250YWN0LW9wdGlvbnMvcmVsYXRpb24tY29udGFjdC1vcHRpb25zLm1vZHVsZSc7XHJcbmltcG9ydCB7UmVsYXRpb25BdmF0YXJNb2R1bGV9IGZyb20gJy4uL3JlbGF0aW9uLWF2YXRhci9yZWxhdGlvbi1hdmF0YXIubW9kdWxlJztcclxuaW1wb3J0IHtSZWxhdGlvbkFkZHJlc3Nlc01vZHVsZX0gZnJvbSAnLi4vcmVsYXRpb24tYWRkcmVzc2VzL3JlbGF0aW9uLWFkZHJlc3Nlcy5tb2R1bGUnO1xyXG5pbXBvcnQge1JlbGF0aW9uU2VydmljZX0gZnJvbSAnLi4vLi4vc2VydmljZS9yZWxhdGlvbi5zZXJ2aWNlJztcclxuaW1wb3J0IHtSZWxhdGlvblNjcmVlbkNvbmZpZ3VyYXRpb25TZXJ2aWNlfSBmcm9tICcuLi8uLi9zZXJ2aWNlL3JlbGF0aW9uLXNjcmVlbi1jb25maWd1cmF0aW9uLnNlcnZpY2UnO1xyXG5pbXBvcnQge1JlbGF0aW9uVHJhbnNsYXRpb25Nb2R1bGV9IGZyb20gJy4uLy4uL3RyYW5zbGF0aW9uL3JlbGF0aW9uLXRyYW5zbGF0aW9uLm1vZHVsZSc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIEJyb3dzZXJBbmltYXRpb25zTW9kdWxlLFxyXG4gICAgQ29yZURpYWxvZ01vZHVsZSxcclxuICAgIFJlbGF0aW9uRmlyc3ROYW1lTW9kdWxlLFxyXG4gICAgQnV0dG9uTW9kdWxlLFxyXG4gICAgTG9hZGVyTW9kdWxlLFxyXG4gICAgUmVsYXRpb25QcmVmaXhOYW1lTW9kdWxlLFxyXG4gICAgUmVsYXRpb25MYXN0TmFtZU1vZHVsZSxcclxuICAgIFJlbGF0aW9uSW5pdGlhbHNNb2R1bGUsXHJcbiAgICBSZWxhdGlvbkdlbmRlck1vZHVsZSxcclxuICAgIFJlbGF0aW9uVGl0bGVNb2R1bGUsXHJcbiAgICBSZWxhdGlvblByZWZlcmVuY2VzTW9kdWxlLFxyXG4gICAgUmVsYXRpb25MYW5ndWFnZU1vZHVsZSxcclxuICAgIFJlbGF0aW9uQ29udGFjdE9wdGlvbnNNb2R1bGUsXHJcbiAgICBSZWxhdGlvbkF2YXRhck1vZHVsZSxcclxuICAgIFJlbGF0aW9uQWRkcmVzc2VzTW9kdWxlLFxyXG4gICAgQ29yZUNvbXBvbmVudHNUcmFuc2xhdGlvbk1vZHVsZS5mb3JSb290KCksXHJcbiAgICBSZWxhdGlvblRyYW5zbGF0aW9uTW9kdWxlXHJcbiAgXSxcclxuICBkZWNsYXJhdGlvbnM6IFtcclxuICAgIFJlbGF0aW9uTG9hZGVyQ29tcG9uZW50LFxyXG4gICAgUmVsYXRpb25Db21wb25lbnRcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtcclxuICAgIFJlbGF0aW9uQ29tcG9uZW50XHJcbiAgXSxcclxuICBwcm92aWRlcnM6IFtcclxuICAgIHtwcm92aWRlOiBCYXNlTW9kdWxlU2VydmljZSwgdXNlRXhpc3Rpbmc6IFJlbGF0aW9uU2VydmljZX0sXHJcbiAgICB7cHJvdmlkZTogQmFzZU1vZHVsZVNjcmVlbkNvbmZpZ1NlcnZpY2UsIHVzZUV4aXN0aW5nOiBSZWxhdGlvblNjcmVlbkNvbmZpZ3VyYXRpb25TZXJ2aWNlfVxyXG4gIF0sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBSZWxhdGlvbk1vZHVsZSB7XHJcbn1cclxuIl19
63
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVsYXRpb24ubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcmVsYXRpb24vc3JjL2xpYi9jb21wb25lbnQvcmVsYXRpb24vcmVsYXRpb24ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxpQkFBaUIsRUFBQyxNQUFNLHNCQUFzQixDQUFDO0FBQ3ZELE9BQU8sRUFBQyx1QkFBdUIsRUFBQyxNQUFNLG1EQUFtRCxDQUFDO0FBQzFGLE9BQU8sRUFDTCw2QkFBNkIsRUFDN0IsaUJBQWlCLEVBQ2pCLFlBQVksRUFDWiwrQkFBK0IsRUFDL0IsZ0JBQWdCLEVBQ2hCLFlBQVksRUFBRSx5QkFBeUIsRUFDeEMsTUFBTSw4QkFBOEIsQ0FBQztBQUN0QyxPQUFPLEVBQUMsdUJBQXVCLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQUMxRSxPQUFPLEVBQUMsdUJBQXVCLEVBQUMsTUFBTSxzQ0FBc0MsQ0FBQztBQUM3RSxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSxxREFBcUQsQ0FBQztBQUM3RixPQUFPLEVBQUMsc0JBQXNCLEVBQUMsTUFBTSxpREFBaUQsQ0FBQztBQUN2RixPQUFPLEVBQUMsc0JBQXNCLEVBQUMsTUFBTSwrQ0FBK0MsQ0FBQztBQUNyRixPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQUMvRSxPQUFPLEVBQUMsbUJBQW1CLEVBQUMsTUFBTSx5Q0FBeUMsQ0FBQztBQUM1RSxPQUFPLEVBQUMseUJBQXlCLEVBQUMsTUFBTSxxREFBcUQsQ0FBQztBQUM5RixPQUFPLEVBQUMsc0JBQXNCLEVBQUMsTUFBTSwrQ0FBK0MsQ0FBQztBQUNyRixPQUFPLEVBQUMsNEJBQTRCLEVBQUMsTUFBTSw2REFBNkQsQ0FBQztBQUN6RyxPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQUMvRSxPQUFPLEVBQUMsdUJBQXVCLEVBQUMsTUFBTSxpREFBaUQsQ0FBQztBQUN4RixPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sZ0NBQWdDLENBQUM7QUFDL0QsT0FBTyxFQUFDLGtDQUFrQyxFQUFDLE1BQU0scURBQXFELENBQUM7QUFDdkcsT0FBTyxFQUFDLHlCQUF5QixFQUFDLE1BQU0sK0NBQStDLENBQUM7QUFDeEYsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFDLHVCQUF1QixFQUFDLE1BQU0saURBQWlELENBQUM7QUFzQ3hGLE1BQU0sT0FBTyxjQUFjOzs7WUFwQzFCLFFBQVEsU0FBQztnQkFDUixPQUFPLEVBQUU7b0JBQ1AsWUFBWTtvQkFDWix1QkFBdUI7b0JBQ3ZCLGdCQUFnQjtvQkFDaEIsdUJBQXVCO29CQUN2QixZQUFZO29CQUNaLFlBQVk7b0JBQ1osd0JBQXdCO29CQUN4QixzQkFBc0I7b0JBQ3RCLHNCQUFzQjtvQkFDdEIsb0JBQW9CO29CQUNwQixtQkFBbUI7b0JBQ25CLHlCQUF5QjtvQkFDekIsc0JBQXNCO29CQUN0Qiw0QkFBNEI7b0JBQzVCLG9CQUFvQjtvQkFDcEIsdUJBQXVCO29CQUN2QiwrQkFBK0IsQ0FBQyxPQUFPLEVBQUU7b0JBQ3pDLHlCQUF5QixDQUFDLE9BQU8sRUFBRTtvQkFDbkMseUJBQXlCO29CQUN6QixpQkFBaUI7b0JBQ2pCLHVCQUF1QjtpQkFDeEI7Z0JBQ0QsWUFBWSxFQUFFO29CQUNaLHVCQUF1QjtvQkFDdkIsaUJBQWlCO2lCQUNsQjtnQkFDRCxPQUFPLEVBQUU7b0JBQ1AsaUJBQWlCO2lCQUNsQjtnQkFDRCxTQUFTLEVBQUU7b0JBQ1QsRUFBQyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsV0FBVyxFQUFFLGVBQWUsRUFBQztvQkFDMUQsRUFBQyxPQUFPLEVBQUUsNkJBQTZCLEVBQUUsV0FBVyxFQUFFLGtDQUFrQyxFQUFDO2lCQUMxRjthQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQge1JlbGF0aW9uQ29tcG9uZW50fSBmcm9tICcuL3JlbGF0aW9uLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7UmVsYXRpb25GaXJzdE5hbWVNb2R1bGV9IGZyb20gJy4uL3JlbGF0aW9uLWZpcnN0LW5hbWUvcmVsYXRpb24tZmlyc3QtbmFtZS5tb2R1bGUnO1xyXG5pbXBvcnQge1xyXG4gIEJhc2VNb2R1bGVTY3JlZW5Db25maWdTZXJ2aWNlLFxyXG4gIEJhc2VNb2R1bGVTZXJ2aWNlLFxyXG4gIEJ1dHRvbk1vZHVsZSxcclxuICBDb3JlQ29tcG9uZW50c1RyYW5zbGF0aW9uTW9kdWxlLFxyXG4gIENvcmVEaWFsb2dNb2R1bGUsXHJcbiAgTG9hZGVyTW9kdWxlLCBTY3JlZW5Db25maWd1cmF0aW9uTW9kdWxlXHJcbn0gZnJvbSAnQGNvbGlqbml0L2NvcmVjb21wb25lbnRzX3YxMic7XHJcbmltcG9ydCB7UmVsYXRpb25Mb2FkZXJDb21wb25lbnR9IGZyb20gJy4uL2Jhc2UvcmVsYXRpb24tbG9hZGVyLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7QnJvd3NlckFuaW1hdGlvbnNNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXIvYW5pbWF0aW9ucyc7XHJcbmltcG9ydCB7UmVsYXRpb25QcmVmaXhOYW1lTW9kdWxlfSBmcm9tICcuLi9yZWxhdGlvbi1wcmVmaXgtbmFtZS9yZWxhdGlvbi1wcmVmaXgtbmFtZS5tb2R1bGUnO1xyXG5pbXBvcnQge1JlbGF0aW9uTGFzdE5hbWVNb2R1bGV9IGZyb20gJy4uL3JlbGF0aW9uLWxhc3QtbmFtZS9yZWxhdGlvbi1sYXN0LW5hbWUubW9kdWxlJztcclxuaW1wb3J0IHtSZWxhdGlvbkluaXRpYWxzTW9kdWxlfSBmcm9tICcuLi9yZWxhdGlvbi1pbml0aWFscy9yZWxhdGlvbi1pbml0aWFscy5tb2R1bGUnO1xyXG5pbXBvcnQge1JlbGF0aW9uR2VuZGVyTW9kdWxlfSBmcm9tICcuLi9yZWxhdGlvbi1nZW5kZXIvcmVsYXRpb24tZ2VuZGVyLm1vZHVsZSc7XHJcbmltcG9ydCB7UmVsYXRpb25UaXRsZU1vZHVsZX0gZnJvbSAnLi4vcmVsYXRpb24tdGl0bGUvcmVsYXRpb24tdGl0bGUubW9kdWxlJztcclxuaW1wb3J0IHtSZWxhdGlvblByZWZlcmVuY2VzTW9kdWxlfSBmcm9tICcuLi9yZWxhdGlvbi1wcmVmZXJlbmNlcy9yZWxhdGlvbi1wcmVmZXJlbmNlcy5tb2R1bGUnO1xyXG5pbXBvcnQge1JlbGF0aW9uTGFuZ3VhZ2VNb2R1bGV9IGZyb20gJy4uL3JlbGF0aW9uLWxhbmd1YWdlL3JlbGF0aW9uLWxhbmd1YWdlLm1vZHVsZSc7XHJcbmltcG9ydCB7UmVsYXRpb25Db250YWN0T3B0aW9uc01vZHVsZX0gZnJvbSAnLi4vcmVsYXRpb24tY29udGFjdC1vcHRpb25zL3JlbGF0aW9uLWNvbnRhY3Qtb3B0aW9ucy5tb2R1bGUnO1xyXG5pbXBvcnQge1JlbGF0aW9uQXZhdGFyTW9kdWxlfSBmcm9tICcuLi9yZWxhdGlvbi1hdmF0YXIvcmVsYXRpb24tYXZhdGFyLm1vZHVsZSc7XHJcbmltcG9ydCB7UmVsYXRpb25BZGRyZXNzZXNNb2R1bGV9IGZyb20gJy4uL3JlbGF0aW9uLWFkZHJlc3Nlcy9yZWxhdGlvbi1hZGRyZXNzZXMubW9kdWxlJztcclxuaW1wb3J0IHtSZWxhdGlvblNlcnZpY2V9IGZyb20gJy4uLy4uL3NlcnZpY2UvcmVsYXRpb24uc2VydmljZSc7XHJcbmltcG9ydCB7UmVsYXRpb25TY3JlZW5Db25maWd1cmF0aW9uU2VydmljZX0gZnJvbSAnLi4vLi4vc2VydmljZS9yZWxhdGlvbi1zY3JlZW4tY29uZmlndXJhdGlvbi5zZXJ2aWNlJztcclxuaW1wb3J0IHtSZWxhdGlvblRyYW5zbGF0aW9uTW9kdWxlfSBmcm9tICcuLi8uLi90cmFuc2xhdGlvbi9yZWxhdGlvbi10cmFuc2xhdGlvbi5tb2R1bGUnO1xyXG5pbXBvcnQge0ZpbGVzVXBsb2FkTW9kdWxlfSBmcm9tIFwiQGNvbGlqbml0L2NvcmVjb21wb25lbnRzXCI7XHJcbmltcG9ydCB7UmVsYXRpb25Eb2N1bWVudHNNb2R1bGV9IGZyb20gXCIuLi9yZWxhdGlvbi1kb2N1bWVudHMvcmVsYXRpb24tZG9jdW1lbnRzLm1vZHVsZVwiO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBCcm93c2VyQW5pbWF0aW9uc01vZHVsZSxcclxuICAgIENvcmVEaWFsb2dNb2R1bGUsXHJcbiAgICBSZWxhdGlvbkZpcnN0TmFtZU1vZHVsZSxcclxuICAgIEJ1dHRvbk1vZHVsZSxcclxuICAgIExvYWRlck1vZHVsZSxcclxuICAgIFJlbGF0aW9uUHJlZml4TmFtZU1vZHVsZSxcclxuICAgIFJlbGF0aW9uTGFzdE5hbWVNb2R1bGUsXHJcbiAgICBSZWxhdGlvbkluaXRpYWxzTW9kdWxlLFxyXG4gICAgUmVsYXRpb25HZW5kZXJNb2R1bGUsXHJcbiAgICBSZWxhdGlvblRpdGxlTW9kdWxlLFxyXG4gICAgUmVsYXRpb25QcmVmZXJlbmNlc01vZHVsZSxcclxuICAgIFJlbGF0aW9uTGFuZ3VhZ2VNb2R1bGUsXHJcbiAgICBSZWxhdGlvbkNvbnRhY3RPcHRpb25zTW9kdWxlLFxyXG4gICAgUmVsYXRpb25BdmF0YXJNb2R1bGUsXHJcbiAgICBSZWxhdGlvbkFkZHJlc3Nlc01vZHVsZSxcclxuICAgIENvcmVDb21wb25lbnRzVHJhbnNsYXRpb25Nb2R1bGUuZm9yUm9vdCgpLFxyXG4gICAgUmVsYXRpb25UcmFuc2xhdGlvbk1vZHVsZS5mb3JSb290KCksXHJcbiAgICBTY3JlZW5Db25maWd1cmF0aW9uTW9kdWxlLFxyXG4gICAgRmlsZXNVcGxvYWRNb2R1bGUsXHJcbiAgICBSZWxhdGlvbkRvY3VtZW50c01vZHVsZVxyXG4gIF0sXHJcbiAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICBSZWxhdGlvbkxvYWRlckNvbXBvbmVudCxcclxuICAgIFJlbGF0aW9uQ29tcG9uZW50XHJcbiAgXSxcclxuICBleHBvcnRzOiBbXHJcbiAgICBSZWxhdGlvbkNvbXBvbmVudFxyXG4gIF0sXHJcbiAgcHJvdmlkZXJzOiBbXHJcbiAgICB7cHJvdmlkZTogQmFzZU1vZHVsZVNlcnZpY2UsIHVzZUV4aXN0aW5nOiBSZWxhdGlvblNlcnZpY2V9LFxyXG4gICAge3Byb3ZpZGU6IEJhc2VNb2R1bGVTY3JlZW5Db25maWdTZXJ2aWNlLCB1c2VFeGlzdGluZzogUmVsYXRpb25TY3JlZW5Db25maWd1cmF0aW9uU2VydmljZX1cclxuICBdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgUmVsYXRpb25Nb2R1bGUge1xyXG59XHJcbiJdfQ==
@@ -1,7 +1,7 @@
1
1
  import { __awaiter } from "tslib";
2
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, HostBinding, HostListener, Input, ViewChild, ViewEncapsulation } from '@angular/core';
2
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, forwardRef, HostBinding, HostListener, Input, ViewChild, ViewEncapsulation } from '@angular/core';
3
3
  import { RelationConnectorService } from '../../service/relation-connector.service';
4
- import { ColorSequenceService, CoreDialogService } from '@colijnit/corecomponents_v12';
4
+ import { ColorSequenceService, CoreDialogService, SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME } from '@colijnit/corecomponents_v12';
5
5
  import { FileUtils } from '@colijnit/mainapi/build/utils/file-utils';
6
6
  import { StringUtils } from '@colijnit/ioneconnector/build/utils/string-utils';
7
7
  import { CoDocumentImageDisplayKind } from '@colijnit/mainapi/build/enum/co-document-image-display-kind.enum';
@@ -197,7 +197,11 @@ RelationAvatarComponent.decorators = [
197
197
  </ng-container>
198
198
  `,
199
199
  changeDetection: ChangeDetectionStrategy.OnPush,
200
- encapsulation: ViewEncapsulation.None
200
+ encapsulation: ViewEncapsulation.None,
201
+ providers: [{
202
+ provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,
203
+ useExisting: forwardRef(() => RelationAvatarComponent)
204
+ }]
201
205
  },] }
202
206
  ];
203
207
  RelationAvatarComponent.ctorParameters = () => [
@@ -219,4 +223,4 @@ RelationAvatarComponent.propDecorators = {
219
223
  backgroundColor: [{ type: HostBinding, args: ["style.background-color",] }],
220
224
  onClick: [{ type: HostListener, args: ["click",] }]
221
225
  };
222
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relation-avatar.component.js","sourceRoot":"","sources":["../../../../../../projects/relation/src/lib/component/relation-avatar/relation-avatar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component, ElementRef,\r\n  HostBinding,\r\n  HostListener,\r\n  Input, OnDestroy,\r\n  OnInit, ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {CoDocument} from '@colijnit/mainapi/build/model/co-document.bo';\r\nimport {RelationConnectorService} from '../../service/relation-connector.service';\r\nimport {ColorSequenceService, CoreDialogService} from '@colijnit/corecomponents_v12';\r\nimport {RelationAnyType} from '@colijnit/relationapi/build/model/relation-any-type';\r\nimport {RelationSmallObject} from '@colijnit/relationapi/build/model/relation-small-object.bo';\r\nimport {FileUtils} from '@colijnit/mainapi/build/utils/file-utils';\r\nimport {StringUtils} from '@colijnit/ioneconnector/build/utils/string-utils';\r\nimport {CoDocumentImageDisplayKind} from '@colijnit/mainapi/build/enum/co-document-image-display-kind.enum';\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-avatar',\r\n  template: `\r\n      <co-image [source]=\"imageSrc\" *ngIf=\"imageSrc; else showInitials\"></co-image>\r\n      <ng-template #showInitials>\r\n          <svg viewBox=\"0 0 30 30\">\r\n              <text x=\"50%\" y=\"50%\" dominant-baseline=\"central\" text-anchor=\"middle\">{{ initials }}</text>\r\n          </svg>\r\n      </ng-template>\r\n      <ng-container *ngIf=\"canChangeAvatar\">\r\n          <div class=\"relation-avatar-pencil-wrapper\">\r\n              <co-icon [iconData]=\"iconCacheService.getIcon(icons.PencilRoundOpen)\" class=\"pencil-icon\"></co-icon>\r\n          </div>\r\n          <input #uploadAvatar class=\"value-text\" type=\"file\" (change)=\"onFileChangeEvent($event)\" accept=\".jpg, .png, .jpeg\">\r\n      </ng-container>\r\n  `,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class RelationAvatarComponent implements OnInit, OnDestroy {\r\n  public readonly icons: typeof Icon = Icon;\r\n\r\n  @ViewChild(\"uploadAvatar\")\r\n  public input: ElementRef;\r\n\r\n  @Input()\r\n  public set image(value: CoDocument) {\r\n    this._image = value;\r\n    this._setImageForAvatar();\r\n  }\r\n\r\n  public get image(): CoDocument {\r\n    return this._image;\r\n  }\r\n\r\n  @Input()\r\n  public set relationId(value: number) {\r\n    if (this.relationId !== value) {\r\n      this._image = undefined;\r\n      this._relation = undefined;\r\n      this._relationId = value;\r\n      this._setImageForAvatar();\r\n    }\r\n  }\r\n\r\n  public get relationId(): number {\r\n    return this._relationId;\r\n  }\r\n\r\n  @Input()\r\n  public set relation(value: RelationAnyType) {\r\n    if (!this._relation || (this._relation && value && this._relation.relationId !== value.relationId)) {\r\n      this._image = undefined;\r\n      this._relationId = undefined;\r\n      this._relation = value;\r\n      this._setImageForAvatar();\r\n    }\r\n  }\r\n\r\n  public get relation(): RelationAnyType {\r\n    return this._relation;\r\n  }\r\n\r\n  @Input() @HostBinding(\"class.can-change\")\r\n  public canChangeAvatar: boolean = false;\r\n\r\n  @Input()\r\n  public maxUploadSizeInMb: number = 3;\r\n\r\n  @Input()\r\n  public maxAvatarSize: number = 200;\r\n\r\n  @HostBinding('class.co-relation-avatar')\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public imageSrc: string;\r\n\r\n  @HostBinding(\"style.background-color\")\r\n  public backgroundColor: string;\r\n\r\n  @HostListener(\"click\")\r\n  public onClick(): void {\r\n    this.uploadTheAvatar();\r\n  }\r\n\r\n  public set initials(value: string) {\r\n    this._initials = value;\r\n    this._setBackgroundColor();\r\n  }\r\n\r\n  public get initials(): string {\r\n    return this._initials;\r\n  }\r\n\r\n  private _initials: string;\r\n  private _relationId: number;\r\n  private _relation: RelationAnyType;\r\n  private _image: CoDocument;\r\n\r\n  constructor(\r\n    public iconCacheService: IconCacheService,\r\n    private _relationConnectorService: RelationConnectorService,\r\n    private _colorSequenceService: ColorSequenceService,\r\n    private _changeDetector: ChangeDetectorRef,\r\n    private _dialogService: CoreDialogService\r\n  ) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    this._setImageForAvatar();\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.input = undefined;\r\n  }\r\n\r\n  public uploadTheAvatar(): void {\r\n    if (this.canChangeAvatar && this.input) {\r\n      this.input.nativeElement.click();\r\n    }\r\n  }\r\n\r\n  // Take File from event and save it internally as a CoDocument.\r\n  public onFileChangeEvent(event: any): void {\r\n    if (event && event.target && event.target.files && event.target.files.length > 0) {\r\n      const fileToUpload: File = event.target.files[0];\r\n\r\n      if (!FileUtils.CheckMaxUploadSize(fileToUpload)) {\r\n        this._dialogService.showWarning(StringUtils.Format(\r\n          \"File is to large to upload. Maximum file size is {0} Mb\", [this.maxUploadSizeInMb]));\r\n      } else if (!FileUtils.IsImageFile(fileToUpload)) {\r\n        this._dialogService.showWarning(\"Please select an image\");\r\n      } else {\r\n        this._setFileAsAvatarToCurrentRelation(fileToUpload);\r\n      }\r\n      if (this.input && this.input.nativeElement) {\r\n        this.input.nativeElement.value = null;\r\n      }\r\n    }\r\n  }\r\n\r\n  private async _setFileAsAvatarToCurrentRelation(file: File): Promise<void> {\r\n    const document: CoDocument = await FileUtils.ReadFileAsNewCoDocument(file, true, this.maxAvatarSize);\r\n    await this.setDocProperties(document);\r\n  }\r\n\r\n  private async setDocProperties(document: CoDocument): Promise<void> {\r\n    document.thumbnailBody = document.documentBody;\r\n    document.creationDate = new Date();\r\n    document.creationUser = this._relationConnectorService.loginResponse.userName;\r\n    document.imageDisplayKind = CoDocumentImageDisplayKind.Avatar;\r\n    if (this._relation) {\r\n      this._relation.avatarImage = document;\r\n    }\r\n    this.imageSrc = document.thumbnailBodyAsDataUri;\r\n    this._changeDetector.detectChanges();\r\n  }\r\n\r\n  private async _setImageForAvatar(): Promise<void> {\r\n    if (this.image && this.image.documentId) {\r\n      if (!await this._getImageContent(this.image.documentId)) {\r\n        this._setImageFromRelation();\r\n      }\r\n    } else {\r\n      this._setImageFromRelation();\r\n    }\r\n    this._changeDetector.detectChanges();\r\n  }\r\n\r\n  private async _setImageFromRelation(): Promise<void> {\r\n    if (this.relation) {\r\n      if (this.relation.avatarImage && this.relation.avatarImage.documentId) {\r\n        this._image = this.relation.avatarImage;\r\n        if (!await this._getImageContent(this.image.documentId)) {\r\n          this._setRelationInitials();\r\n        }\r\n      } else {\r\n        this._setRelationInitials();\r\n      }\r\n    } else if (this.relationId) {\r\n      this._relationConnectorService.getRelationSmallObject(this.relationId).then(async (relationSmallObject: RelationSmallObject) => {\r\n        if (relationSmallObject) {\r\n          if (relationSmallObject.avatarImage && relationSmallObject.avatarImage.documentId) {\r\n            this._image = relationSmallObject.avatarImage;\r\n            if (!await this._getImageContent(this.image.documentId)) {\r\n              this._setRelationInitials();\r\n            }\r\n          } else {\r\n            this._setRelationInitials();\r\n          }\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  private _setRelationInitials(): void {\r\n    if (this.relation) {\r\n      this.initials = this.relation.displayInitials;\r\n    }\r\n  }\r\n\r\n  private async _getImageContent(docId: number): Promise<boolean> {\r\n    const content: string = await this._relationConnectorService.getDocumentContent(docId);\r\n    if (content && this._image) {\r\n      this._image.thumbnailBody = content;\r\n      this.imageSrc = this.image.thumbnailBodyAsDataUri;\r\n      this._changeDetector.detectChanges();\r\n      return true;\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  private _setBackgroundColor(): void {\r\n    this.imageSrc = \"\";\r\n    if (this.relation) {\r\n      this.backgroundColor = this._colorSequenceService.getRandomColor(this.relation.relationId);\r\n    }\r\n    this._changeDetector.detectChanges();\r\n  }\r\n} \r\n"]}
226
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relation-avatar.component.js","sourceRoot":"","sources":["../../../../../../projects/relation/src/lib/component/relation-avatar/relation-avatar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component, ElementRef, forwardRef,\r\n  HostBinding,\r\n  HostListener,\r\n  Input, OnDestroy,\r\n  OnInit, ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {CoDocument} from '@colijnit/mainapi/build/model/co-document.bo';\r\nimport {RelationConnectorService} from '../../service/relation-connector.service';\r\nimport {ColorSequenceService, CoreDialogService, SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '@colijnit/corecomponents_v12';\r\nimport {RelationAnyType} from '@colijnit/relationapi/build/model/relation-any-type';\r\nimport {RelationSmallObject} from '@colijnit/relationapi/build/model/relation-small-object.bo';\r\nimport {FileUtils} from '@colijnit/mainapi/build/utils/file-utils';\r\nimport {StringUtils} from '@colijnit/ioneconnector/build/utils/string-utils';\r\nimport {CoDocumentImageDisplayKind} from '@colijnit/mainapi/build/enum/co-document-image-display-kind.enum';\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-avatar',\r\n  template: `\r\n      <co-image [source]=\"imageSrc\" *ngIf=\"imageSrc; else showInitials\"></co-image>\r\n      <ng-template #showInitials>\r\n          <svg viewBox=\"0 0 30 30\">\r\n              <text x=\"50%\" y=\"50%\" dominant-baseline=\"central\" text-anchor=\"middle\">{{ initials }}</text>\r\n          </svg>\r\n      </ng-template>\r\n      <ng-container *ngIf=\"canChangeAvatar\">\r\n          <div class=\"relation-avatar-pencil-wrapper\">\r\n              <co-icon [iconData]=\"iconCacheService.getIcon(icons.PencilRoundOpen)\" class=\"pencil-icon\"></co-icon>\r\n          </div>\r\n          <input #uploadAvatar class=\"value-text\" type=\"file\" (change)=\"onFileChangeEvent($event)\" accept=\".jpg, .png, .jpeg\">\r\n      </ng-container>\r\n  `,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  encapsulation: ViewEncapsulation.None,\r\n  providers: [{\r\n    provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n    useExisting: forwardRef(() => RelationAvatarComponent)\r\n  }],\r\n})\r\nexport class RelationAvatarComponent implements OnInit, OnDestroy {\r\n  public readonly icons: typeof Icon = Icon;\r\n\r\n  @ViewChild(\"uploadAvatar\")\r\n  public input: ElementRef;\r\n\r\n  @Input()\r\n  public set image(value: CoDocument) {\r\n    this._image = value;\r\n    this._setImageForAvatar();\r\n  }\r\n\r\n  public get image(): CoDocument {\r\n    return this._image;\r\n  }\r\n\r\n  @Input()\r\n  public set relationId(value: number) {\r\n    if (this.relationId !== value) {\r\n      this._image = undefined;\r\n      this._relation = undefined;\r\n      this._relationId = value;\r\n      this._setImageForAvatar();\r\n    }\r\n  }\r\n\r\n  public get relationId(): number {\r\n    return this._relationId;\r\n  }\r\n\r\n  @Input()\r\n  public set relation(value: RelationAnyType) {\r\n    if (!this._relation || (this._relation && value && this._relation.relationId !== value.relationId)) {\r\n      this._image = undefined;\r\n      this._relationId = undefined;\r\n      this._relation = value;\r\n      this._setImageForAvatar();\r\n    }\r\n  }\r\n\r\n  public get relation(): RelationAnyType {\r\n    return this._relation;\r\n  }\r\n\r\n  @Input() @HostBinding(\"class.can-change\")\r\n  public canChangeAvatar: boolean = false;\r\n\r\n  @Input()\r\n  public maxUploadSizeInMb: number = 3;\r\n\r\n  @Input()\r\n  public maxAvatarSize: number = 200;\r\n\r\n  @HostBinding('class.co-relation-avatar')\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public imageSrc: string;\r\n\r\n  @HostBinding(\"style.background-color\")\r\n  public backgroundColor: string;\r\n\r\n  @HostListener(\"click\")\r\n  public onClick(): void {\r\n    this.uploadTheAvatar();\r\n  }\r\n\r\n  public set initials(value: string) {\r\n    this._initials = value;\r\n    this._setBackgroundColor();\r\n  }\r\n\r\n  public get initials(): string {\r\n    return this._initials;\r\n  }\r\n\r\n  private _initials: string;\r\n  private _relationId: number;\r\n  private _relation: RelationAnyType;\r\n  private _image: CoDocument;\r\n\r\n  constructor(\r\n    public iconCacheService: IconCacheService,\r\n    private _relationConnectorService: RelationConnectorService,\r\n    private _colorSequenceService: ColorSequenceService,\r\n    private _changeDetector: ChangeDetectorRef,\r\n    private _dialogService: CoreDialogService\r\n  ) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    this._setImageForAvatar();\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.input = undefined;\r\n  }\r\n\r\n  public uploadTheAvatar(): void {\r\n    if (this.canChangeAvatar && this.input) {\r\n      this.input.nativeElement.click();\r\n    }\r\n  }\r\n\r\n  // Take File from event and save it internally as a CoDocument.\r\n  public onFileChangeEvent(event: any): void {\r\n    if (event && event.target && event.target.files && event.target.files.length > 0) {\r\n      const fileToUpload: File = event.target.files[0];\r\n\r\n      if (!FileUtils.CheckMaxUploadSize(fileToUpload)) {\r\n        this._dialogService.showWarning(StringUtils.Format(\r\n          \"File is to large to upload. Maximum file size is {0} Mb\", [this.maxUploadSizeInMb]));\r\n      } else if (!FileUtils.IsImageFile(fileToUpload)) {\r\n        this._dialogService.showWarning(\"Please select an image\");\r\n      } else {\r\n        this._setFileAsAvatarToCurrentRelation(fileToUpload);\r\n      }\r\n      if (this.input && this.input.nativeElement) {\r\n        this.input.nativeElement.value = null;\r\n      }\r\n    }\r\n  }\r\n\r\n  private async _setFileAsAvatarToCurrentRelation(file: File): Promise<void> {\r\n    const document: CoDocument = await FileUtils.ReadFileAsNewCoDocument(file, true, this.maxAvatarSize);\r\n    await this.setDocProperties(document);\r\n  }\r\n\r\n  private async setDocProperties(document: CoDocument): Promise<void> {\r\n    document.thumbnailBody = document.documentBody;\r\n    document.creationDate = new Date();\r\n    document.creationUser = this._relationConnectorService.loginResponse.userName;\r\n    document.imageDisplayKind = CoDocumentImageDisplayKind.Avatar;\r\n    if (this._relation) {\r\n      this._relation.avatarImage = document;\r\n    }\r\n    this.imageSrc = document.thumbnailBodyAsDataUri;\r\n    this._changeDetector.detectChanges();\r\n  }\r\n\r\n  private async _setImageForAvatar(): Promise<void> {\r\n    if (this.image && this.image.documentId) {\r\n      if (!await this._getImageContent(this.image.documentId)) {\r\n        this._setImageFromRelation();\r\n      }\r\n    } else {\r\n      this._setImageFromRelation();\r\n    }\r\n    this._changeDetector.detectChanges();\r\n  }\r\n\r\n  private async _setImageFromRelation(): Promise<void> {\r\n    if (this.relation) {\r\n      if (this.relation.avatarImage && this.relation.avatarImage.documentId) {\r\n        this._image = this.relation.avatarImage;\r\n        if (!await this._getImageContent(this.image.documentId)) {\r\n          this._setRelationInitials();\r\n        }\r\n      } else {\r\n        this._setRelationInitials();\r\n      }\r\n    } else if (this.relationId) {\r\n      this._relationConnectorService.getRelationSmallObject(this.relationId).then(async (relationSmallObject: RelationSmallObject) => {\r\n        if (relationSmallObject) {\r\n          if (relationSmallObject.avatarImage && relationSmallObject.avatarImage.documentId) {\r\n            this._image = relationSmallObject.avatarImage;\r\n            if (!await this._getImageContent(this.image.documentId)) {\r\n              this._setRelationInitials();\r\n            }\r\n          } else {\r\n            this._setRelationInitials();\r\n          }\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  private _setRelationInitials(): void {\r\n    if (this.relation) {\r\n      this.initials = this.relation.displayInitials;\r\n    }\r\n  }\r\n\r\n  private async _getImageContent(docId: number): Promise<boolean> {\r\n    const content: string = await this._relationConnectorService.getDocumentContent(docId);\r\n    if (content && this._image) {\r\n      this._image.thumbnailBody = content;\r\n      this.imageSrc = this.image.thumbnailBodyAsDataUri;\r\n      this._changeDetector.detectChanges();\r\n      return true;\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  private _setBackgroundColor(): void {\r\n    this.imageSrc = \"\";\r\n    if (this.relation) {\r\n      this.backgroundColor = this._colorSequenceService.getRandomColor(this.relation.relationId);\r\n    }\r\n    this._changeDetector.detectChanges();\r\n  }\r\n} \r\n"]}
@@ -9,11 +9,12 @@ const DragConfig = {
9
9
  const ɵ0 = DragConfig;
10
10
  export class RelationContactOptionListComponent {
11
11
  constructor() {
12
+ // Drag-drop doesn't work when the fields wrap (ex. flex-wrap). Hardcoded to true until fixed.
12
13
  this.dragDropDisabled = false;
13
14
  this.collection = [];
14
15
  this.deleteClick = new EventEmitter();
15
16
  this.showClass = true;
16
- this.dragStartDelay = 500;
17
+ this.dragStartDelay = 200;
17
18
  this.handleCanDragDrop = (drag, drop) => {
18
19
  return (drag.data.type === this.type);
19
20
  };
@@ -43,11 +44,11 @@ export class RelationContactOptionListComponent {
43
44
  clearTimeout(this._mouseDownTimeout);
44
45
  this._mouseDownTimeout = setTimeout(() => {
45
46
  let mouseMoveEvent;
46
- if ("createEvent" in document) {
47
- mouseMoveEvent = document.createEvent("Event");
47
+ if ('createEvent' in document) {
48
+ mouseMoveEvent = document.createEvent('Event');
48
49
  mouseMoveEvent.initEvent('mousemove', true, true);
49
50
  }
50
- else if ("Event" in window) {
51
+ else if ('Event' in window) {
51
52
  mouseMoveEvent = new Event('mousemove', { bubbles: true, cancelable: true });
52
53
  }
53
54
  // @ts-ignore
@@ -60,9 +61,21 @@ export class RelationContactOptionListComponent {
60
61
  handleOptionMouseUp(event) {
61
62
  clearTimeout(this._mouseDownTimeout);
62
63
  }
64
+ handleSequenceUp(option) {
65
+ const optionIndex = this.collection.indexOf(option);
66
+ moveItemInArray(this.collection, optionIndex, optionIndex + 1);
67
+ this._reArrangeSequences();
68
+ }
69
+ handleSequenceDown(option) {
70
+ const optionIndex = this.collection.indexOf(option);
71
+ moveItemInArray(this.collection, optionIndex, optionIndex - 1);
72
+ this._reArrangeSequences();
73
+ }
63
74
  _reArrangeSequences() {
64
75
  for (let i = 0; i < this.collection.length; i++) {
65
76
  this.collection[i].sequence = i;
77
+ this.collection[i].lowestSequence = (i === 0);
78
+ this.collection[i].highestSequence = (i === this.collection.length - 1);
66
79
  }
67
80
  }
68
81
  }
@@ -70,17 +83,19 @@ RelationContactOptionListComponent.decorators = [
70
83
  { type: Component, args: [{
71
84
  selector: 'co-relation-contact-option-list',
72
85
  template: `
73
- <div #dropListContactOptions class="contact-option-wrapper drag-drop-list" cdkDropList cdkDropListOrientation="vertical"
74
- [cdkDropListDisabled]="dragDropDisabled"
86
+ <div #dropListContactOptions class="contact-option-wrapper drag-drop-list" cdkDropList cdkDropListOrientation="horizontal"
87
+ [cdkDropListDisabled]="true"
75
88
  [cdkDropListData]="collection"
76
89
  [cdkDropListEnterPredicate]="handleCanDragDrop"
77
90
  (cdkDropListDropped)="handleDrop($event)"
78
91
  >
79
92
  <co-relation-contact-option class="draggable-contact-option" *ngFor="let option of collection" [model]="option"
80
93
  cdkDrag [cdkDragStartDelay]="dragStartDelay"
81
- (mousedown)="handleOptionMouseDown($event)"
94
+ (mousedown)="handleOptionMouseDown($event)"
82
95
  (mouseup)="handleOptionMouseUp($event)"
83
96
  (deleteClick)="deleteClick.emit($event)"
97
+ (sequenceChangeUp)="handleSequenceUp($event)"
98
+ (sequenceChangeDown)="handleSequenceDown($event)"
84
99
  ></co-relation-contact-option>
85
100
  </div>
86
101
  `,
@@ -98,4 +113,4 @@ RelationContactOptionListComponent.propDecorators = {
98
113
  showClass: [{ type: HostBinding, args: ['class.co-relation-contact-option-list',] }]
99
114
  };
100
115
  export { ɵ0 };
101
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relation-contact-option-list.component.js","sourceRoot":"","sources":["../../../../../../projects/relation/src/lib/component/relation-contact-options/relation-contact-option-list.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewEncapsulation} from '@angular/core';\r\nimport {ContactOption} from '@colijnit/relationapi/build/model/contact-option.bo';\r\nimport {CommunicationType} from '@colijnit/relationapi/build/enum/communication-type.enum';\r\nimport {CDK_DRAG_CONFIG, CdkDrag, CdkDragDrop, CdkDropList, moveItemInArray} from '@angular/cdk/drag-drop';\r\n\r\nconst DragConfig = {\r\n  dragStartThreshold: 0,\r\n  pointerDirectionChangeThreshold: 5,\r\n  zIndex: 10000\r\n};\r\n\r\n@Component({\r\n  selector: 'co-relation-contact-option-list',\r\n  template: `\r\n      <div #dropListContactOptions class=\"contact-option-wrapper drag-drop-list\" cdkDropList cdkDropListOrientation=\"vertical\"\r\n           [cdkDropListDisabled]=\"dragDropDisabled\"\r\n           [cdkDropListData]=\"collection\"\r\n           [cdkDropListEnterPredicate]=\"handleCanDragDrop\"\r\n           (cdkDropListDropped)=\"handleDrop($event)\"\r\n      >\r\n          <co-relation-contact-option class=\"draggable-contact-option\" *ngFor=\"let option of collection\" [model]=\"option\"\r\n                                      cdkDrag [cdkDragStartDelay]=\"dragStartDelay\"\r\n                                      (mousedown)=\"handleOptionMouseDown($event)\" \r\n                                      (mouseup)=\"handleOptionMouseUp($event)\"\r\n                                      (deleteClick)=\"deleteClick.emit($event)\"\r\n          ></co-relation-contact-option>\r\n      </div>\r\n  `,\r\n  providers: [\r\n    {provide: CDK_DRAG_CONFIG, useValue: DragConfig}\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class RelationContactOptionListComponent {\r\n  @Input()\r\n  public dragDropDisabled: boolean = false;\r\n\r\n  @Input()\r\n  public type: CommunicationType;\r\n\r\n  @Input()\r\n  public collection: ContactOption[] = [];\r\n\r\n  @Output()\r\n  public deleteClick: EventEmitter<ContactOption> = new EventEmitter<ContactOption>();\r\n\r\n  @HostBinding('class.co-relation-contact-option-list')\r\n  public showClass: boolean = true;\r\n\r\n  public dragStartDelay: number = 500;\r\n\r\n  private _mouseDownTimeout: any;\r\n\r\n  public handleCanDragDrop = (drag: CdkDrag, drop: CdkDropList) => {\r\n    return (drag.data.type === this.type);\r\n  }\r\n\r\n  public async handleDrop(event: CdkDragDrop<ContactOption[]>): Promise<void> {\r\n    try {\r\n      const from: number = event.previousIndex;\r\n      const to: number = event.currentIndex;\r\n      if (from === to) {\r\n        return;\r\n      }\r\n      // set items in correct order\r\n      moveItemInArray(this.collection, from, to);\r\n      this._reArrangeSequences();\r\n    } catch (e) {\r\n      console.error(e);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Hack to make sure that dragged item has the right css when not moving the mouse\r\n   * @param event\r\n   */\r\n  public handleOptionMouseDown(event: MouseEvent): void {\r\n    clearTimeout(this._mouseDownTimeout);\r\n    this._mouseDownTimeout = setTimeout(() => {\r\n      let mouseMoveEvent: Event;\r\n      if (\"createEvent\" in document) {\r\n        mouseMoveEvent = document.createEvent(\"Event\");\r\n        mouseMoveEvent.initEvent('mousemove', true, true);\r\n      } else if (\"Event\" in window) {\r\n        mouseMoveEvent = new Event('mousemove', { bubbles: true, cancelable: true });\r\n      }\r\n      // @ts-ignore\r\n      mouseMoveEvent.pageX = event.pageX;\r\n      // @ts-ignore\r\n      mouseMoveEvent.pageY = event.pageY;\r\n      document.dispatchEvent(mouseMoveEvent);\r\n    }, this.dragStartDelay);\r\n  }\r\n\r\n  public handleOptionMouseUp(event: MouseEvent): void {\r\n    clearTimeout(this._mouseDownTimeout)\r\n  }\r\n\r\n  private _reArrangeSequences(): void {\r\n    for (let i = 0; i < this.collection.length; i++) {\r\n      this.collection[i].sequence = i;\r\n    }\r\n  }\r\n}\r\n"]}
116
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relation-contact-option-list.component.js","sourceRoot":"","sources":["../../../../../../projects/relation/src/lib/component/relation-contact-options/relation-contact-option-list.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation} from '@angular/core';\r\nimport {ContactOption} from '@colijnit/relationapi/build/model/contact-option.bo';\r\nimport {CommunicationType} from '@colijnit/relationapi/build/enum/communication-type.enum';\r\nimport {CDK_DRAG_CONFIG, CdkDrag, CdkDragDrop, CdkDropList, moveItemInArray} from '@angular/cdk/drag-drop';\r\n\r\nconst DragConfig = {\r\n  dragStartThreshold: 0,\r\n  pointerDirectionChangeThreshold: 5,\r\n  zIndex: 10000\r\n};\r\n\r\n@Component({\r\n  selector: 'co-relation-contact-option-list',\r\n  template: `\r\n      <div #dropListContactOptions class=\"contact-option-wrapper drag-drop-list\" cdkDropList cdkDropListOrientation=\"horizontal\"\r\n           [cdkDropListDisabled]=\"true\"\r\n           [cdkDropListData]=\"collection\"\r\n           [cdkDropListEnterPredicate]=\"handleCanDragDrop\"\r\n           (cdkDropListDropped)=\"handleDrop($event)\"\r\n      >\r\n          <co-relation-contact-option class=\"draggable-contact-option\" *ngFor=\"let option of collection\" [model]=\"option\"\r\n                                      cdkDrag [cdkDragStartDelay]=\"dragStartDelay\"\r\n                                      (mousedown)=\"handleOptionMouseDown($event)\"\r\n                                      (mouseup)=\"handleOptionMouseUp($event)\"\r\n                                      (deleteClick)=\"deleteClick.emit($event)\"\r\n                                      (sequenceChangeUp)=\"handleSequenceUp($event)\"\r\n                                      (sequenceChangeDown)=\"handleSequenceDown($event)\"\r\n          ></co-relation-contact-option>\r\n      </div>\r\n  `,\r\n  providers: [\r\n    {provide: CDK_DRAG_CONFIG, useValue: DragConfig}\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class RelationContactOptionListComponent {\r\n  // Drag-drop doesn't work when the fields wrap (ex. flex-wrap). Hardcoded to true until fixed.\r\n  @Input()\r\n  public dragDropDisabled: boolean = false;\r\n\r\n  @Input()\r\n  public type: CommunicationType;\r\n\r\n  @Input()\r\n  public collection: ContactOption[] = [];\r\n\r\n  @Output()\r\n  public deleteClick: EventEmitter<ContactOption> = new EventEmitter<ContactOption>();\r\n\r\n  @HostBinding('class.co-relation-contact-option-list')\r\n  public showClass: boolean = true;\r\n\r\n  public dragStartDelay: number = 200;\r\n\r\n  private _mouseDownTimeout: any;\r\n\r\n  public handleCanDragDrop = (drag: CdkDrag, drop: CdkDropList) => {\r\n    return (drag.data.type === this.type);\r\n  };\r\n\r\n  public async handleDrop(event: CdkDragDrop<ContactOption[]>): Promise<void> {\r\n    try {\r\n      const from: number = event.previousIndex;\r\n      const to: number = event.currentIndex;\r\n      if (from === to) {\r\n        return;\r\n      }\r\n      // set items in correct order\r\n      moveItemInArray(this.collection, from, to);\r\n      this._reArrangeSequences();\r\n    } catch (e) {\r\n      console.error(e);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Hack to make sure that dragged item has the right css when not moving the mouse\r\n   * @param event\r\n   */\r\n  public handleOptionMouseDown(event: MouseEvent): void {\r\n    clearTimeout(this._mouseDownTimeout);\r\n    this._mouseDownTimeout = setTimeout(() => {\r\n      let mouseMoveEvent: Event;\r\n      if ('createEvent' in document) {\r\n        mouseMoveEvent = document.createEvent('Event');\r\n        mouseMoveEvent.initEvent('mousemove', true, true);\r\n      } else if ('Event' in window) {\r\n        mouseMoveEvent = new Event('mousemove', {bubbles: true, cancelable: true});\r\n      }\r\n      // @ts-ignore\r\n      mouseMoveEvent.pageX = event.pageX;\r\n      // @ts-ignore\r\n      mouseMoveEvent.pageY = event.pageY;\r\n      document.dispatchEvent(mouseMoveEvent);\r\n    }, this.dragStartDelay);\r\n  }\r\n\r\n  public handleOptionMouseUp(event: MouseEvent): void {\r\n    clearTimeout(this._mouseDownTimeout);\r\n  }\r\n\r\n  public handleSequenceUp(option: ContactOption): void {\r\n    const optionIndex = this.collection.indexOf(option);\r\n    moveItemInArray(this.collection, optionIndex, optionIndex + 1);\r\n    this._reArrangeSequences();\r\n  }\r\n\r\n  public handleSequenceDown(option: ContactOption): void {\r\n    const optionIndex = this.collection.indexOf(option);\r\n    moveItemInArray(this.collection, optionIndex, optionIndex - 1);\r\n    this._reArrangeSequences();\r\n  }\r\n\r\n  private _reArrangeSequences(): void {\r\n    for (let i = 0; i < this.collection.length; i++) {\r\n      this.collection[i].sequence = i;\r\n      this.collection[i].lowestSequence = (i === 0);\r\n      this.collection[i].highestSequence = (i === this.collection.length - 1);\r\n    }\r\n  }\r\n}\r\n"]}