@piserve-tech/form-submission 1.3.227 → 1.3.229

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.
@@ -57,16 +57,11 @@ export class MailFieldsComponent {
57
57
  this.validationMessage = 'This is a required question';
58
58
  this.question.validation = false;
59
59
  }
60
- else if (this.expectedDomains) {
61
- const isValidEmail = this.expectedDomains?.some((domain) => enteredEmail?.endsWith(domain));
60
+ else if (this.expectedDomains && this.expectedDomains.some(d => d.trim() !== '')) {
61
+ const isValidEmail = this.expectedDomains.some((domain) => enteredEmail?.endsWith(domain));
62
62
  this.validationFailed = !isValidEmail;
63
63
  this.validationMessage = 'Please enter valid email address';
64
- if (this.validationFailed) {
65
- this.question.validation = false;
66
- }
67
- else {
68
- this.question.validation = true;
69
- }
64
+ this.question.validation = !this.validationFailed;
70
65
  }
71
66
  else {
72
67
  this.question.validation = true;
@@ -114,4 +109,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
114
109
  }], answerChange: [{
115
110
  type: Output
116
111
  }] } });
117
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mail-fields.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/form-fields/mail-fields/mail-fields.component.ts","../../../../../projects/form-submission/src/form-fields/mail-fields/mail-fields.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, Output } from '@angular/core';\nimport { ValidationService } from '../../services/validation.service';\nimport { ElementTrackerService } from '../../services/element-tracker.service';\n\n@Component({\n  selector: 'lib-mail-fields',\n  templateUrl: './mail-fields.component.html',\n  styleUrls: ['./mail-fields.component.scss'],\n})\nexport class MailFieldsComponent {\n  @Input() question: any = {};\n  @Input() inLine: boolean = false;\n  @Output() answerChange = new EventEmitter<{ answer: any; maxPossibleScore?: number }>();\n\n  count: number = 0;\n  required: boolean = false;\n  hint: string = '';\n  placeholder: string = '';\n  expectedDomains: string[] = [];\n  regularExpression: string = '';\n  email: string = '';\n  validationFailed: boolean = false;\n  validationMessage: string = '';\n  defaultValue: string = '';\n  disableEdit: boolean = false;\n  private elementId: string='';\n  constructor(\n    private validationService: ValidationService,\n    private tracker: ElementTrackerService\n  ) {\n  }\n\n\n  ngOnInit() {\n    this.valueAssigned();\n  }\n\n  valueAssigned() {\n    this.count = this.question.count;\n    this.required = this.question.required;\n    this.hint = this.question.hint;\n    this.placeholder = this.question.formElement?.appearance?.placeholder || '';\n    this.expectedDomains =\n      this.question?.formElement?.validation?.expectedDomains\n        ?.split(',')\n        .map((domain: any) => domain.trim());\n    this.regularExpression =\n    this.question.formElement.validation.regularExpression;\n    this.defaultValue = this.question?.defaultValue;\n    this.disableEdit = this.question.disableEdit;\n    this.email = this.defaultValue;\n    if(this.question.answer){\n      this.email = this.question?.answer  \n    }else if(this.defaultValue && !this.question.answer){\n      this.question.answer = this.defaultValue;\n    }\n  }\n\n  validateEmail() {\n    this.validationFailed = false;\n    this.validationMessage = '';\n    const enteredEmail = this.email?.trim().toLowerCase();\n    if (this.required && !this.email) {\n      this.validationFailed = true;\n      this.validationMessage = 'This is a required question';\n      this.question.validation = false;\n    } else if (this.expectedDomains) {\n      const isValidEmail = this.expectedDomains?.some((domain) =>\n        enteredEmail?.endsWith(domain)\n      );\n      this.validationFailed = !isValidEmail;\n      this.validationMessage = 'Please enter valid email address';\n      if (this.validationFailed) {\n        this.question.validation = false;\n      }\n      else {\n        this.question.validation = true;\n      }\n    }\n    else {\n      this.question.validation = true;\n    }\n  }\n  validateInput(event: any) {\n    this.validationService.clearInvalid(this.question.id)\n    this.question.answer = event.target.value;\n    this.answerChange.emit({answer:this.question.answer,maxPossibleScore:0});\n    this.validateEmail();\n  }\n\n  handleValidation(isValid: boolean, message: string = 'This field is required') {\n    if (isValid) {\n      this.validationService.clearInvalid(this.question.id);\n    } else {\n      // this.validationService.setInvalid(this.question.id, message);\n    }\n  }\n\n  get isInvalid(): boolean {\n    return !!this.validationService.getErrorMessage(this.question.id);\n  }\n\n  get errorMessage(): string | null {\n    return this.validationService.getErrorMessage(this.question.id);\n  }\n\n  ngAfterViewInit() {\n    this.elementId = `question-${this.question.id}`;\n    this.tracker.registerElement(this.elementId);\n  }\n\n  ngOnDestroy() {\n    if (this.elementId) {\n      this.tracker.unregisterElement(this.elementId);\n    }\n  }\n}\n","<div\n  [ngClass]=\"{ 'mb-4': !inLine }\"\n  class=\"px-3\"\n  [id]=\"'question-' + question.id\"\n  [attr.name]=\"question.testElementName\"\n>\n  <div class=\"input-wrapper mb-2\" *ngIf=\"!inLine\">\n    <div *ngIf=\"question.questionNumber\" [innerHTML]=\"question.questionNumber\"></div>\n    <span *ngIf=\"question.questionNumber\" class=\"space\"></span> <label>{{ question.question }}</label\n    >&nbsp;\n    <span class=\"text-danger\" *ngIf=\"required\">*</span>\n    <div\n      class=\"svg-wrapper mb-2 hintIcon\"\n      [attr.data-title]=\"hint\"\n      *ngIf=\"hint\"\n    >\n      <svg\n        class=\"hintSvg\"\n        viewBox=\"0 0 30 30\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n      >\n        <path\n          fill-rule=\"evenodd\"\n          clip-rule=\"evenodd\"\n          d=\"M15 26.25V26.25C8.78625 26.25 3.75 21.2138 3.75 15V15C3.75 8.78625 8.78625 3.75 15 3.75V3.75C21.2138 3.75 26.25 8.78625 26.25 15V15C26.25 21.2138 21.2138 26.25 15 26.25Z\"\n          stroke=\"#323232\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          d=\"M15 16.5623V16.2498C15 15.2285 15.6312 14.6748 16.2637 14.2498C16.8812 13.8335 17.5 13.291 17.5 12.291C17.5 10.9098 16.3813 9.79102 15 9.79102C13.6187 9.79102 12.5 10.9098 12.5 12.291\"\n          stroke=\"#323232\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          d=\"M14.9988 20C14.8263 20 14.6863 20.14 14.6875 20.3125C14.6875 20.485 14.8275 20.625 15 20.625C15.1725 20.625 15.3125 20.485 15.3125 20.3125C15.3125 20.14 15.1725 20 14.9988 20\"\n          stroke=\"#323232\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n      </svg>\n    </div>\n  </div>\n  <input\n    type=\"email\"\n    class=\"form-control mb-2 height\"\n    [placeholder]=\"placeholder\"\n    [(ngModel)]=\"email\"\n    (blur)=\"validateEmail()\"\n    (input)=\"validateInput($event)\"\n    [class.invalid]=\"validationFailed\"\n    [class.invalid-question]=\"isInvalid && (!inLine || !email)\"\n    [disabled]=\"disableEdit\"\n  />\n  <!-- <div *ngIf=\"isInvalid\" class=\"error-message\"> -->\n  <div *ngIf=\"isInvalid && (!inLine || !email)\" class=\"error-message\">\n    {{ errorMessage }}\n  </div>\n  <div *ngIf=\"validationFailed && !isInvalid\" class=\"text-danger\">\n    <svg\n      class=\"validationSvg\"\n      viewBox=\"0 0 24 24\"\n      xmlns=\"http://www.w3.org/2000/svg\"\n    >\n      <path\n        d=\"M12.001 16.75C12.139 16.75 12.251 16.638 12.25 16.5C12.25 16.362 12.138 16.25 12 16.25C11.862 16.25 11.75 16.362 11.75 16.5C11.75 16.638 11.862 16.75 12.001 16.75\"\n        stroke=\"white\"\n        stroke-width=\"1.5\"\n        stroke-linecap=\"round\"\n        stroke-linejoin=\"round\"\n      />\n      <path\n        fill-rule=\"evenodd\"\n        clip-rule=\"evenodd\"\n        d=\"M12 21C7.029 21 3 16.971 3 12C3 7.029 7.029 3 12 3C16.971 3 21 7.029 21 12C21 16.971 16.971 21 12 21Z\"\n        fill=\"#FF0000\"\n        stroke=\"#FF0000\"\n        stroke-width=\"1.5\"\n        stroke-linecap=\"round\"\n        stroke-linejoin=\"round\"\n      />\n      <path\n        d=\"M12 12.75L12 7.75\"\n        stroke=\"white\"\n        stroke-width=\"1.5\"\n        stroke-linecap=\"round\"\n        stroke-linejoin=\"round\"\n      />\n      <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\" />\n    </svg>\n    {{ validationMessage }}\n  </div>\n</div>\n"]}
112
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mail-fields.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/form-fields/mail-fields/mail-fields.component.ts","../../../../../projects/form-submission/src/form-fields/mail-fields/mail-fields.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, Output } from '@angular/core';\nimport { ValidationService } from '../../services/validation.service';\nimport { ElementTrackerService } from '../../services/element-tracker.service';\n\n@Component({\n  selector: 'lib-mail-fields',\n  templateUrl: './mail-fields.component.html',\n  styleUrls: ['./mail-fields.component.scss'],\n})\nexport class MailFieldsComponent {\n  @Input() question: any = {};\n  @Input() inLine: boolean = false;\n  @Output() answerChange = new EventEmitter<{ answer: any; maxPossibleScore?: number }>();\n\n  count: number = 0;\n  required: boolean = false;\n  hint: string = '';\n  placeholder: string = '';\n  expectedDomains: string[] = [];\n  regularExpression: string = '';\n  email: string = '';\n  validationFailed: boolean = false;\n  validationMessage: string = '';\n  defaultValue: string = '';\n  disableEdit: boolean = false;\n  private elementId: string='';\n  constructor(\n    private validationService: ValidationService,\n    private tracker: ElementTrackerService\n  ) {\n  }\n\n\n  ngOnInit() {\n    this.valueAssigned();\n  }\n\n  valueAssigned() {\n    this.count = this.question.count;\n    this.required = this.question.required;\n    this.hint = this.question.hint;\n    this.placeholder = this.question.formElement?.appearance?.placeholder || '';\n    this.expectedDomains =\n      this.question?.formElement?.validation?.expectedDomains\n        ?.split(',')\n        .map((domain: any) => domain.trim());\n    this.regularExpression =\n    this.question.formElement.validation.regularExpression;\n    this.defaultValue = this.question?.defaultValue;\n    this.disableEdit = this.question.disableEdit;\n    this.email = this.defaultValue;\n    if(this.question.answer){\n      this.email = this.question?.answer  \n    }else if(this.defaultValue && !this.question.answer){\n      this.question.answer = this.defaultValue;\n    }\n  }\n\n  validateEmail() {\n    this.validationFailed = false;\n    this.validationMessage = '';\n    const enteredEmail = this.email?.trim().toLowerCase();\n    if (this.required && !this.email) {\n      this.validationFailed = true;\n      this.validationMessage = 'This is a required question';\n      this.question.validation = false;\n    } else if (this.expectedDomains && this.expectedDomains.some(d => d.trim() !== '')) {    \n      const isValidEmail = this.expectedDomains.some((domain) =>\n        enteredEmail?.endsWith(domain)\n      );\n      this.validationFailed = !isValidEmail;\n      this.validationMessage = 'Please enter valid email address';\n      this.question.validation = !this.validationFailed;\n    }\n    else {\n      this.question.validation = true;\n    }\n  }\n  validateInput(event: any) {\n    this.validationService.clearInvalid(this.question.id)\n    this.question.answer = event.target.value;\n    this.answerChange.emit({answer:this.question.answer,maxPossibleScore:0});\n    this.validateEmail();\n  }\n\n  handleValidation(isValid: boolean, message: string = 'This field is required') {\n    if (isValid) {\n      this.validationService.clearInvalid(this.question.id);\n    } else {\n      // this.validationService.setInvalid(this.question.id, message);\n    }\n  }\n\n  get isInvalid(): boolean {\n    return !!this.validationService.getErrorMessage(this.question.id);\n  }\n\n  get errorMessage(): string | null {\n    return this.validationService.getErrorMessage(this.question.id);\n  }\n\n  ngAfterViewInit() {\n    this.elementId = `question-${this.question.id}`;\n    this.tracker.registerElement(this.elementId);\n  }\n\n  ngOnDestroy() {\n    if (this.elementId) {\n      this.tracker.unregisterElement(this.elementId);\n    }\n  }\n}\n","<div\n  [ngClass]=\"{ 'mb-4': !inLine }\"\n  class=\"px-3\"\n  [id]=\"'question-' + question.id\"\n  [attr.name]=\"question.testElementName\"\n>\n  <div class=\"input-wrapper mb-2\" *ngIf=\"!inLine\">\n    <div *ngIf=\"question.questionNumber\" [innerHTML]=\"question.questionNumber\"></div>\n    <span *ngIf=\"question.questionNumber\" class=\"space\"></span> <label>{{ question.question }}</label\n    >&nbsp;\n    <span class=\"text-danger\" *ngIf=\"required\">*</span>\n    <div\n      class=\"svg-wrapper mb-2 hintIcon\"\n      [attr.data-title]=\"hint\"\n      *ngIf=\"hint\"\n    >\n      <svg\n        class=\"hintSvg\"\n        viewBox=\"0 0 30 30\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n      >\n        <path\n          fill-rule=\"evenodd\"\n          clip-rule=\"evenodd\"\n          d=\"M15 26.25V26.25C8.78625 26.25 3.75 21.2138 3.75 15V15C3.75 8.78625 8.78625 3.75 15 3.75V3.75C21.2138 3.75 26.25 8.78625 26.25 15V15C26.25 21.2138 21.2138 26.25 15 26.25Z\"\n          stroke=\"#323232\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          d=\"M15 16.5623V16.2498C15 15.2285 15.6312 14.6748 16.2637 14.2498C16.8812 13.8335 17.5 13.291 17.5 12.291C17.5 10.9098 16.3813 9.79102 15 9.79102C13.6187 9.79102 12.5 10.9098 12.5 12.291\"\n          stroke=\"#323232\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          d=\"M14.9988 20C14.8263 20 14.6863 20.14 14.6875 20.3125C14.6875 20.485 14.8275 20.625 15 20.625C15.1725 20.625 15.3125 20.485 15.3125 20.3125C15.3125 20.14 15.1725 20 14.9988 20\"\n          stroke=\"#323232\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n      </svg>\n    </div>\n  </div>\n  <input\n    type=\"email\"\n    class=\"form-control mb-2 height\"\n    [placeholder]=\"placeholder\"\n    [(ngModel)]=\"email\"\n    (blur)=\"validateEmail()\"\n    (input)=\"validateInput($event)\"\n    [class.invalid]=\"validationFailed\"\n    [class.invalid-question]=\"isInvalid && (!inLine || !email)\"\n    [disabled]=\"disableEdit\"\n  />\n  <!-- <div *ngIf=\"isInvalid\" class=\"error-message\"> -->\n  <div *ngIf=\"isInvalid && (!inLine || !email)\" class=\"error-message\">\n    {{ errorMessage }}\n  </div>\n  <div *ngIf=\"validationFailed && !isInvalid\" class=\"text-danger\">\n    <svg\n      class=\"validationSvg\"\n      viewBox=\"0 0 24 24\"\n      xmlns=\"http://www.w3.org/2000/svg\"\n    >\n      <path\n        d=\"M12.001 16.75C12.139 16.75 12.251 16.638 12.25 16.5C12.25 16.362 12.138 16.25 12 16.25C11.862 16.25 11.75 16.362 11.75 16.5C11.75 16.638 11.862 16.75 12.001 16.75\"\n        stroke=\"white\"\n        stroke-width=\"1.5\"\n        stroke-linecap=\"round\"\n        stroke-linejoin=\"round\"\n      />\n      <path\n        fill-rule=\"evenodd\"\n        clip-rule=\"evenodd\"\n        d=\"M12 21C7.029 21 3 16.971 3 12C3 7.029 7.029 3 12 3C16.971 3 21 7.029 21 12C21 16.971 16.971 21 12 21Z\"\n        fill=\"#FF0000\"\n        stroke=\"#FF0000\"\n        stroke-width=\"1.5\"\n        stroke-linecap=\"round\"\n        stroke-linejoin=\"round\"\n      />\n      <path\n        d=\"M12 12.75L12 7.75\"\n        stroke=\"white\"\n        stroke-width=\"1.5\"\n        stroke-linecap=\"round\"\n        stroke-linejoin=\"round\"\n      />\n      <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\" />\n    </svg>\n    {{ validationMessage }}\n  </div>\n</div>\n"]}