@colijnit/relation 259.1.0 → 259.1.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -9,6 +9,7 @@ import { RelationConnectorService } from '../../service/relation-connector.servi
9
9
  import { RelationScreenConfigurationService } from '../../service/relation-screen-configuration.service';
10
10
  import { IconCacheService } from "../../service/icon-cache.service";
11
11
  import { Icon } from "../../enum/icon.enum";
12
+ import { RelationKind } from "@colijnit/relationapi/build/enum/relation-kind.enum";
12
13
  export class RelationComponent {
13
14
  constructor(relationEventService, _translationService, _settingsService, _relationConnectorService, _relationService, iconCacheService) {
14
15
  this.relationEventService = relationEventService;
@@ -30,16 +31,26 @@ export class RelationComponent {
30
31
  return true;
31
32
  }
32
33
  ngOnInit() {
33
- if (this.loadRelationFromLoginResponse && this._relationConnectorService.loginResponse) {
34
- this._relationService.relationId = this._relationConnectorService.loginResponse.relationId;
35
- }
36
- this._subs.push(this.relationEventService.relationLoaded.subscribe((relation) => __awaiter(this, void 0, void 0, function* () {
37
- if (relation && relation.relationId) {
38
- this.relation = relation;
39
- yield this.getTitleCollection();
40
- this.relationTitle = this.getTitleForRelation(this.relation);
34
+ return __awaiter(this, void 0, void 0, function* () {
35
+ if (this.loadRelationFromLoginResponse && this._relationConnectorService.loginResponse) {
36
+ if (this._relationConnectorService.loginResponse.relationKind === RelationKind.ContactPerson) {
37
+ const customer = yield this._relationService.getFirstCustomerForContact(this._relationConnectorService.loginResponse.relationId);
38
+ if (customer && (customer.relationId !== null && customer.relationId !== undefined)) {
39
+ this._relationService.relationId = customer.relationId;
40
+ }
41
+ }
42
+ else {
43
+ this._relationService.relationId = this._relationConnectorService.loginResponse.relationId;
44
+ }
41
45
  }
42
- })));
46
+ this._subs.push(this.relationEventService.relationLoaded.subscribe((relation) => __awaiter(this, void 0, void 0, function* () {
47
+ if (relation && relation.relationId) {
48
+ this.relation = relation;
49
+ yield this.getTitleCollection();
50
+ this.relationTitle = this.getTitleForRelation(this.relation);
51
+ }
52
+ })));
53
+ });
43
54
  }
44
55
  ngOnDestroy() {
45
56
  this._subs.forEach(s => s.unsubscribe());
@@ -201,4 +212,4 @@ RelationComponent.propDecorators = {
201
212
  customerPortal: [{ type: Input }],
202
213
  showClass: [{ type: HostBinding, args: ['class.co-relation',] }]
203
214
  };
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 && this._relationConnectorService.loginResponse) {\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"]}
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"]}
@@ -219,4 +219,4 @@ RelationAvatarComponent.propDecorators = {
219
219
  backgroundColor: [{ type: HostBinding, args: ["style.background-color",] }],
220
220
  onClick: [{ type: HostListener, args: ["click",] }]
221
221
  };
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":";AAAA,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,WAAW,EACX,YAAY,EACZ,KAAK,EACG,SAAS,EACjB,iBAAiB,EAClB,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAC,wBAAwB,EAAC,MAAM,0CAA0C,CAAC;AAClF,OAAO,EAAC,oBAAoB,EAAE,iBAAiB,EAAC,MAAM,8BAA8B,CAAC;AAGrF,OAAO,EAAC,SAAS,EAAC,MAAM,0CAA0C,CAAC;AACnE,OAAO,EAAC,WAAW,EAAC,MAAM,kDAAkD,CAAC;AAC7E,OAAO,EAAC,0BAA0B,EAAC,MAAM,kEAAkE,CAAC;AAC5G,OAAO,EAAC,gBAAgB,EAAC,MAAM,kCAAkC,CAAC;AAClE,OAAO,EAAC,IAAI,EAAC,MAAM,sBAAsB,CAAC;AAqB1C,MAAM,OAAO,uBAAuB;IAkFlC,YACS,gBAAkC,EACjC,yBAAmD,EACnD,qBAA2C,EAC3C,eAAkC,EAClC,cAAiC;QAJlC,qBAAgB,GAAhB,gBAAgB,CAAkB;QACjC,8BAAyB,GAAzB,yBAAyB,CAA0B;QACnD,0BAAqB,GAArB,qBAAqB,CAAsB;QAC3C,oBAAe,GAAf,eAAe,CAAmB;QAClC,mBAAc,GAAd,cAAc,CAAmB;QAtF3B,UAAK,GAAgB,IAAI,CAAC;QA4CnC,oBAAe,GAAY,KAAK,CAAC;QAGjC,sBAAiB,GAAW,CAAC,CAAC;QAG9B,kBAAa,GAAW,GAAG,CAAC;IAsCnC,CAAC;IAnFD,IACW,KAAK,CAAC,KAAiB;QAChC,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAED,IAAW,KAAK;QACd,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED,IACW,UAAU,CAAC,KAAa;QACjC,IAAI,IAAI,CAAC,UAAU,KAAK,KAAK,EAAE;YAC7B,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC;YACxB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;YAC3B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;YACzB,IAAI,CAAC,kBAAkB,EAAE,CAAC;SAC3B;IACH,CAAC;IAED,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED,IACW,QAAQ,CAAC,KAAsB;QACxC,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,KAAK,IAAI,IAAI,CAAC,SAAS,CAAC,UAAU,KAAK,KAAK,CAAC,UAAU,CAAC,EAAE;YAClG,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC;YACxB,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC;YAC7B,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;YACvB,IAAI,CAAC,kBAAkB,EAAE,CAAC;SAC3B;IACH,CAAC;IAED,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAYM,SAAS;QACd,OAAO,IAAI,CAAC;IACd,CAAC;IAQM,OAAO;QACZ,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAED,IAAW,QAAQ,CAAC,KAAa;QAC/B,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAED,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAgBD,QAAQ;QACN,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAED,WAAW;QACT,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;IACzB,CAAC;IAEM,eAAe;QACpB,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,KAAK,EAAE;YACtC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;SAClC;IACH,CAAC;IAED,+DAA+D;IACxD,iBAAiB,CAAC,KAAU;QACjC,IAAI,KAAK,IAAI,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC,KAAK,IAAI,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YAChF,MAAM,YAAY,GAAS,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAEjD,IAAI,CAAC,SAAS,CAAC,kBAAkB,CAAC,YAAY,CAAC,EAAE;gBAC/C,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,WAAW,CAAC,MAAM,CAChD,yDAAyD,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC;aACzF;iBAAM,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,YAAY,CAAC,EAAE;gBAC/C,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,wBAAwB,CAAC,CAAC;aAC3D;iBAAM;gBACL,IAAI,CAAC,iCAAiC,CAAC,YAAY,CAAC,CAAC;aACtD;YACD,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE;gBAC1C,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,KAAK,GAAG,IAAI,CAAC;aACvC;SACF;IACH,CAAC;IAEa,iCAAiC,CAAC,IAAU;;YACxD,MAAM,QAAQ,GAAe,MAAM,SAAS,CAAC,uBAAuB,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;YACrG,MAAM,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;QACxC,CAAC;KAAA;IAEa,gBAAgB,CAAC,QAAoB;;YACjD,QAAQ,CAAC,aAAa,GAAG,QAAQ,CAAC,YAAY,CAAC;YAC/C,QAAQ,CAAC,YAAY,GAAG,IAAI,IAAI,EAAE,CAAC;YACnC,QAAQ,CAAC,YAAY,GAAG,IAAI,CAAC,yBAAyB,CAAC,aAAa,CAAC,QAAQ,CAAC;YAC9E,QAAQ,CAAC,gBAAgB,GAAG,0BAA0B,CAAC,MAAM,CAAC;YAC9D,IAAI,IAAI,CAAC,SAAS,EAAE;gBAClB,IAAI,CAAC,SAAS,CAAC,WAAW,GAAG,QAAQ,CAAC;aACvC;YACD,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,sBAAsB,CAAC;YAChD,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;QACvC,CAAC;KAAA;IAEa,kBAAkB;;YAC9B,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE;gBACvC,IAAI,CAAC,CAAA,MAAM,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAA,EAAE;oBACvD,IAAI,CAAC,qBAAqB,EAAE,CAAC;iBAC9B;aACF;iBAAM;gBACL,IAAI,CAAC,qBAAqB,EAAE,CAAC;aAC9B;YACD,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;QACvC,CAAC;KAAA;IAEa,qBAAqB;;YACjC,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,IAAI,IAAI,CAAC,QAAQ,CAAC,WAAW,IAAI,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,EAAE;oBACrE,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC;oBACxC,IAAI,CAAC,CAAA,MAAM,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAA,EAAE;wBACvD,IAAI,CAAC,oBAAoB,EAAE,CAAC;qBAC7B;iBACF;qBAAM;oBACL,IAAI,CAAC,oBAAoB,EAAE,CAAC;iBAC7B;aACF;iBAAM,IAAI,IAAI,CAAC,UAAU,EAAE;gBAC1B,IAAI,CAAC,yBAAyB,CAAC,sBAAsB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,CAAO,mBAAwC,EAAE,EAAE;oBAC7H,IAAI,mBAAmB,EAAE;wBACvB,IAAI,mBAAmB,CAAC,WAAW,IAAI,mBAAmB,CAAC,WAAW,CAAC,UAAU,EAAE;4BACjF,IAAI,CAAC,MAAM,GAAG,mBAAmB,CAAC,WAAW,CAAC;4BAC9C,IAAI,CAAC,CAAA,MAAM,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAA,EAAE;gCACvD,IAAI,CAAC,oBAAoB,EAAE,CAAC;6BAC7B;yBACF;6BAAM;4BACL,IAAI,CAAC,oBAAoB,EAAE,CAAC;yBAC7B;qBACF;gBACH,CAAC,CAAA,CAAC,CAAC;aACJ;QACH,CAAC;KAAA;IAEO,oBAAoB;QAC1B,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC;SAC/C;IACH,CAAC;IAEa,gBAAgB,CAAC,KAAa;;YAC1C,MAAM,OAAO,GAAW,MAAM,IAAI,CAAC,yBAAyB,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;YACvF,IAAI,OAAO,IAAI,IAAI,CAAC,MAAM,EAAE;gBAC1B,IAAI,CAAC,MAAM,CAAC,aAAa,GAAG,OAAO,CAAC;gBACpC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,sBAAsB,CAAC;gBAClD,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;gBACrC,OAAO,IAAI,CAAC;aACb;iBAAM;gBACL,OAAO,KAAK,CAAC;aACd;QACH,CAAC;KAAA;IAEO,mBAAmB;QACzB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;QACnB,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,qBAAqB,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;SAC5F;QACD,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;IACvC,CAAC;;;YA7NF,SAAS,SAAC;gBACT,QAAQ,EAAE,oBAAoB;gBAC9B,QAAQ,EAAE;;;;;;;;;;;;;GAaT;gBACD,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACtC;;;YArBO,gBAAgB;YAPhB,wBAAwB;YACxB,oBAAoB;YAV1B,iBAAiB;YAUW,iBAAiB;;;oBA+B5C,SAAS,SAAC,cAAc;oBAGxB,KAAK;yBAUL,KAAK;uBAcL,KAAK;8BAcL,KAAK,YAAI,WAAW,SAAC,kBAAkB;gCAGvC,KAAK;4BAGL,KAAK;wBAGL,WAAW,SAAC,0BAA0B;8BAOtC,WAAW,SAAC,wBAAwB;sBAGpC,YAAY,SAAC,OAAO","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';\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"]}
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"]}
@@ -76,7 +76,7 @@ RelationContactOptionComponent.decorators = [
76
76
  [placeholder]="label | reLocalize"
77
77
  [model]="model?.value"
78
78
  [showSaveCancel]="true"
79
- [screenConfigurationObject]="screenConfigurationObject"
79
+ [screenConfigurationObject]="screenConfigObjectName"
80
80
  ></co-input-text>
81
81
  <co-icon class="relation-delete" [iconData]="iconCacheService.getIcon(icons.TrashBin)" (click)="deleteClick.emit(model)"></co-icon>
82
82
  `,
@@ -92,9 +92,9 @@ RelationContactOptionComponent.propDecorators = {
92
92
  model: [{ type: Input }],
93
93
  type: [{ type: Input }],
94
94
  shouldFocus: [{ type: Input }],
95
- screenConfigurationObject: [{ type: Input }],
95
+ screenConfigObjectName: [{ type: Input }],
96
96
  saveClick: [{ type: Output }],
97
97
  deleteClick: [{ type: Output }],
98
98
  showClass: [{ type: HostBinding, args: ['class.co-relation-contact-option',] }]
99
99
  };
100
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relation-contact-option.component.js","sourceRoot":"","sources":["../../../../../../projects/relation/src/lib/component/relation-contact-options/relation-contact-option.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewChild, ViewEncapsulation} from '@angular/core';\r\nimport {CommunicationType} from '@colijnit/relationapi/build/enum/communication-type.enum';\r\nimport {Icon} from '../../enum/icon.enum';\r\nimport {IconCacheService} from '../../service/icon-cache.service';\r\nimport {ContactOption} from '@colijnit/relationapi/build/model/contact-option.bo';\r\nimport {InputTextComponent} from '@colijnit/corecomponents_v12';\r\nimport {RelationService} from '../../service/relation.service';\r\n\r\n@Component({\r\n  selector: 'co-relation-contact-option',\r\n  template: `\r\n      <!--div class=\"relation-contact-option-sequence\" *ngIf=\"model.sequence !== null && model.sequence !== undefined\"\r\n           [textContent]=\"model.sequence\"></div-->\r\n      <co-input-text #input\r\n                     [placeholder]=\"label | reLocalize\"\r\n                     [model]=\"model?.value\"\r\n                     [showSaveCancel]=\"true\"\r\n                     [screenConfigurationObject]=\"screenConfigurationObject\"\r\n      ></co-input-text>\r\n      <co-icon class=\"relation-delete\" [iconData]=\"iconCacheService.getIcon(icons.TrashBin)\" (click)=\"deleteClick.emit(model)\"></co-icon>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class RelationContactOptionComponent implements OnInit {\r\n  public readonly icons: typeof Icon = Icon;\r\n\r\n  @ViewChild('input', { read: InputTextComponent }) set child(content) {\r\n    if (content) {\r\n      this.input = content;\r\n      this.input.commit = (value) => this.handleCommit(value);\r\n      if (this.shouldFocus) {\r\n        setTimeout(() => {\r\n          this.input.requestFocus();\r\n        })\r\n      }\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  public set model(value: ContactOption) {\r\n    this._model = value;\r\n    if (this._model) {\r\n      this.type = this._model.type;\r\n    }\r\n  }\r\n\r\n  public get model(): ContactOption {\r\n    return this._model;\r\n  }\r\n\r\n  @Input()\r\n  public set type(value: CommunicationType) {\r\n    this._type = value;\r\n    this._prepareType(this._type);\r\n  }\r\n\r\n  @Input()\r\n  public shouldFocus: boolean;\r\n\r\n  public get type(): CommunicationType {\r\n    return this._type;\r\n  }\r\n\r\n  @Input()\r\n  public screenConfigurationObject: string;\r\n\r\n  @Output()\r\n  public saveClick: EventEmitter<ContactOption> = new EventEmitter<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')\r\n  public showClass: boolean = true;\r\n\r\n  public iconType: Icon = Icon.Email;\r\n  public label: string = 'EMAIL';\r\n  public input: InputTextComponent;\r\n\r\n  private _model: ContactOption;\r\n  private _type: CommunicationType = CommunicationType.Email;\r\n\r\n  constructor(\r\n    public iconCacheService: IconCacheService,\r\n    private _relationService: RelationService\r\n  ) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    if (this.type && !this.model) {\r\n      const newOption: ContactOption = new ContactOption();\r\n      newOption.type = this.type;\r\n      this.model = newOption;\r\n    }\r\n  }\r\n\r\n  public async handleCommit(value: string): Promise<boolean> {\r\n    this.model.value = value;\r\n    this.saveClick.next(this.model);\r\n    return true;\r\n  }\r\n\r\n  private _prepareType(type: CommunicationType): void {\r\n    if (type) {\r\n      this.iconType = this._relationService.communicationTypeIcon.get(type);\r\n      this.label = this._relationService.communicationTypeLabel.get(type);\r\n    }\r\n  }\r\n}\r\n"]}
100
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relation-contact-option.component.js","sourceRoot":"","sources":["../../../../../../projects/relation/src/lib/component/relation-contact-options/relation-contact-option.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewChild, ViewEncapsulation} from '@angular/core';\r\nimport {CommunicationType} from '@colijnit/relationapi/build/enum/communication-type.enum';\r\nimport {Icon} from '../../enum/icon.enum';\r\nimport {IconCacheService} from '../../service/icon-cache.service';\r\nimport {ContactOption} from '@colijnit/relationapi/build/model/contact-option.bo';\r\nimport {InputTextComponent} from '@colijnit/corecomponents_v12';\r\nimport {RelationService} from '../../service/relation.service';\r\n\r\n@Component({\r\n  selector: 'co-relation-contact-option',\r\n  template: `\r\n      <!--div class=\"relation-contact-option-sequence\" *ngIf=\"model.sequence !== null && model.sequence !== undefined\"\r\n           [textContent]=\"model.sequence\"></div-->\r\n      <co-input-text #input\r\n                     [placeholder]=\"label | reLocalize\"\r\n                     [model]=\"model?.value\"\r\n                     [showSaveCancel]=\"true\"\r\n                     [screenConfigurationObject]=\"screenConfigObjectName\"\r\n      ></co-input-text>\r\n      <co-icon class=\"relation-delete\" [iconData]=\"iconCacheService.getIcon(icons.TrashBin)\" (click)=\"deleteClick.emit(model)\"></co-icon>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class RelationContactOptionComponent implements OnInit {\r\n  public readonly icons: typeof Icon = Icon;\r\n\r\n  @ViewChild('input', { read: InputTextComponent }) set child(content) {\r\n    if (content) {\r\n      this.input = content;\r\n      this.input.commit = (value) => this.handleCommit(value);\r\n      if (this.shouldFocus) {\r\n        setTimeout(() => {\r\n          this.input.requestFocus();\r\n        })\r\n      }\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  public set model(value: ContactOption) {\r\n    this._model = value;\r\n    if (this._model) {\r\n      this.type = this._model.type;\r\n    }\r\n  }\r\n\r\n  public get model(): ContactOption {\r\n    return this._model;\r\n  }\r\n\r\n  @Input()\r\n  public set type(value: CommunicationType) {\r\n    this._type = value;\r\n    this._prepareType(this._type);\r\n  }\r\n\r\n  @Input()\r\n  public shouldFocus: boolean;\r\n\r\n  public get type(): CommunicationType {\r\n    return this._type;\r\n  }\r\n\r\n  @Input()\r\n  public screenConfigObjectName: string;\r\n\r\n  @Output()\r\n  public saveClick: EventEmitter<ContactOption> = new EventEmitter<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')\r\n  public showClass: boolean = true;\r\n\r\n  public iconType: Icon = Icon.Email;\r\n  public label: string = 'EMAIL';\r\n  public input: InputTextComponent;\r\n\r\n  private _model: ContactOption;\r\n  private _type: CommunicationType = CommunicationType.Email;\r\n\r\n  constructor(\r\n    public iconCacheService: IconCacheService,\r\n    private _relationService: RelationService\r\n  ) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    if (this.type && !this.model) {\r\n      const newOption: ContactOption = new ContactOption();\r\n      newOption.type = this.type;\r\n      this.model = newOption;\r\n    }\r\n  }\r\n\r\n  public async handleCommit(value: string): Promise<boolean> {\r\n    this.model.value = value;\r\n    this.saveClick.next(this.model);\r\n    return true;\r\n  }\r\n\r\n  private _prepareType(type: CommunicationType): void {\r\n    if (type) {\r\n      this.iconType = this._relationService.communicationTypeIcon.get(type);\r\n      this.label = this._relationService.communicationTypeLabel.get(type);\r\n    }\r\n  }\r\n}\r\n"]}
@@ -118,7 +118,7 @@ RelationContactOptionsComponent.decorators = [
118
118
  *ngIf="showNewEmail"
119
119
  [type]="commType.Email"
120
120
  [shouldFocus]="shouldFocus"
121
- [screenConfigurationObject]="emailScreenConfigurationObject"
121
+ [screenConfigObjectName]="emailScreenConfigurationObject"
122
122
  (saveClick)="addContactOption($event)">
123
123
  </co-relation-contact-option>
124
124
  <!--div *ngIf="showAddContact" class="relation-contact-options-type-label-wrapper">
@@ -131,7 +131,7 @@ RelationContactOptionsComponent.decorators = [
131
131
  *ngIf="showNewPhone"
132
132
  [type]="commType.Telephone"
133
133
  [shouldFocus]="shouldFocus"
134
- [screenConfigurationObject]="phoneScreenConfigurationObject"
134
+ [screenConfigObjectName]="phoneScreenConfigurationObject"
135
135
  (saveClick)="addContactOption($event)">
136
136
  </co-relation-contact-option>
137
137
  <!--div *ngIf="showAddContact" class="relation-contact-options-type-label-wrapper">
@@ -178,4 +178,4 @@ RelationContactOptionsComponent.propDecorators = {
178
178
  emailScreenConfigurationObject: [{ type: Input }],
179
179
  phoneScreenConfigurationObject: [{ type: Input }]
180
180
  };
181
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relation-contact-options.component.js","sourceRoot":"","sources":["../../../../../../projects/relation/src/lib/component/relation-contact-options/relation-contact-options.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ComponentRef,\r\n  ElementRef,\r\n  HostBinding,\r\n  HostListener,\r\n  Input,\r\n  ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {RelationScreenConfigBaseComponent} from '../base/relation-screen-config-base.component';\r\nimport {RelmanCfgName} from '../../enum/relman-cfg-name.enum';\r\nimport {RelmanContactOptionsCfgNames} from '../../enum/relman-contact-options-cfg-names';\r\nimport {ContactOption} from '@colijnit/relationapi/build/model/contact-option.bo';\r\nimport {CommunicationType} from '@colijnit/relationapi/build/enum/communication-type.enum';\r\nimport {OverlayService} 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\nimport {RelationContactOptionsOtherTypesPopupComponent} from './relation-contact-options-other-types-popup.component';\r\n\r\n@Component({\r\n  selector: 'co-relation-contact-options',\r\n  template: `\r\n    <div class=\"relation-option-wrapper\">\r\n      <co-relation-contact-option-list [dragDropDisabled]=\"showNewEmail\" [collection]=\"emailContactOptions\" (deleteClick)=\"handleDeleteOption($event)\"></co-relation-contact-option-list>\r\n      <co-relation-contact-option class=\"new-contact-option\"\r\n                                  *ngIf=\"showNewEmail\"\r\n                                  [type]=\"commType.Email\"\r\n                                  [shouldFocus]=\"shouldFocus\"\r\n                                  [screenConfigurationObject]=\"emailScreenConfigurationObject\"\r\n                                  (saveClick)=\"addContactOption($event)\">\r\n      </co-relation-contact-option>\r\n      <!--div *ngIf=\"showAddContact\" class=\"relation-contact-options-type-label-wrapper\">\r\n        <div class=\"relation-contact-options-type-label\" [textContent]=\"'Toevoegen' | reLocalize\" (click)=\"showNewEmail = true\"></div>\r\n      </div-->\r\n    </div>\r\n    <div class=\"relation-option-wrapper\">\r\n      <co-relation-contact-option-list [dragDropDisabled]=\"showNewPhone\" [collection]=\"phoneContactOptions\" (deleteClick)=\"handleDeleteOption($event)\"></co-relation-contact-option-list>\r\n      <co-relation-contact-option class=\"new-contact-option\"\r\n                                  *ngIf=\"showNewPhone\"\r\n                                  [type]=\"commType.Telephone\"\r\n                                  [shouldFocus]=\"shouldFocus\"\r\n                                  [screenConfigurationObject]=\"phoneScreenConfigurationObject\"\r\n                                  (saveClick)=\"addContactOption($event)\">\r\n      </co-relation-contact-option>\r\n      <!--div *ngIf=\"showAddContact\" class=\"relation-contact-options-type-label-wrapper\">\r\n        <div class=\"relation-contact-options-type-label\" [textContent]=\"'Toevoegen' | reLocalize\" (click)=\"showNewPhone = true\"></div>\r\n      </div-->\r\n    </div>\r\n    <div class=\"relation-option-wrapper\">\r\n        <co-relation-contact-option class=\"new-contact-option\"\r\n                                    *ngIf=\"showNewOther\"\r\n                                    [type]=\"newOtherType\"\r\n                                    [shouldFocus]=\"shouldFocus\"\r\n                                (saveClick)=\"addContactOption($event)\">\r\n        </co-relation-contact-option>\r\n        <co-relation-contact-option-list [dragDropDisabled]=\"showNewOther\" [collection]=\"otherContactOptions\" (deleteClick)=\"handleDeleteOption($event)\"></co-relation-contact-option-list>\r\n    </div>\r\n    <div class=\"relation-contact-options-type-label-wrapper\" (click)=\"showNewOtherPopup()\">\r\n      <co-icon [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\" class=\"relation-contact-options-plus-icon\"\r\n               ></co-icon>\r\n      <div #overlayParent class=\"relation-contact-options-type-label\" [textContent]=\"'BUTTON_ADD_CONTACT_OPTION' | reLocalize\"></div>\r\n    </div>\r\n  `,\r\n  providers: [\r\n    OverlayService\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class RelationContactOptionsComponent extends RelationScreenConfigBaseComponent {\r\n  public readonly commType: typeof CommunicationType = CommunicationType;\r\n  public readonly generalContactOptionsCfgNames: RelmanContactOptionsCfgNames = {\r\n    contactOptionValue: RelmanCfgName.ContactOptionValue,\r\n    contactOptionType: RelmanCfgName.ContactOptionType,\r\n    contactOptionDescription: RelmanCfgName.ContactOptionDescription,\r\n    contactOptionEmailType: RelmanCfgName.ContactOptionEmailType\r\n  }\r\n\r\n  @ViewChild('overlayParent', { read: ElementRef })\r\n  public overlayParent: ElementRef;\r\n\r\n  @HostBinding('class.co-relation-contact-options')\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  @HostListener('document:keydown', ['$event'])\r\n  public handleKeyDown(event: KeyboardEvent): void {\r\n    if (event.key === 'Escape' && (this.showNewEmail || this.showNewPhone || this.showNewOther)) {\r\n      event.preventDefault();\r\n      event.stopImmediatePropagation();\r\n      event.stopPropagation();\r\n      this._resetNew();\r\n    }\r\n  }\r\n\r\n  public emailContactOptions: ContactOption[] = [];\r\n  public phoneContactOptions: ContactOption[] = [];\r\n  public otherContactOptions: ContactOption[] = [];\r\n  @HostBinding('class.adding-email-option')\r\n  public showNewEmail: boolean = true;\r\n  @HostBinding('class.adding-phone-option')\r\n  public showNewPhone: boolean = true;\r\n  @HostBinding('class.adding-other-option')\r\n  public showNewOther: boolean = false;\r\n  public newOtherType: CommunicationType;\r\n\r\n  public shouldFocus: boolean = false;\r\n\r\n  @Input()\r\n  public showAddContact: boolean = true;\r\n\r\n  @Input()\r\n  public emailScreenConfigurationObject: string;\r\n\r\n  @Input()\r\n  public phoneScreenConfigurationObject: string;\r\n\r\n  private _otherTypePopupComponentRef: ComponentRef<any>\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 _overlayService: OverlayService,\r\n    private _changeDetector: ChangeDetectorRef\r\n  ) {\r\n    super(relationService, iconCacheService, relationConnectorService, relationEventService);\r\n  }\r\n\r\n  public showNewOtherPopup(): void {\r\n    this._otherTypePopupComponentRef = this._overlayService.createComponent(RelationContactOptionsOtherTypesPopupComponent,\r\n      {\r\n        parentForOverlay: this.overlayParent\r\n      },\r\n      {\r\n        typeClick: (type: CommunicationType) => this._handleCreateOtherType(type),\r\n        clickedOutside: () => this.hideNewOtherPopup()\r\n      });\r\n  }\r\n\r\n  public hideNewOtherPopup(): void {\r\n    this._overlayService.removeComponent(this._otherTypePopupComponentRef);\r\n  }\r\n\r\n  public async addContactOption(option: ContactOption): Promise<void> {\r\n    option.relationId = this.relation.relationId;\r\n    option.sequence = this.relation.getNewContactOptionSequenceForType(option.type);\r\n    const sequence: number = await this.relationConnectorService.getNextContactOptionSequenceNumber();\r\n    option.comNr = sequence;\r\n    this.relation.addContactOption(option);\r\n    this.relationChange.next(this.relation);\r\n    this._resetNew();\r\n    this._getCollection();\r\n  }\r\n\r\n  public handleDeleteOption(option: ContactOption): void {\r\n    if (option && option.comNr) {\r\n      const idx: number = this.relation.contactOptions.findIndex(c => c.comNr === option.comNr);\r\n      if (idx > -1) {\r\n        this.relation.contactOptions.splice(idx, 1);\r\n        this.relationChange.next(this.relation);\r\n        this._resetNew();\r\n        this._getCollection();\r\n      }\r\n    }\r\n  }\r\n\r\n  protected relationSet() {\r\n    this._getCollection();\r\n  }\r\n\r\n  private _handleCreateOtherType(type: CommunicationType): void {\r\n    this.showNewOther = false;\r\n    this._changeDetector.detectChanges();\r\n    this.newOtherType = type;\r\n    this.hideNewOtherPopup();\r\n    this.showNewOther = true;\r\n    this.shouldFocus = true;\r\n  }\r\n\r\n  private _getCollection(): void {\r\n    const contactOptions: ContactOption[] = this.relation.contactOptions;\r\n    if (contactOptions) {\r\n      this.emailContactOptions = contactOptions.filter(c => c.type === CommunicationType.Email);\r\n      this.phoneContactOptions = contactOptions.filter(c => c.type === CommunicationType.Telephone);\r\n      this.otherContactOptions = contactOptions.filter(c => c.type !== CommunicationType.Email && c.type !== CommunicationType.Telephone);\r\n    }\r\n    this.showNewEmail = this.emailContactOptions.length === 0;\r\n    this.showNewPhone = this.phoneContactOptions.length === 0;\r\n    //this.showNewOther = this.otherContactOptions.length === 0;\r\n  }\r\n\r\n  private _resetNew(): void {\r\n    this.newOtherType = undefined;\r\n    this.showNewEmail = false;\r\n    this.showNewOther = false;\r\n    this.showNewPhone = false;\r\n  }\r\n}\r\n"]}
181
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relation-contact-options.component.js","sourceRoot":"","sources":["../../../../../../projects/relation/src/lib/component/relation-contact-options/relation-contact-options.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ComponentRef,\r\n  ElementRef,\r\n  HostBinding,\r\n  HostListener,\r\n  Input,\r\n  ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {RelationScreenConfigBaseComponent} from '../base/relation-screen-config-base.component';\r\nimport {RelmanCfgName} from '../../enum/relman-cfg-name.enum';\r\nimport {RelmanContactOptionsCfgNames} from '../../enum/relman-contact-options-cfg-names';\r\nimport {ContactOption} from '@colijnit/relationapi/build/model/contact-option.bo';\r\nimport {CommunicationType} from '@colijnit/relationapi/build/enum/communication-type.enum';\r\nimport {OverlayService} 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\nimport {RelationContactOptionsOtherTypesPopupComponent} from './relation-contact-options-other-types-popup.component';\r\n\r\n@Component({\r\n  selector: 'co-relation-contact-options',\r\n  template: `\r\n    <div class=\"relation-option-wrapper\">\r\n      <co-relation-contact-option-list [dragDropDisabled]=\"showNewEmail\" [collection]=\"emailContactOptions\" (deleteClick)=\"handleDeleteOption($event)\"></co-relation-contact-option-list>\r\n      <co-relation-contact-option class=\"new-contact-option\"\r\n                                  *ngIf=\"showNewEmail\"\r\n                                  [type]=\"commType.Email\"\r\n                                  [shouldFocus]=\"shouldFocus\"\r\n                                  [screenConfigObjectName]=\"emailScreenConfigurationObject\"\r\n                                  (saveClick)=\"addContactOption($event)\">\r\n      </co-relation-contact-option>\r\n      <!--div *ngIf=\"showAddContact\" class=\"relation-contact-options-type-label-wrapper\">\r\n        <div class=\"relation-contact-options-type-label\" [textContent]=\"'Toevoegen' | reLocalize\" (click)=\"showNewEmail = true\"></div>\r\n      </div-->\r\n    </div>\r\n    <div class=\"relation-option-wrapper\">\r\n      <co-relation-contact-option-list [dragDropDisabled]=\"showNewPhone\" [collection]=\"phoneContactOptions\" (deleteClick)=\"handleDeleteOption($event)\"></co-relation-contact-option-list>\r\n      <co-relation-contact-option class=\"new-contact-option\"\r\n                                  *ngIf=\"showNewPhone\"\r\n                                  [type]=\"commType.Telephone\"\r\n                                  [shouldFocus]=\"shouldFocus\"\r\n                                  [screenConfigObjectName]=\"phoneScreenConfigurationObject\"\r\n                                  (saveClick)=\"addContactOption($event)\">\r\n      </co-relation-contact-option>\r\n      <!--div *ngIf=\"showAddContact\" class=\"relation-contact-options-type-label-wrapper\">\r\n        <div class=\"relation-contact-options-type-label\" [textContent]=\"'Toevoegen' | reLocalize\" (click)=\"showNewPhone = true\"></div>\r\n      </div-->\r\n    </div>\r\n    <div class=\"relation-option-wrapper\">\r\n        <co-relation-contact-option class=\"new-contact-option\"\r\n                                    *ngIf=\"showNewOther\"\r\n                                    [type]=\"newOtherType\"\r\n                                    [shouldFocus]=\"shouldFocus\"\r\n                                (saveClick)=\"addContactOption($event)\">\r\n        </co-relation-contact-option>\r\n        <co-relation-contact-option-list [dragDropDisabled]=\"showNewOther\" [collection]=\"otherContactOptions\" (deleteClick)=\"handleDeleteOption($event)\"></co-relation-contact-option-list>\r\n    </div>\r\n    <div class=\"relation-contact-options-type-label-wrapper\" (click)=\"showNewOtherPopup()\">\r\n      <co-icon [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\" class=\"relation-contact-options-plus-icon\"\r\n               ></co-icon>\r\n      <div #overlayParent class=\"relation-contact-options-type-label\" [textContent]=\"'BUTTON_ADD_CONTACT_OPTION' | reLocalize\"></div>\r\n    </div>\r\n  `,\r\n  providers: [\r\n    OverlayService\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class RelationContactOptionsComponent extends RelationScreenConfigBaseComponent {\r\n  public readonly commType: typeof CommunicationType = CommunicationType;\r\n  public readonly generalContactOptionsCfgNames: RelmanContactOptionsCfgNames = {\r\n    contactOptionValue: RelmanCfgName.ContactOptionValue,\r\n    contactOptionType: RelmanCfgName.ContactOptionType,\r\n    contactOptionDescription: RelmanCfgName.ContactOptionDescription,\r\n    contactOptionEmailType: RelmanCfgName.ContactOptionEmailType\r\n  }\r\n\r\n  @ViewChild('overlayParent', { read: ElementRef })\r\n  public overlayParent: ElementRef;\r\n\r\n  @HostBinding('class.co-relation-contact-options')\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  @HostListener('document:keydown', ['$event'])\r\n  public handleKeyDown(event: KeyboardEvent): void {\r\n    if (event.key === 'Escape' && (this.showNewEmail || this.showNewPhone || this.showNewOther)) {\r\n      event.preventDefault();\r\n      event.stopImmediatePropagation();\r\n      event.stopPropagation();\r\n      this._resetNew();\r\n    }\r\n  }\r\n\r\n  public emailContactOptions: ContactOption[] = [];\r\n  public phoneContactOptions: ContactOption[] = [];\r\n  public otherContactOptions: ContactOption[] = [];\r\n  @HostBinding('class.adding-email-option')\r\n  public showNewEmail: boolean = true;\r\n  @HostBinding('class.adding-phone-option')\r\n  public showNewPhone: boolean = true;\r\n  @HostBinding('class.adding-other-option')\r\n  public showNewOther: boolean = false;\r\n  public newOtherType: CommunicationType;\r\n\r\n  public shouldFocus: boolean = false;\r\n\r\n  @Input()\r\n  public showAddContact: boolean = true;\r\n\r\n  @Input()\r\n  public emailScreenConfigurationObject: string;\r\n\r\n  @Input()\r\n  public phoneScreenConfigurationObject: string;\r\n\r\n  private _otherTypePopupComponentRef: ComponentRef<any>\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 _overlayService: OverlayService,\r\n    private _changeDetector: ChangeDetectorRef\r\n  ) {\r\n    super(relationService, iconCacheService, relationConnectorService, relationEventService);\r\n  }\r\n\r\n  public showNewOtherPopup(): void {\r\n    this._otherTypePopupComponentRef = this._overlayService.createComponent(RelationContactOptionsOtherTypesPopupComponent,\r\n      {\r\n        parentForOverlay: this.overlayParent\r\n      },\r\n      {\r\n        typeClick: (type: CommunicationType) => this._handleCreateOtherType(type),\r\n        clickedOutside: () => this.hideNewOtherPopup()\r\n      });\r\n  }\r\n\r\n  public hideNewOtherPopup(): void {\r\n    this._overlayService.removeComponent(this._otherTypePopupComponentRef);\r\n  }\r\n\r\n  public async addContactOption(option: ContactOption): Promise<void> {\r\n    option.relationId = this.relation.relationId;\r\n    option.sequence = this.relation.getNewContactOptionSequenceForType(option.type);\r\n    const sequence: number = await this.relationConnectorService.getNextContactOptionSequenceNumber();\r\n    option.comNr = sequence;\r\n    this.relation.addContactOption(option);\r\n    this.relationChange.next(this.relation);\r\n    this._resetNew();\r\n    this._getCollection();\r\n  }\r\n\r\n  public handleDeleteOption(option: ContactOption): void {\r\n    if (option && option.comNr) {\r\n      const idx: number = this.relation.contactOptions.findIndex(c => c.comNr === option.comNr);\r\n      if (idx > -1) {\r\n        this.relation.contactOptions.splice(idx, 1);\r\n        this.relationChange.next(this.relation);\r\n        this._resetNew();\r\n        this._getCollection();\r\n      }\r\n    }\r\n  }\r\n\r\n  protected relationSet() {\r\n    this._getCollection();\r\n  }\r\n\r\n  private _handleCreateOtherType(type: CommunicationType): void {\r\n    this.showNewOther = false;\r\n    this._changeDetector.detectChanges();\r\n    this.newOtherType = type;\r\n    this.hideNewOtherPopup();\r\n    this.showNewOther = true;\r\n    this.shouldFocus = true;\r\n  }\r\n\r\n  private _getCollection(): void {\r\n    const contactOptions: ContactOption[] = this.relation.contactOptions;\r\n    if (contactOptions) {\r\n      this.emailContactOptions = contactOptions.filter(c => c.type === CommunicationType.Email);\r\n      this.phoneContactOptions = contactOptions.filter(c => c.type === CommunicationType.Telephone);\r\n      this.otherContactOptions = contactOptions.filter(c => c.type !== CommunicationType.Email && c.type !== CommunicationType.Telephone);\r\n    }\r\n    this.showNewEmail = this.emailContactOptions.length === 0;\r\n    this.showNewPhone = this.phoneContactOptions.length === 0;\r\n    //this.showNewOther = this.otherContactOptions.length === 0;\r\n  }\r\n\r\n  private _resetNew(): void {\r\n    this.newOtherType = undefined;\r\n    this.showNewEmail = false;\r\n    this.showNewOther = false;\r\n    this.showNewPhone = false;\r\n  }\r\n}\r\n"]}
@@ -3,8 +3,8 @@ export class Version {
3
3
  constructor() {
4
4
  this.name = "@colijnit/relation";
5
5
  this.description = "Colijn IT relation package specific for version 2.5.7.";
6
- this.symVer = "259.1.0";
7
- this.publishDate = "7/9/2025, 10:01:50 AM";
6
+ this.symVer = "259.1.2";
7
+ this.publishDate = "14/08/2025, 16:22:09";
8
8
  }
9
9
  }
10
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVsYXRpb24tdmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3JlbGF0aW9uL3NyYy9saWIvcmVsYXRpb24tdmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSx1REFBdUQ7QUFDdkQsTUFBTSxPQUFPLE9BQU87SUFBcEI7UUFDUyxTQUFJLEdBQUcsb0JBQW9CLENBQUM7UUFDNUIsZ0JBQVcsR0FBRyx3REFBd0QsQ0FBQztRQUN2RSxXQUFNLEdBQUcsU0FBUyxDQUFDO1FBQ25CLGdCQUFXLEdBQUcsdUJBQXVCLENBQUM7SUFDL0MsQ0FBQztDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiLy8gdGhpcyBmaWxlIGlzIGR5bmFtaWNhbGx5IGNyZWF0ZWQsIGRvIG5vdCBjaGFuZ2UgdGhpc1xuZXhwb3J0IGNsYXNzIFZlcnNpb24ge1xuICBwdWJsaWMgbmFtZSA9IFwiQGNvbGlqbml0L3JlbGF0aW9uXCI7XG4gIHB1YmxpYyBkZXNjcmlwdGlvbiA9IFwiQ29saWpuIElUIHJlbGF0aW9uIHBhY2thZ2Ugc3BlY2lmaWMgZm9yIHZlcnNpb24gMi41LjcuXCI7XG4gIHB1YmxpYyBzeW1WZXIgPSBcIjI1OS4xLjBcIjtcbiAgcHVibGljIHB1Ymxpc2hEYXRlID0gXCI3LzkvMjAyNSwgMTA6MDE6NTAgQU1cIjtcbn0iXX0=
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVsYXRpb24tdmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3JlbGF0aW9uL3NyYy9saWIvcmVsYXRpb24tdmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSx1REFBdUQ7QUFDdkQsTUFBTSxPQUFPLE9BQU87SUFBcEI7UUFDUyxTQUFJLEdBQUcsb0JBQW9CLENBQUM7UUFDNUIsZ0JBQVcsR0FBRyx3REFBd0QsQ0FBQztRQUN2RSxXQUFNLEdBQUcsU0FBUyxDQUFDO1FBQ25CLGdCQUFXLEdBQUcsc0JBQXNCLENBQUM7SUFDOUMsQ0FBQztDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiLy8gdGhpcyBmaWxlIGlzIGR5bmFtaWNhbGx5IGNyZWF0ZWQsIGRvIG5vdCBjaGFuZ2UgdGhpc1xuZXhwb3J0IGNsYXNzIFZlcnNpb24ge1xuICBwdWJsaWMgbmFtZSA9IFwiQGNvbGlqbml0L3JlbGF0aW9uXCI7XG4gIHB1YmxpYyBkZXNjcmlwdGlvbiA9IFwiQ29saWpuIElUIHJlbGF0aW9uIHBhY2thZ2Ugc3BlY2lmaWMgZm9yIHZlcnNpb24gMi41LjcuXCI7XG4gIHB1YmxpYyBzeW1WZXIgPSBcIjI1OS4xLjJcIjtcbiAgcHVibGljIHB1Ymxpc2hEYXRlID0gXCIxNC8wOC8yMDI1LCAxNjoyMjowOVwiO1xufSJdfQ==