@piserve-tech/form-submission 1.3.235 → 1.3.236

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.
@@ -56,10 +56,14 @@ export class FilePickerFieldsComponent {
56
56
  this.clearValidationMessageAfterTimeout();
57
57
  }
58
58
  clearValidationMessageAfterTimeout() {
59
- setTimeout(() => {
59
+ if (this.timeoutId) {
60
+ clearTimeout(this.timeoutId);
61
+ }
62
+ this.timeoutId = setTimeout(() => {
60
63
  this.validationMessage = '';
61
64
  this.validationFailed = false;
62
- }, 5000); // Timeout set to 5 seconds
65
+ this.timeoutId = null;
66
+ }, 5000);
63
67
  }
64
68
  handleFinalArray(fileType) {
65
69
  const extractedData = fileType.map((item) => ({
@@ -167,4 +171,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
167
171
  }], inlineDeleteFiles: [{
168
172
  type: Output
169
173
  }] } });
170
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-picker-fields.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/form-fields/file-picker-fields/file-picker-fields.component.ts","../../../../../projects/form-submission/src/form-fields/file-picker-fields/file-picker-fields.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { ElementTrackerService } from '../../services/element-tracker.service';\nimport { ValidationService } from '../../services/validation.service';\nimport { DataService } from '../../services/data.service';\n\nexport interface Attachment {\n  fileId: string;\n  fileName: string;\n  fileUrl: string;\n}\n\n@Component({\n  selector: 'lib-file-picker-fields',\n  templateUrl: './file-picker-fields.component.html',\n  styleUrls: ['./file-picker-fields.component.scss'],\n})\nexport class FilePickerFieldsComponent {\n  @Input() question: any = {};\n  @Input() inLine: boolean = false;\n  @Output() answerChange = new EventEmitter<{ answer: any; maxPossibleScore?: number }>();\n  @Output() inlineDeleteFiles = new EventEmitter<any>();\n\n  count: number = 0;\n  required: boolean = false;\n  hint: string = '';\n  multiFileUploads: boolean = true;\n  fileTypes: string[] = [];\n  fileSize: number = 0;\n  fileSizeUnit: string = '';\n  totalFileSize: number = 0;\n  initialFileSize: number = 0;\n  initialTotalSize: number = 0;\n  dragAndDrop: boolean = false;\n  previewUploadedFiles: boolean = true;\n  validationFailed: boolean = false;\n  validationMessage: string = '';\n  attachments: Attachment[] = [];\n\n  avatarPicker: boolean = false;\n  files: any;\n  private elementId: string='';\n  apiUrl:string = '';\n  constructor(\n      private validationService: ValidationService,\n      private tracker: ElementTrackerService,\n      private dataService: DataService\n    ) {\n      this.dataService.apiUrl$.subscribe((data) => {\n        this.apiUrl = data+'/api/cdn/preview?url=';\n      });\n    }\n\n  handleFileTypeNotAllowed(fileType: string): void {\n    this.validationFailed = true;\n    this.validationMessage = 'File type not allowed';\n    this.clearValidationMessageAfterTimeout();\n  }\n\n  handleFileSize(event: string): void {\n    this.validationFailed = true;\n    if (event === 'File size exceeds the limit') {\n      this.validationMessage = `${event} ${this.initialFileSize} ${this.fileSizeUnit}`;\n    } else if (event === 'Total size exceeds the limit') {\n      this.validationMessage = `${event} ${this.initialTotalSize} ${this.fileSizeUnit}`;\n    } else {\n      this.validationMessage = event;\n    }\n    this.clearValidationMessageAfterTimeout();\n  }\n\n  clearValidationMessageAfterTimeout(): void {\n    setTimeout(() => {\n      this.validationMessage = '';\n      this.validationFailed = false;\n    }, 5000); // Timeout set to 5 seconds\n  }\n\n  handleFinalArray(fileType: any[]): void {\n    \n    const extractedData = fileType.map((item: any) => ({\n      name: item._file.name,\n      size: item._file.size,\n      type: item._file.type,\n    }));\n\n\n    const jsonString = JSON.stringify(extractedData);\n    this.question.answer = fileType;\n    this.answerChange.emit({answer:this.question.answer,maxPossibleScore:0});\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.multiFileUploads =\n      this.question.formElement.appearance.multiFileUploads;\n    this.dragAndDrop = this.question.formElement.appearance.dragAndDrop;\n    this.previewUploadedFiles =\n      this.question.formElement.appearance.previewUploadedFiles;\n    this.fileTypes = this.question.formElement.validation.fileTypes;\n    this.fileSizeUnit = this.question.formElement.validation.fileSizeUnit;\n    this.avatarPicker = this.question.formElement.appearance.avatarPicker;\n    this.initialFileSize = this.question.formElement.validation?.fileSize;\n    this.fileSize = this.convertToBytes(\n      this.initialFileSize,\n      this.fileSizeUnit\n    );\n    this.initialTotalSize = this.question.formElement.validation?.totalFileSize;\n    this.totalFileSize = this.convertToBytes(\n      this.initialTotalSize,\n      this.fileSizeUnit\n    );\n\n    if (this.question.answer) {\n      this.files = this.question.answer;\n    }\n\n    \n    this.attachments = this.question?.attachments;\n    this.convertUrl();\n  }\n\n  convertUrl(){\n    if(this.attachments){\n      this.attachments = this.attachments.map(attachment => {\n        return {\n          ...attachment,\n          fileUrl: this.apiUrl+attachment.fileUrl.replace(/\\//g, \"%2F\")\n        };\n      });\n    }\n  }\n\n  convertToBytes(size: number, unit: string): number {\n    const units: { [key: string]: number } = {\n      B: 1,\n      KB: 1024,\n      MB: 1024 * 1024,\n      GB: 1024 * 1024 * 1024,\n    };\n    return size * (units[unit.toUpperCase()] || 1);\n  }\n\n  selectedFile!: File;\n  selectedFiles: any = [];\n\n  onFileChange(event: any) {\n    const file: File = event.target.files[0];\n    this.selectedFile = file;\n    this.selectedFiles.push(this.selectedFile);\n    this.question.answer = this.selectedFiles;\n    this.answerChange.emit({answer:this.question.answer,maxPossibleScore:0});\n  }\n  deleteFiles(event: any) {\n    this.question.deleteFiles = event;\n    this.question.attachments = this.question.attachments.filter(\n      (item: any) => {\n        return !event.includes(item.fileId);\n      }\n    );\n    this.inlineDeleteFiles.emit(this.question.deleteFiles);\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  <lib-docUpload\n    [totalSize]=\"totalFileSize\"\n    [fileAllowed]=\"fileTypes\"\n    [multiple]=\"multiFileUploads\"\n    [fileSize]=\"fileSize\"\n    [files]=\"files\"\n    [avatarPicker]=\"avatarPicker\"\n    (fileTypeNotAllowed)=\"handleFileTypeNotAllowed($event)\"\n    (fileSizeAllowed)=\"handleFileSize($event)\"\n    (finalArray)=\"handleFinalArray($event)\"\n    [attachments]=\"attachments\"\n    (deleteFiles)=\"deleteFiles($event)\"\n  ></lib-docUpload>\n\n  <div *ngIf=\"isInvalid && (!inLine || (!question.answer||!attachments))\" 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"]}
174
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-picker-fields.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/form-fields/file-picker-fields/file-picker-fields.component.ts","../../../../../projects/form-submission/src/form-fields/file-picker-fields/file-picker-fields.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { ElementTrackerService } from '../../services/element-tracker.service';\nimport { ValidationService } from '../../services/validation.service';\nimport { DataService } from '../../services/data.service';\n\nexport interface Attachment {\n  fileId: string;\n  fileName: string;\n  fileUrl: string;\n}\n\n@Component({\n  selector: 'lib-file-picker-fields',\n  templateUrl: './file-picker-fields.component.html',\n  styleUrls: ['./file-picker-fields.component.scss'],\n})\nexport class FilePickerFieldsComponent {\n  @Input() question: any = {};\n  @Input() inLine: boolean = false;\n  @Output() answerChange = new EventEmitter<{ answer: any; maxPossibleScore?: number }>();\n  @Output() inlineDeleteFiles = new EventEmitter<any>();\n\n  count: number = 0;\n  required: boolean = false;\n  hint: string = '';\n  multiFileUploads: boolean = true;\n  fileTypes: string[] = [];\n  fileSize: number = 0;\n  fileSizeUnit: string = '';\n  totalFileSize: number = 0;\n  initialFileSize: number = 0;\n  initialTotalSize: number = 0;\n  dragAndDrop: boolean = false;\n  previewUploadedFiles: boolean = true;\n  validationFailed: boolean = false;\n  validationMessage: string = '';\n  attachments: Attachment[] = [];\n  timeoutId: any;\n\n  avatarPicker: boolean = false;\n  files: any;\n  private elementId: string='';\n  apiUrl:string = '';\n  constructor(\n      private validationService: ValidationService,\n      private tracker: ElementTrackerService,\n      private dataService: DataService\n    ) {\n      this.dataService.apiUrl$.subscribe((data) => {\n        this.apiUrl = data+'/api/cdn/preview?url=';\n      });\n    }\n\n  handleFileTypeNotAllowed(fileType: string): void {\n    this.validationFailed = true;\n    this.validationMessage = 'File type not allowed';\n    this.clearValidationMessageAfterTimeout();\n  }\n\n  handleFileSize(event: string): void {\n    this.validationFailed = true;\n    if (event === 'File size exceeds the limit') {\n      this.validationMessage = `${event} ${this.initialFileSize} ${this.fileSizeUnit}`;\n    } else if (event === 'Total size exceeds the limit') {\n      this.validationMessage = `${event} ${this.initialTotalSize} ${this.fileSizeUnit}`;\n    } else {\n      this.validationMessage = event;\n    }\n    this.clearValidationMessageAfterTimeout();\n  }\n\n  clearValidationMessageAfterTimeout(): void {\n  if (this.timeoutId) {\n    clearTimeout(this.timeoutId);\n  }\n\n  this.timeoutId = setTimeout(() => {\n    this.validationMessage = '';\n    this.validationFailed = false;\n    this.timeoutId = null;\n  }, 5000);\n}\n\n  handleFinalArray(fileType: any[]): void {\n\n    const extractedData = fileType.map((item: any) => ({\n      name: item._file.name,\n      size: item._file.size,\n      type: item._file.type,\n    }));\n\n\n    const jsonString = JSON.stringify(extractedData);\n    this.question.answer = fileType;\n    this.answerChange.emit({answer:this.question.answer,maxPossibleScore:0});\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.multiFileUploads =\n      this.question.formElement.appearance.multiFileUploads;\n    this.dragAndDrop = this.question.formElement.appearance.dragAndDrop;\n    this.previewUploadedFiles =\n      this.question.formElement.appearance.previewUploadedFiles;\n    this.fileTypes = this.question.formElement.validation.fileTypes;\n    this.fileSizeUnit = this.question.formElement.validation.fileSizeUnit;\n    this.avatarPicker = this.question.formElement.appearance.avatarPicker;\n    this.initialFileSize = this.question.formElement.validation?.fileSize;\n    this.fileSize = this.convertToBytes(\n      this.initialFileSize,\n      this.fileSizeUnit\n    );\n    this.initialTotalSize = this.question.formElement.validation?.totalFileSize;\n    this.totalFileSize = this.convertToBytes(\n      this.initialTotalSize,\n      this.fileSizeUnit\n    );\n\n    if (this.question.answer) {\n      this.files = this.question.answer;\n    }\n\n\n    this.attachments = this.question?.attachments;\n    this.convertUrl();\n  }\n\n  convertUrl(){\n    if(this.attachments){\n      this.attachments = this.attachments.map(attachment => {\n        return {\n          ...attachment,\n          fileUrl: this.apiUrl+attachment.fileUrl.replace(/\\//g, \"%2F\")\n        };\n      });\n    }\n  }\n\n  convertToBytes(size: number, unit: string): number {\n    const units: { [key: string]: number } = {\n      B: 1,\n      KB: 1024,\n      MB: 1024 * 1024,\n      GB: 1024 * 1024 * 1024,\n    };\n    return size * (units[unit.toUpperCase()] || 1);\n  }\n\n  selectedFile!: File;\n  selectedFiles: any = [];\n\n  onFileChange(event: any) {\n    const file: File = event.target.files[0];\n    this.selectedFile = file;\n    this.selectedFiles.push(this.selectedFile);\n    this.question.answer = this.selectedFiles;\n    this.answerChange.emit({answer:this.question.answer,maxPossibleScore:0});\n  }\n  deleteFiles(event: any) {\n    this.question.deleteFiles = event;\n    this.question.attachments = this.question.attachments.filter(\n      (item: any) => {\n        return !event.includes(item.fileId);\n      }\n    );\n    this.inlineDeleteFiles.emit(this.question.deleteFiles);\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  <lib-docUpload\n    [totalSize]=\"totalFileSize\"\n    [fileAllowed]=\"fileTypes\"\n    [multiple]=\"multiFileUploads\"\n    [fileSize]=\"fileSize\"\n    [files]=\"files\"\n    [avatarPicker]=\"avatarPicker\"\n    (fileTypeNotAllowed)=\"handleFileTypeNotAllowed($event)\"\n    (fileSizeAllowed)=\"handleFileSize($event)\"\n    (finalArray)=\"handleFinalArray($event)\"\n    [attachments]=\"attachments\"\n    (deleteFiles)=\"deleteFiles($event)\"\n  ></lib-docUpload>\n\n  <div *ngIf=\"isInvalid && (!inLine || (!question.answer||!attachments))\" 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"]}
@@ -2547,10 +2547,14 @@ class FilePickerFieldsComponent {
2547
2547
  this.clearValidationMessageAfterTimeout();
2548
2548
  }
2549
2549
  clearValidationMessageAfterTimeout() {
2550
- setTimeout(() => {
2550
+ if (this.timeoutId) {
2551
+ clearTimeout(this.timeoutId);
2552
+ }
2553
+ this.timeoutId = setTimeout(() => {
2551
2554
  this.validationMessage = '';
2552
2555
  this.validationFailed = false;
2553
- }, 5000); // Timeout set to 5 seconds
2556
+ this.timeoutId = null;
2557
+ }, 5000);
2554
2558
  }
2555
2559
  handleFinalArray(fileType) {
2556
2560
  const extractedData = fileType.map((item) => ({