@the-liberators/ngx-scrumteamsurvey-tools 2.3.7 → 2.3.9

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.
@@ -1,4 +1,4 @@
1
- import { Component, HostListener, Input, forwardRef } from '@angular/core';
1
+ import { Component, EventEmitter, HostListener, Input, Output, forwardRef } from '@angular/core';
2
2
  import { FormControl, NG_VALUE_ACCESSOR, Validators } from '@angular/forms';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "@angular/forms";
@@ -8,6 +8,7 @@ import * as i4 from "@angular/material/input";
8
8
  export class MultiEmailInputComponent {
9
9
  constructor(formBuilder) {
10
10
  this.formBuilder = formBuilder;
11
+ this.changed = new EventEmitter();
11
12
  this.onChange = () => { };
12
13
  this.onTouch = () => { };
13
14
  this.form = this.formBuilder.group({
@@ -40,16 +41,26 @@ export class MultiEmailInputComponent {
40
41
  isDisabled ? this.form.disable() : this.form.enable();
41
42
  }
42
43
  addField() {
43
- this.fields().push(this.createField());
44
- this.onChange(this.getValue());
44
+ var group = this.fields();
45
+ if (group.controls.length > 0) {
46
+ var lastField = group.controls[group.controls.length - 1];
47
+ if (!lastField.value || !lastField.value.email || !this.isValidEmail(lastField.value.email)) {
48
+ return;
49
+ }
50
+ }
51
+ var value = this.getValue();
52
+ group.push(this.createField());
53
+ this.onChange(value);
54
+ this.changed.emit(value);
45
55
  }
46
56
  removeField(index) {
47
57
  this.fields().removeAt(index);
48
- this.onChange(this.getValue());
58
+ var value = this.getValue();
59
+ this.onChange(value);
60
+ this.changed.emit(value);
49
61
  }
50
62
  fields() {
51
- var formGroup = this.form.get("emails");
52
- return formGroup;
63
+ return this.form.get("emails");
53
64
  }
54
65
  onKeyDown(event) {
55
66
  if (event.key === 'Tab' && event.target instanceof HTMLInputElement) {
@@ -69,7 +80,7 @@ export class MultiEmailInputComponent {
69
80
  return Validators.email(new FormControl(email)) === null;
70
81
  }
71
82
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: MultiEmailInputComponent, deps: [{ token: i1.FormBuilder }], target: i0.ɵɵFactoryTarget.Component }); }
72
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: MultiEmailInputComponent, selector: "multi-email-input", inputs: { label: "label", maximum: "maximum", addLabel: "addLabel", emptyLabel: "emptyLabel" }, host: { listeners: { "keydown": "onKeyDown($event)" } }, providers: [
83
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: MultiEmailInputComponent, selector: "multi-email-input", inputs: { label: "label", maximum: "maximum", addLabel: "addLabel", emptyLabel: "emptyLabel" }, outputs: { changed: "changed" }, host: { listeners: { "keydown": "onKeyDown($event)" } }, providers: [
73
84
  {
74
85
  provide: NG_VALUE_ACCESSOR,
75
86
  useExisting: forwardRef(() => MultiEmailInputComponent),
@@ -94,8 +105,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImpo
94
105
  type: Input
95
106
  }], emptyLabel: [{
96
107
  type: Input
108
+ }], changed: [{
109
+ type: Output
97
110
  }], onKeyDown: [{
98
111
  type: HostListener,
99
112
  args: ['keydown', ['$event']]
100
113
  }] } });
101
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-email-input.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-scrumteamsurvey-tools/src/lib/components/multi-email-input/multi-email-input.component.ts","../../../../../../projects/ngx-scrumteamsurvey-tools/src/lib/components/multi-email-input/multi-email-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostListener, Input, forwardRef } from '@angular/core';\nimport { ControlValueAccessor, FormArray, FormBuilder, FormControl, FormGroup, NG_VALUE_ACCESSOR, Validators } from '@angular/forms';\n\n@Component({\n   selector: 'multi-email-input',\n   templateUrl: './multi-email-input.component.html',\n   styleUrls: ['./multi-email-input.component.less'],\n   providers: [\n      {\n         provide: NG_VALUE_ACCESSOR,\n         useExisting: forwardRef(() => MultiEmailInputComponent),\n         multi: true\n      }\n   ]\n})\nexport class MultiEmailInputComponent implements ControlValueAccessor {\n   public form: FormGroup;\n   @Input() label: string;\n   @Input() maximum: number;\n   @Input() addLabel: string;\n   @Input() emptyLabel: string;\n\n   constructor(private formBuilder: FormBuilder) {\n      this.form = this.formBuilder.group({\n         emails: this.formBuilder.array([])\n      });\n   }\n\n   ngOnInit() {\n      this.form.valueChanges.subscribe(() => {\n         this.onChange(this.getValue());\n      });\n   }\n\n   onChange: any = () => { };\n   onTouch: any = () => { };\n\n   writeValue(emails: string[]): void {\n      if (emails && emails.length) {\n         var emailControls = emails.map(email => this.createField(email));\n         this.form.setControl('emails', this.formBuilder.array(emailControls));\n      }\n   }\n\n   public getValue(): string[] {\n      return this.fields().controls\n         .filter(control => control.valid && control.value.email)\n         .map(control => control.value.email);\n   }\n\n   public registerOnChange(fn: any): void {\n      this.onChange = fn;\n   }\n\n   public registerOnTouched(fn: any): void {\n      this.onTouch = fn;\n   }\n\n   public setDisabledState?(isDisabled: boolean): void {\n      isDisabled ? this.form.disable() : this.form.enable();\n   }\n\n   public addField() {\n      this.fields().push(this.createField());\n      this.onChange(this.getValue());\n   }\n\n   public removeField(index: number) {\n      this.fields().removeAt(index);\n      this.onChange(this.getValue());\n   }\n   \n   public fields(): FormArray {\n      var formGroup = this.form.get(\"emails\") as FormArray;\n      return formGroup;\n   }\n\n   @HostListener('keydown', ['$event'])\n   public onKeyDown(event: KeyboardEvent): void {\n      if (event.key === 'Tab' && event.target instanceof HTMLInputElement) {\n         const input = event.target;\n         if (input.value && this.isValidEmail(input.value)) {\n            event.preventDefault();\n            this.addField();\n         }\n      }\n   }\n   \n   private createField(email: string = null) {\n      return this.formBuilder.group({\n         email: [email, [Validators.required, Validators.email]]\n      })\n   }\n\n   private isValidEmail(email: string): boolean {\n      return Validators.email(new FormControl(email)) === null;\n   }\n}\n","<form [formGroup]=\"form\">\n   <div *ngIf=\"fields().controls.length == 0 && emptyLabel\">{{emptyLabel}}</div>\n   <ng-container formArrayName=\"emails\">\n      <div class=\"question email\" *ngFor=\"let item of fields().controls; let i = index\" [formGroupName]=\"i\">\n         <div class=\"question-body text\">\n            <mat-form-field appearance=\"fill\" subscriptSizing=\"dynamic\">\n               <mat-label>E-mail address</mat-label>\n               <input matInput formControlName=\"email\">\n            </mat-form-field>\n            <div class=\"delete\" [id]=\"'action-removeemail-' + i\" (click)=\"removeField(i)\"><span class=\"icon ph-trash-bold\"></span></div>\n         </div>\n      </div>\n   </ng-container>\n   <button id=\"action-addemail\" (click)=\"addField()\" class=\"subactionbutton\" *ngIf=\"maximum == 0 || fields().controls.length < maximum\"><span class=\"icon ph-plus-bold\"></span>{{addLabel ?? \"Add\"}}</button>\n</form>\n"]}
114
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-email-input.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-scrumteamsurvey-tools/src/lib/components/multi-email-input/multi-email-input.component.ts","../../../../../../projects/ngx-scrumteamsurvey-tools/src/lib/components/multi-email-input/multi-email-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, HostListener, Input, Output, forwardRef } from '@angular/core';\nimport { ControlValueAccessor, FormArray, FormBuilder, FormControl, FormGroup, NG_VALUE_ACCESSOR, Validators } from '@angular/forms';\n\n@Component({\n   selector: 'multi-email-input',\n   templateUrl: './multi-email-input.component.html',\n   styleUrls: ['./multi-email-input.component.less'],\n   providers: [\n      {\n         provide: NG_VALUE_ACCESSOR,\n         useExisting: forwardRef(() => MultiEmailInputComponent),\n         multi: true\n      }\n   ]\n})\nexport class MultiEmailInputComponent implements ControlValueAccessor {\n   public form: FormGroup;\n   @Input() label: string;\n   @Input() maximum: number;\n   @Input() addLabel: string;\n   @Input() emptyLabel: string;\n   @Output() changed = new EventEmitter<string[]>();\n\n   constructor(private formBuilder: FormBuilder) {\n      this.form = this.formBuilder.group({\n         emails: this.formBuilder.array([])\n      });\n   }\n\n   ngOnInit() {\n      this.form.valueChanges.subscribe(() => {\n         this.onChange(this.getValue());\n      });\n   }\n\n   onChange: any = () => { };\n   onTouch: any = () => { };\n\n   writeValue(emails: string[]): void {\n      if (emails && emails.length) {\n         var emailControls = emails.map(email => this.createField(email));\n         this.form.setControl('emails', this.formBuilder.array(emailControls));\n      }\n   }\n\n   public getValue(): string[] {\n      return this.fields().controls\n         .filter(control => control.valid && control.value.email)\n         .map(control => control.value.email);\n   }\n\n   public registerOnChange(fn: any): void {\n      this.onChange = fn;\n   }\n\n   public registerOnTouched(fn: any): void {\n      this.onTouch = fn;\n   }\n\n   public setDisabledState?(isDisabled: boolean): void {\n      isDisabled ? this.form.disable() : this.form.enable();\n   }\n\n   public addField() {\n      var group = this.fields();\n\n      if (group.controls.length > 0) {\n         var lastField = group.controls[group.controls.length - 1];\n         if (!lastField.value || !lastField.value.email || !this.isValidEmail(lastField.value.email)) { return; }\n      }\n\n      var value = this.getValue();\n      group.push(this.createField());\n      this.onChange(value);\n      this.changed.emit(value);\n   }\n\n   public removeField(index: number) {\n      this.fields().removeAt(index);\n      var value = this.getValue();\n      this.onChange(value);\n      this.changed.emit(value);\n   }\n   \n   public fields(): FormArray {\n      return this.form.get(\"emails\") as FormArray;\n   }\n\n   @HostListener('keydown', ['$event'])\n   public onKeyDown(event: KeyboardEvent): void {\n      if (event.key === 'Tab' && event.target instanceof HTMLInputElement) {\n         const input = event.target;\n         if (input.value && this.isValidEmail(input.value)) {\n            event.preventDefault();\n            this.addField();\n         }\n      }\n   }\n   \n   private createField(email: string = null) {\n      return this.formBuilder.group({\n         email: [email, [Validators.required, Validators.email]]\n      })\n   }\n\n   private isValidEmail(email: string): boolean {\n      return Validators.email(new FormControl(email)) === null;\n   }\n}\n","<form [formGroup]=\"form\">\n   <div *ngIf=\"fields().controls.length == 0 && emptyLabel\">{{emptyLabel}}</div>\n   <ng-container formArrayName=\"emails\">\n      <div class=\"question email\" *ngFor=\"let item of fields().controls; let i = index\" [formGroupName]=\"i\">\n         <div class=\"question-body text\">\n            <mat-form-field appearance=\"fill\" subscriptSizing=\"dynamic\">\n               <mat-label>E-mail address</mat-label>\n               <input matInput formControlName=\"email\">\n            </mat-form-field>\n            <div class=\"delete\" [id]=\"'action-removeemail-' + i\" (click)=\"removeField(i)\"><span class=\"icon ph-trash-bold\"></span></div>\n         </div>\n      </div>\n   </ng-container>\n   <button id=\"action-addemail\" (click)=\"addField()\" class=\"subactionbutton\" *ngIf=\"maximum == 0 || fields().controls.length < maximum\"><span class=\"icon ph-plus-bold\"></span>{{addLabel ?? \"Add\"}}</button>\n</form>\n"]}
@@ -3676,6 +3676,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImpo
3676
3676
  class MultiEmailInputComponent {
3677
3677
  constructor(formBuilder) {
3678
3678
  this.formBuilder = formBuilder;
3679
+ this.changed = new EventEmitter();
3679
3680
  this.onChange = () => { };
3680
3681
  this.onTouch = () => { };
3681
3682
  this.form = this.formBuilder.group({
@@ -3708,16 +3709,26 @@ class MultiEmailInputComponent {
3708
3709
  isDisabled ? this.form.disable() : this.form.enable();
3709
3710
  }
3710
3711
  addField() {
3711
- this.fields().push(this.createField());
3712
- this.onChange(this.getValue());
3712
+ var group = this.fields();
3713
+ if (group.controls.length > 0) {
3714
+ var lastField = group.controls[group.controls.length - 1];
3715
+ if (!lastField.value || !lastField.value.email || !this.isValidEmail(lastField.value.email)) {
3716
+ return;
3717
+ }
3718
+ }
3719
+ var value = this.getValue();
3720
+ group.push(this.createField());
3721
+ this.onChange(value);
3722
+ this.changed.emit(value);
3713
3723
  }
3714
3724
  removeField(index) {
3715
3725
  this.fields().removeAt(index);
3716
- this.onChange(this.getValue());
3726
+ var value = this.getValue();
3727
+ this.onChange(value);
3728
+ this.changed.emit(value);
3717
3729
  }
3718
3730
  fields() {
3719
- var formGroup = this.form.get("emails");
3720
- return formGroup;
3731
+ return this.form.get("emails");
3721
3732
  }
3722
3733
  onKeyDown(event) {
3723
3734
  if (event.key === 'Tab' && event.target instanceof HTMLInputElement) {
@@ -3737,7 +3748,7 @@ class MultiEmailInputComponent {
3737
3748
  return Validators.email(new FormControl(email)) === null;
3738
3749
  }
3739
3750
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: MultiEmailInputComponent, deps: [{ token: i4$1.FormBuilder }], target: i0.ɵɵFactoryTarget.Component }); }
3740
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: MultiEmailInputComponent, selector: "multi-email-input", inputs: { label: "label", maximum: "maximum", addLabel: "addLabel", emptyLabel: "emptyLabel" }, host: { listeners: { "keydown": "onKeyDown($event)" } }, providers: [
3751
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: MultiEmailInputComponent, selector: "multi-email-input", inputs: { label: "label", maximum: "maximum", addLabel: "addLabel", emptyLabel: "emptyLabel" }, outputs: { changed: "changed" }, host: { listeners: { "keydown": "onKeyDown($event)" } }, providers: [
3741
3752
  {
3742
3753
  provide: NG_VALUE_ACCESSOR,
3743
3754
  useExisting: forwardRef(() => MultiEmailInputComponent),
@@ -3762,6 +3773,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImpo
3762
3773
  type: Input
3763
3774
  }], emptyLabel: [{
3764
3775
  type: Input
3776
+ }], changed: [{
3777
+ type: Output
3765
3778
  }], onKeyDown: [{
3766
3779
  type: HostListener,
3767
3780
  args: ['keydown', ['$event']]