@colijnit/relation 255.1.1 → 255.1.21

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.
@@ -16,7 +16,6 @@ export class RelationContactOptionComponent {
16
16
  this.showClass = true;
17
17
  this.iconType = Icon.Email;
18
18
  this.label = 'EMAIL';
19
- this.shouldFocus = false;
20
19
  this._type = CommunicationType.Email;
21
20
  }
22
21
  set child(content) {
@@ -51,7 +50,6 @@ export class RelationContactOptionComponent {
51
50
  const newOption = new ContactOption();
52
51
  newOption.type = this.type;
53
52
  this.model = newOption;
54
- this.shouldFocus = true;
55
53
  }
56
54
  }
57
55
  handleCommit(value) {
@@ -72,15 +70,14 @@ RelationContactOptionComponent.decorators = [
72
70
  { type: Component, args: [{
73
71
  selector: 'co-relation-contact-option',
74
72
  template: `
75
- <div class="relation-contact-option-sequence" *ngIf="model.sequence !== null && model.sequence !== undefined"
76
- [textContent]="model.sequence"></div>
73
+ <!--div class="relation-contact-option-sequence" *ngIf="model.sequence !== null && model.sequence !== undefined"
74
+ [textContent]="model.sequence"></div-->
77
75
  <co-input-text #input
78
76
  [placeholder]="label | reLocalize"
79
- [model]="model.value"
80
- [leftIconData]="iconCacheService.getIcon(iconType)"
77
+ [model]="model?.value"
81
78
  [showSaveCancel]="true"
82
79
  ></co-input-text>
83
- <co-icon [iconData]="iconCacheService.getIcon(icons.TrashBin)" (click)="deleteClick.emit(model)"></co-icon>
80
+ <co-icon class="relation-delete" [iconData]="iconCacheService.getIcon(icons.TrashBin)" (click)="deleteClick.emit(model)"></co-icon>
84
81
  `,
85
82
  encapsulation: ViewEncapsulation.None
86
83
  },] }
@@ -93,8 +90,9 @@ RelationContactOptionComponent.propDecorators = {
93
90
  child: [{ type: ViewChild, args: ['input', { read: InputTextComponent },] }],
94
91
  model: [{ type: Input }],
95
92
  type: [{ type: Input }],
93
+ shouldFocus: [{ type: Input }],
96
94
  saveClick: [{ type: Output }],
97
95
  deleteClick: [{ type: Output }],
98
96
  showClass: [{ type: HostBinding, args: ['class.co-relation-contact-option',] }]
99
97
  };
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                     [leftIconData]=\"iconCacheService.getIcon(iconType)\"\r\n                     [showSaveCancel]=\"true\"\r\n      ></co-input-text>\r\n      <co-icon [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  public get type(): CommunicationType {\r\n    return this._type;\r\n  }\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  public shouldFocus: boolean = false;\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      this.shouldFocus = true;\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"]}
98
+ //# 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      ></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  @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"]}
@@ -1,5 +1,5 @@
1
1
  import { __awaiter } from "tslib";
2
- import { ChangeDetectorRef, Component, ElementRef, HostBinding, HostListener, ViewChild, ViewEncapsulation } from '@angular/core';
2
+ import { ChangeDetectorRef, Component, ElementRef, HostBinding, HostListener, Input, ViewChild, ViewEncapsulation } from '@angular/core';
3
3
  import { RelationScreenConfigBaseComponent } from '../base/relation-screen-config-base.component';
4
4
  import { RelmanCfgName } from '../../enum/relman-cfg-name.enum';
5
5
  import { CommunicationType } from '@colijnit/relationapi/build/enum/communication-type.enum';
@@ -28,9 +28,11 @@ export class RelationContactOptionsComponent extends RelationScreenConfigBaseCom
28
28
  this.emailContactOptions = [];
29
29
  this.phoneContactOptions = [];
30
30
  this.otherContactOptions = [];
31
- this.showNewEmail = false;
32
- this.showNewPhone = false;
31
+ this.showNewEmail = true;
32
+ this.showNewPhone = true;
33
33
  this.showNewOther = false;
34
+ this.shouldFocus = false;
35
+ this.showAddContact = true;
34
36
  }
35
37
  showClass() {
36
38
  return true;
@@ -86,6 +88,7 @@ export class RelationContactOptionsComponent extends RelationScreenConfigBaseCom
86
88
  this.newOtherType = type;
87
89
  this.hideNewOtherPopup();
88
90
  this.showNewOther = true;
91
+ this.shouldFocus = true;
89
92
  }
90
93
  _getCollection() {
91
94
  const contactOptions = this.relation.contactOptions;
@@ -94,6 +97,9 @@ export class RelationContactOptionsComponent extends RelationScreenConfigBaseCom
94
97
  this.phoneContactOptions = contactOptions.filter(c => c.type === CommunicationType.Telephone);
95
98
  this.otherContactOptions = contactOptions.filter(c => c.type !== CommunicationType.Email && c.type !== CommunicationType.Telephone);
96
99
  }
100
+ this.showNewEmail = this.emailContactOptions.length === 0;
101
+ this.showNewPhone = this.phoneContactOptions.length === 0;
102
+ //this.showNewOther = this.otherContactOptions.length === 0;
97
103
  }
98
104
  _resetNew() {
99
105
  this.newOtherType = undefined;
@@ -106,30 +112,44 @@ RelationContactOptionsComponent.decorators = [
106
112
  { type: Component, args: [{
107
113
  selector: 'co-relation-contact-options',
108
114
  template: `
109
- <div class="relation-contact-options-type-label-wrapper">
110
- <div class="relation-contact-options-type-label" [textContent]="'EMAIL' | reLocalize"></div>
111
- <co-icon [iconData]="iconCacheService.getIcon(icons.PlusSimple)" class="relation-contact-options-plus-icon"
112
- (click)="showNewEmail = true"></co-icon>
113
- </div>
114
- <co-relation-contact-option class="new-contact-option" *ngIf="showNewEmail" [type]="commType.Email"
115
- (saveClick)="addContactOption($event)"></co-relation-contact-option>
115
+ <div class="relation-option-wrapper">
116
116
  <co-relation-contact-option-list [dragDropDisabled]="showNewEmail" [collection]="emailContactOptions" (deleteClick)="handleDeleteOption($event)"></co-relation-contact-option-list>
117
- <div class="relation-contact-options-type-label-wrapper">
118
- <div class="relation-contact-options-type-label" [textContent]="'PHONE' | reLocalize"></div>
119
- <co-icon [iconData]="iconCacheService.getIcon(icons.PlusSimple)" class="relation-contact-options-plus-icon"
120
- (click)="showNewPhone = true"></co-icon>
121
- </div>
122
- <co-relation-contact-option class="new-contact-option" *ngIf="showNewPhone" [type]="commType.Telephone"
123
- (saveClick)="addContactOption($event)"></co-relation-contact-option>
117
+ <co-relation-contact-option class="new-contact-option"
118
+ *ngIf="showNewEmail"
119
+ [type]="commType.Email"
120
+ [shouldFocus]="shouldFocus"
121
+ (saveClick)="addContactOption($event)">
122
+ </co-relation-contact-option>
123
+ <!--div *ngIf="showAddContact" class="relation-contact-options-type-label-wrapper">
124
+ <div class="relation-contact-options-type-label" [textContent]="'Toevoegen' | reLocalize" (click)="showNewEmail = true"></div>
125
+ </div-->
126
+ </div>
127
+ <div class="relation-option-wrapper">
124
128
  <co-relation-contact-option-list [dragDropDisabled]="showNewPhone" [collection]="phoneContactOptions" (deleteClick)="handleDeleteOption($event)"></co-relation-contact-option-list>
125
- <div class="relation-contact-options-type-label-wrapper">
126
- <div class="relation-contact-options-type-label" [textContent]="'OTHER' | reLocalize"></div>
127
- <co-icon #overlayParent [iconData]="iconCacheService.getIcon(icons.PlusSimple)" class="relation-contact-options-plus-icon"
128
- (click)="showNewOtherPopup()"></co-icon>
129
- </div>
130
- <co-relation-contact-option class="new-contact-option" *ngIf="showNewOther" [type]="newOtherType"
131
- (saveClick)="addContactOption($event)"></co-relation-contact-option>
132
- <co-relation-contact-option-list [dragDropDisabled]="showNewOther" [collection]="otherContactOptions" (deleteClick)="handleDeleteOption($event)"></co-relation-contact-option-list>
129
+ <co-relation-contact-option class="new-contact-option"
130
+ *ngIf="showNewPhone"
131
+ [type]="commType.Telephone"
132
+ [shouldFocus]="shouldFocus"
133
+ (saveClick)="addContactOption($event)">
134
+ </co-relation-contact-option>
135
+ <!--div *ngIf="showAddContact" class="relation-contact-options-type-label-wrapper">
136
+ <div class="relation-contact-options-type-label" [textContent]="'Toevoegen' | reLocalize" (click)="showNewPhone = true"></div>
137
+ </div-->
138
+ </div>
139
+ <div class="relation-option-wrapper">
140
+ <co-relation-contact-option class="new-contact-option"
141
+ *ngIf="showNewOther"
142
+ [type]="newOtherType"
143
+ [shouldFocus]="shouldFocus"
144
+ (saveClick)="addContactOption($event)">
145
+ </co-relation-contact-option>
146
+ <co-relation-contact-option-list [dragDropDisabled]="showNewOther" [collection]="otherContactOptions" (deleteClick)="handleDeleteOption($event)"></co-relation-contact-option-list>
147
+ </div>
148
+ <div class="relation-contact-options-type-label-wrapper" (click)="showNewOtherPopup()">
149
+ <co-icon [iconData]="iconCacheService.getIcon(icons.ArrowPointRight)" class="relation-contact-options-plus-icon"
150
+ ></co-icon>
151
+ <div #overlayParent class="relation-contact-options-type-label" [textContent]="'Contactoptie toevoegen' | reLocalize"></div>
152
+ </div>
133
153
  `,
134
154
  providers: [
135
155
  OverlayService
@@ -151,6 +171,7 @@ RelationContactOptionsComponent.propDecorators = {
151
171
  handleKeyDown: [{ type: HostListener, args: ['document:keydown', ['$event'],] }],
152
172
  showNewEmail: [{ type: HostBinding, args: ['class.adding-email-option',] }],
153
173
  showNewPhone: [{ type: HostBinding, args: ['class.adding-phone-option',] }],
154
- showNewOther: [{ type: HostBinding, args: ['class.adding-other-option',] }]
174
+ showNewOther: [{ type: HostBinding, args: ['class.adding-other-option',] }],
175
+ showAddContact: [{ type: Input }]
155
176
  };
156
- //# 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-contact-options-type-label-wrapper\">\r\n          <div class=\"relation-contact-options-type-label\" [textContent]=\"'EMAIL' | reLocalize\"></div>\r\n          <co-icon [iconData]=\"iconCacheService.getIcon(icons.PlusSimple)\" class=\"relation-contact-options-plus-icon\"\r\n                   (click)=\"showNewEmail = true\"></co-icon>\r\n      </div>\r\n      <co-relation-contact-option class=\"new-contact-option\" *ngIf=\"showNewEmail\" [type]=\"commType.Email\"\r\n                                  (saveClick)=\"addContactOption($event)\"></co-relation-contact-option>\r\n      <co-relation-contact-option-list [dragDropDisabled]=\"showNewEmail\" [collection]=\"emailContactOptions\" (deleteClick)=\"handleDeleteOption($event)\"></co-relation-contact-option-list>\r\n      <div class=\"relation-contact-options-type-label-wrapper\">\r\n          <div class=\"relation-contact-options-type-label\" [textContent]=\"'PHONE' | reLocalize\"></div>\r\n          <co-icon [iconData]=\"iconCacheService.getIcon(icons.PlusSimple)\" class=\"relation-contact-options-plus-icon\"\r\n                   (click)=\"showNewPhone = true\"></co-icon>\r\n      </div>\r\n      <co-relation-contact-option class=\"new-contact-option\" *ngIf=\"showNewPhone\" [type]=\"commType.Telephone\"\r\n                                  (saveClick)=\"addContactOption($event)\"></co-relation-contact-option>\r\n      <co-relation-contact-option-list [dragDropDisabled]=\"showNewPhone\" [collection]=\"phoneContactOptions\" (deleteClick)=\"handleDeleteOption($event)\"></co-relation-contact-option-list>\r\n      <div class=\"relation-contact-options-type-label-wrapper\">\r\n          <div class=\"relation-contact-options-type-label\" [textContent]=\"'OTHER' | reLocalize\"></div>\r\n          <co-icon #overlayParent [iconData]=\"iconCacheService.getIcon(icons.PlusSimple)\" class=\"relation-contact-options-plus-icon\"\r\n                   (click)=\"showNewOtherPopup()\"></co-icon>\r\n      </div>\r\n      <co-relation-contact-option class=\"new-contact-option\" *ngIf=\"showNewOther\" [type]=\"newOtherType\"\r\n                                  (saveClick)=\"addContactOption($event)\"></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  `,\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 = false;\r\n  @HostBinding('class.adding-phone-option')\r\n  public showNewPhone: boolean = false;\r\n  @HostBinding('class.adding-other-option')\r\n  public showNewOther: boolean = false;\r\n  public newOtherType: CommunicationType;\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  }\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  }\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"]}
177
+ //# 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                                  (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                                  (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]=\"'Contactoptie toevoegen' | 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  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.4.";
6
- this.symVer = "255.1.1";
7
- this.publishDate = "7/18/2024, 3:19:04 PM";
6
+ this.symVer = "255.1.21";
7
+ this.publishDate = "18-9-2024 09:30:51";
8
8
  }
9
9
  }
10
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVsYXRpb24tdmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3JlbGF0aW9uL3NyYy9saWIvcmVsYXRpb24tdmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSx1REFBdUQ7QUFDdkQsTUFBTSxPQUFPLE9BQU87SUFBcEI7UUFDUyxTQUFJLEdBQUcsb0JBQW9CLENBQUM7UUFDNUIsZ0JBQVcsR0FBRyx3REFBd0QsQ0FBQztRQUN2RSxXQUFNLEdBQUcsU0FBUyxDQUFDO1FBQ25CLGdCQUFXLEdBQUcsdUJBQXVCLENBQUM7SUFDL0MsQ0FBQztDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiLy8gdGhpcyBmaWxlIGlzIGR5bmFtaWNhbGx5IGNyZWF0ZWQsIGRvIG5vdCBjaGFuZ2UgdGhpc1xuZXhwb3J0IGNsYXNzIFZlcnNpb24ge1xuICBwdWJsaWMgbmFtZSA9IFwiQGNvbGlqbml0L3JlbGF0aW9uXCI7XG4gIHB1YmxpYyBkZXNjcmlwdGlvbiA9IFwiQ29saWpuIElUIHJlbGF0aW9uIHBhY2thZ2Ugc3BlY2lmaWMgZm9yIHZlcnNpb24gMi41LjQuXCI7XG4gIHB1YmxpYyBzeW1WZXIgPSBcIjI1NS4xLjFcIjtcbiAgcHVibGljIHB1Ymxpc2hEYXRlID0gXCI3LzE4LzIwMjQsIDM6MTk6MDQgUE1cIjtcbn0iXX0=
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVsYXRpb24tdmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3JlbGF0aW9uL3NyYy9saWIvcmVsYXRpb24tdmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSx1REFBdUQ7QUFDdkQsTUFBTSxPQUFPLE9BQU87SUFBcEI7UUFDUyxTQUFJLEdBQUcsb0JBQW9CLENBQUM7UUFDNUIsZ0JBQVcsR0FBRyx3REFBd0QsQ0FBQztRQUN2RSxXQUFNLEdBQUcsVUFBVSxDQUFDO1FBQ3BCLGdCQUFXLEdBQUcsb0JBQW9CLENBQUM7SUFDNUMsQ0FBQztDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiLy8gdGhpcyBmaWxlIGlzIGR5bmFtaWNhbGx5IGNyZWF0ZWQsIGRvIG5vdCBjaGFuZ2UgdGhpc1xuZXhwb3J0IGNsYXNzIFZlcnNpb24ge1xuICBwdWJsaWMgbmFtZSA9IFwiQGNvbGlqbml0L3JlbGF0aW9uXCI7XG4gIHB1YmxpYyBkZXNjcmlwdGlvbiA9IFwiQ29saWpuIElUIHJlbGF0aW9uIHBhY2thZ2Ugc3BlY2lmaWMgZm9yIHZlcnNpb24gMi41LjQuXCI7XG4gIHB1YmxpYyBzeW1WZXIgPSBcIjI1NS4xLjIxXCI7XG4gIHB1YmxpYyBwdWJsaXNoRGF0ZSA9IFwiMTgtOS0yMDI0IDA5OjMwOjUxXCI7XG59Il19