@piserve-tech/form-submission 1.3.243 → 1.3.245

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.
Files changed (35) hide show
  1. package/esm2022/form-fields/check-box-fields/check-box-fields.component.mjs +4 -1
  2. package/esm2022/form-fields/currency-fields/currency-fields.component.mjs +261 -0
  3. package/esm2022/form-fields/date-time-fields/date-time-fields.component.mjs +6 -1
  4. package/esm2022/form-fields/drop-down-fields/drop-down-fields.component.mjs +3 -1
  5. package/esm2022/form-fields/form-fields.module.mjs +10 -5
  6. package/esm2022/form-fields/mail-fields/mail-fields.component.mjs +3 -1
  7. package/esm2022/form-fields/number-fields/number-fields.component.mjs +6 -1
  8. package/esm2022/form-fields/password-fields/password-fields.component.mjs +9 -1
  9. package/esm2022/form-fields/radio-button-fields/radio-button-fields.component.mjs +2 -1
  10. package/esm2022/form-fields/rich-text-editor-fields/rich-text-editor-fields.component.mjs +2 -1
  11. package/esm2022/form-fields/selection-matrix-fields/selection-matrix-fields.component.mjs +3 -1
  12. package/esm2022/form-fields/text-area-fields/text-area-fields.component.mjs +2 -1
  13. package/esm2022/form-fields/text-fields/text-fields.component.mjs +2 -1
  14. package/esm2022/form-fields/url-fields/url-fields.component.mjs +2 -1
  15. package/esm2022/form-submission/navigation-tabs/navigation-tabs.component.mjs +12 -3
  16. package/esm2022/form-submission/next-prev-navigation/next-prev-navigation.component.mjs +12 -3
  17. package/esm2022/form-submission/submit-form/submit-form.component.mjs +47 -11
  18. package/esm2022/models/appearance.model.mjs +1 -1
  19. package/esm2022/question/card-subform/card-subform.component.mjs +4 -3
  20. package/esm2022/question/inline-multiple-subform/inline-multiple-subform.component.mjs +5 -4
  21. package/esm2022/question/multifields/multifields.component.mjs +4 -3
  22. package/esm2022/question/question/question.component.mjs +4 -3
  23. package/esm2022/question/question-group/question-group.component.mjs +4 -3
  24. package/esm2022/question/sub-form/sub-form.component.mjs +9 -8
  25. package/esm2022/services/mapper.service.mjs +6 -2
  26. package/esm2022/sub-form/submission-modal/submission-modal.component.mjs +4 -3
  27. package/fesm2022/piserve-tech-form-submission.mjs +381 -33
  28. package/fesm2022/piserve-tech-form-submission.mjs.map +1 -1
  29. package/form-fields/currency-fields/currency-fields.component.d.ts +52 -0
  30. package/form-fields/form-fields.module.d.ts +12 -11
  31. package/form-submission/navigation-tabs/navigation-tabs.component.d.ts +4 -1
  32. package/form-submission/next-prev-navigation/next-prev-navigation.component.d.ts +4 -1
  33. package/form-submission/submit-form/submit-form.component.d.ts +3 -0
  34. package/models/appearance.model.d.ts +4 -0
  35. package/package.json +1 -1
@@ -314,6 +314,7 @@ export class CheckBoxFieldsComponent {
314
314
  this.validationService.clearInvalid(this.buildElementId());
315
315
  this.validationFailed = true;
316
316
  this.validationMessage = 'This is a required question';
317
+ this.question.validationMessage = 'This is a required question';
317
318
  this.question.validation = false;
318
319
  }
319
320
  else if (this.minimumSelection !== undefined) {
@@ -322,6 +323,7 @@ export class CheckBoxFieldsComponent {
322
323
  if (this.selectedOptions.length < this.minimumSelection && this.required) {
323
324
  this.validationFailed = true;
324
325
  this.validationMessage = `Minimum ${this.minimumSelection} selection(s) required.`;
326
+ this.question.validationMessage = `Minimum ${this.minimumSelection} selection(s) required.`;
325
327
  this.question.validation = false;
326
328
  }
327
329
  else {
@@ -334,6 +336,7 @@ export class CheckBoxFieldsComponent {
334
336
  this.validationService.clearInvalid(this.buildElementId());
335
337
  this.validationFailed = true;
336
338
  this.validationMessage = `Minimum ${this.minimumSelection} selection(s) required.`;
339
+ this.question.validationMessage = `Minimum ${this.minimumSelection} selection(s) required.`;
337
340
  this.question.validation = false;
338
341
  }
339
342
  else {
@@ -416,4 +419,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
416
419
  }], answerChange: [{
417
420
  type: Output
418
421
  }] } });
419
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"check-box-fields.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/form-fields/check-box-fields/check-box-fields.component.ts","../../../../../projects/form-submission/src/form-fields/check-box-fields/check-box-fields.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { FormService } from '../../services/form.service';\nimport { ElementTrackerService } from '../../services/element-tracker.service';\nimport { ValidationService } from '../../services/validation.service';\nimport { ScoreCalculationService } from '../../services/score.service';\n\n@Component({\n  selector: 'lib-check-box-fields',\n  templateUrl: './check-box-fields.component.html',\n  styleUrls: ['./check-box-fields.component.scss'],\n})\nexport class CheckBoxFieldsComponent {\n  @Input() question: any = {};\n  @Input() inLine: boolean = false;\n  @Input() inCard: boolean = false;\n  @Input() submissionIndex!: number;\n  @Output() answerChange = new EventEmitter<{ answer: any; maxPossibleScore?: number }>();\n\n  count: number = 0;\n  required: boolean = false;\n  hint: string = '';\n  selectionType: string = '';\n  minimumSelection?: number;\n  maximumSelection?: number;\n  optionType: string = '';\n  lookupTable: any = {};\n  customOptions: any[] = [];\n  database: any = {};\n  api: any = {};\n  apiOptions: any[] = []; \n  selectedOptions: any[] = [];\n  validationFailed: boolean = false;\n  displayOptionsInColumn: boolean = false;\n  validationMessage: string = '';\n  private elementId: string='';\n  maxPossibleScore?:number;\n\n  constructor(\n    private formService: FormService,\n    private validationService: ValidationService,\n    private tracker: ElementTrackerService,\n    private scoreCalcService: ScoreCalculationService\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.selectionType = this.question.formElement.appearance.selectionType;\n    this.displayOptionsInColumn =\n      this.question.formElement.appearance.displayOptionsInColumn ?? false;\n    this.minimumSelection =\n      this.question.formElement.validation.minimumSelection;\n    this.maximumSelection =\n      this.question.formElement.validation.maximumSelection;\n    this.optionType = this.question.formElement.option.optionType;\n    switch (this.optionType) {\n      case 'OPTION':\n        this.customOptions = this.question.formElement.option.customOptions;\n         this.customOptions = this.question.formElement.option.customOptions.map((option:any) => ({\n          value: option.value,\n          label: option.value\n        }));\n        if (this.question.answer) {\n          this.initializeCustomOption();\n        }\n        break;\n      case 'LOOKUP':\n        this.lookupTable = this.question.formElement.option.lookupTable;\n        this.fetchDataFromLookup();\n        break;\n      case 'DATABASE':\n        this.database = this.question.formElement.option.database;\n        this.fetchDataFromDatabase();\n        break;\n      case 'API':\n        this.api = this.question.formElement.option.api;\n        this.fetchDataFromAPI();\n        break;\n      default:\n        console.warn('Unknown option type:', this.optionType);\n    }\n\n    if (this.selectionType === 'SINGLE') {\n      this.minimumSelection = 1;\n      this.maximumSelection = 1;\n    }\n\n    if (\n      this.selectionType === 'MULTIPLE' &&\n      !this.minimumSelection &&\n      !this.maximumSelection\n    ) {\n      this.minimumSelection = undefined;\n      this.maximumSelection = undefined;\n    }\n    if(this.question.formElement.scoring && this.question.formElement.scoring.enableScoring\n    ){\n      this.maxPossibleScore = this.scoreCalcService.getMaxPossibleScoreForQuestion(this.question);\n      this.question.maxPossibleScore = this.maxPossibleScore;\n    }\n  }\n\n  initializeCustomOption() {\n    this.selectedOptions = [];\n    this.customOptions?.forEach((option: any) => {\n      if (this.question?.answer?.find((a: any) => {\n        if (typeof a === 'string' && a.includes('|')) {\n          const parts = a.split('|');\n          return parts[1] === option.value.toString();\n        }\n        return a.toString() === option.value.toString();\n      })) {        \n        this.selectedOptions.push(option);\n      }      \n    });\n    if(this.question.childLogics && this.question.answer){\n      this.updateChildLogics(this.question)\n    }\n  }\n\n  onCheckboxChange(option: any, event: any) {\n    if (this.selectionType === 'SINGLE') {\n      if (event.target.checked) {\n        this.selectedOptions = [option];\n        this.question.answer = [`${option.label}|${option.value}`];\n      } else {\n        this.selectedOptions = [];\n        this.question.answer = [];\n      }\n      this.isMinimumSelectionValid();\n    } else if (this.selectionType === 'MULTIPLE') {\n      if (event.target.checked) {\n        if (!this.selectedOptions.includes(option)) {\n          this.selectedOptions.push(option);\n        }\n      } else {\n        this.selectedOptions = this.selectedOptions.filter(\n          (item) => item !== option\n        );\n      }\n      this.question.answer = this.selectedOptions.map(item => `${item.label}|${item.value}`);\n      this.isMinimumSelectionValid();\n    }\n  \n    if (\n      this.maximumSelection !== undefined &&\n      this.selectedOptions.length > this.maximumSelection\n    ) {\n      event.target.checked = false;\n      this.selectedOptions = this.selectedOptions.filter(\n        (item) => item !== option\n      );\n      this.question.answer = this.selectedOptions.map(item => `${item.label}|${item.value}`);\n      this.isMinimumSelectionValid();\n    }\n  \n    if (this.question.childLogics) {\n      this.updateChildLogics(this.question);\n    }\n    const scoreResult = this.scoreCalcService.calculateScoreFromAnswer(this.question.answer, this.question);\n    this.question.score = scoreResult?.scores;\n    this.answerChange.emit({answer:this.question.answer,maxPossibleScore:this.maxPossibleScore});\n  }\n\n  updateChildLogics(question: any) {    \n    if (question.childLogics && Array.isArray(question.childLogics)) {\n      question.childLogics.forEach((childLogic: any) => {\n        if (this.selectionType === 'SINGLE') {\n          if (this.selectedOptions.length === 0) {\n            childLogic.showLogic = false;\n            this.clearAnswersRecursively(childLogic);\n          } else { \n            if(this.evaluateCondition(this.selectedOptions[0]?.label, childLogic.condition, childLogic.inputValue)){\n              childLogic.showLogic = true;\n            }else{\n              childLogic.showLogic = false;\n              this.clearAnswersRecursively(childLogic);\n            }           \n          }\n        } else if (this.selectionType === 'MULTIPLE') {\n          if (this.selectedOptions.length === 0) {\n            childLogic.showLogic = false;\n            this.clearAnswersRecursively(childLogic);\n          } else {\n            const selectedLabels = this.selectedOptions.map((item: any) => item.label);\n            if(this.evaluateMultipleCondition(selectedLabels, childLogic.condition, childLogic.inputValue)){\n              childLogic.showLogic = true;\n            }else{\n              childLogic.showLogic = false;\n              this.clearAnswersRecursively(childLogic);\n            }\n          }\n        }\n      });\n    }\n  }\n\n  clearAnswersRecursively(logic: any) {\n    if (!logic || !logic.rows) return;\n  \n    logic.rows.forEach((row: any) => {\n      row.grid.forEach((item: any) => {\n        const element = item.element;\n  \n        if (item.entityType === 'QUESTION' && element) {\n          // Clear answer if present\n          if ('answer' in element) {\n            element.answer = '';\n          }\n  \n          // Recursively clear childLogics if any\n          if (element.childLogics && element.childLogics.length > 0) {\n            element.childLogics.forEach((childLogic: any) => {\n              this.clearAnswersRecursively(childLogic);\n            });\n          }\n        }\n  \n        if (item.entityType === 'SUBFORM' && element && element.rows) {\n          // SUBFORM contains its own rows structure like a form\n          this.clearAnswersRecursively({ rows: element.rows });\n        }\n      });\n    });\n  }\n  \n  \n  evaluateCondition(answer: any, condition: string, inputValue: any): boolean {    \n    const inputValues = Array.isArray(inputValue)\n      ? inputValue.map(val => val.toString())\n      : [inputValue.toString()];\n  \n    switch (condition) {\n      case \"!=\":\n        return !inputValues.includes(answer);\n      case \"=\":\n        return inputValues.includes(answer);\n      case \"IN\":\n        return inputValues.includes(answer);\n      case \"NOT IN\":\n        return !inputValues.includes(answer);\n      default:\n        return false;\n    }\n  }\n  \n  evaluateMultipleCondition(answers: any[], condition: string, inputValue: any): boolean {\n    const inputValues = Array.isArray(inputValue)\n      ? inputValue.map(val => val.toString())\n      : [inputValue.toString()];\n  \n    switch (condition) {\n      case \"!=\":\n        return answers.every(answer => !inputValues.includes(answer));\n      case \"=\":\n        return answers.some(answer => inputValues.includes(answer));\n      case \"IN\":\n        return answers.some(answer => inputValues.includes(answer));\n      case \"NOT IN\":\n        return answers.every(answer => !inputValues.includes(answer));\n      default:\n        return false;\n    }\n  }\n\n  fetchDataFromLookup() {\n    this.formService.fetchDataFromLookup(this.lookupTable).subscribe(\n      (response) => {\n        this.customOptions = response.result.values.map(\n          (item: { value: string; label: string }) => ({\n            value: item.value,\n            label: item.label,\n          })\n        );\n        if (this.question.answer) {\n          this.initializeCustomOption();\n        }\n      },\n      (error) => {\n        console.error('HTTP Error:', error);\n      }\n    );\n  }\n\n  fetchDataFromDatabase() {\n    const transformedDatabase = this.transformDatabaseObject(this.database);\n    this.formService.fetchDataFromDatabase(transformedDatabase).subscribe(\n      (response) => {\n        if (response.success) {\n          this.customOptions = response.result.map(\n            (item: { value: string; label: string }) => ({\n              value: item.value,\n              label: item.label,\n            })\n          );\n          if (this.question.answer) {\n            this.initializeCustomOption();\n          }\n        } else {\n          console.error('Error fetching data from database:', response.message);\n        }\n      },\n      (error) => {\n        console.error('HTTP Error:', error);\n      }\n    );\n  }\n\n  transformDatabaseObject(database: any) {\n    return {\n      tableName: database.tableName,\n      valueField: database.valueField,\n      labelField: database.labelField,\n      criteria: database.criteria.map((criteria: any) => ({\n        field: criteria?.field,\n        valueSource:criteria?.valueSource,\n        condition: criteria?.condition,\n        value: criteria?.inputValue,\n        logicalOperator: criteria?.logicalOperator,\n      })),\n    };\n  }\n\n  fetchDataFromAPI() {\n    const apiConfig = this.api;\n    this.formService.fetchDataFromExternalAPI(apiConfig).subscribe(\n      (response) => {\n        let data;\n        if(apiConfig.pathToValue) {\n          data = this.extractDataByPath(response, apiConfig.pathToValue);\n        } else {\n          data = response;\n        }\n        \n        this.customOptions = data.map((item: any) => ({\n          value: item[apiConfig.valueField],\n          label: item[apiConfig.labelField],\n        }));        \n        if (this.question.answer) {\n          \n          this.initializeCustomOption();\n          \n        }\n      },\n      (error) => {\n        console.error('HTTP Error:', error);\n      }\n    );\n  }\n\n  extractDataByPath(data: any, path: string) {\n    return path.split('.').reduce((acc, part) => acc && acc[part], data);\n  }\n\n  isMinimumSelectionValid() {\n    this.validationFailed = false;\n    \n    if (this.selectedOptions.length == 0 && this.required) {\n      this.validationService.clearInvalid(this.buildElementId());\n      this.validationFailed = true;\n      this.validationMessage = 'This is a required question';\n      this.question.validation = false;\n    } else if (this.minimumSelection !== undefined) {\n      if(this.selectionType=='SINGLE'){\n        this.validationService.clearInvalid(this.buildElementId());\n        if (this.selectedOptions.length < this.minimumSelection && this.required) {\n          this.validationFailed = true;\n          this.validationMessage = `Minimum ${this.minimumSelection}  selection(s) required.`;\n          this.question.validation = false;\n        }\n        else {\n          this.validationService.clearInvalid(this.buildElementId());\n          this.question.validation = true;\n        }\n      }\n      else{\n        if (this.selectedOptions.length < this.minimumSelection) {\n          this.validationService.clearInvalid(this.buildElementId());\n          this.validationFailed = true;\n          this.validationMessage = `Minimum ${this.minimumSelection}  selection(s) required.`;\n          this.question.validation = false;\n        }\n        else {\n          this.validationService.clearInvalid(this.buildElementId());\n          this.question.validation = true;\n        }\n      }\n    } else {\n      this.validationService.clearInvalid(this.buildElementId());\n      this.question.validation = true;\n    }\n  }\n\n  getOptions() {\n    if (this.optionType === 'OPTION') {\n      return this.customOptions;\n    } else if (this.optionType === 'LOOKUP') {\n      return Object.values(this.lookupTable);\n    } else if (this.optionType === 'API') {\n      return this.apiOptions.map((option) => option.valueField);\n    } else {\n      return [];\n    }\n  }\n\n  isOptionDisabled(option: any): boolean {\n    return (\n      this.maximumSelection !== undefined &&\n      this.selectedOptions.length >= this.maximumSelection &&\n      !this.selectedOptions.includes(option)\n    );\n  }\n\n  \n  handleValidation(isValid: boolean, message: string = 'This field is required') {\n    if (isValid) {\n      this.validationService.clearInvalid(this.buildElementId());\n    } else {\n      // this.validationService.setInvalid(this.question.id, message);\n    }\n  }\n\n  private buildElementId(): string {\n    return (this.inLine || this.inCard)\n      ? `${this.submissionIndex}-${this.question.id}`\n      : `${this.question.id}`;\n  }\n\n  get isInvalid(): boolean {\n    return !!this.validationService.getErrorMessage(this.buildElementId());\n  }\n\n  get errorMessage(): string | null {\n    return this.validationService.getErrorMessage(this.buildElementId());\n  }\n\n  ngAfterViewInit() {\n    if (this.inLine || this.inCard) {\n      this.elementId = `question-${this.submissionIndex}-${this.question.id}`;\n    } else {\n      this.elementId = `question-${this.question.id}`;\n    }\n  \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]=\"(inLine || inCard) ? 'question-' + submissionIndex + '-' + question.id : 'question-' + question.id\"\n  [attr.name]=\"question.testElementName\"\n>\n  <div class=\"input-wrapper mb-3\" *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  <div\n    class=\"checkboxField-container\"\n    [class.two-column]=\"displayOptionsInColumn\"\n  >\n    <div class=\"form-check\" *ngFor=\"let option of customOptions\">\n      <input\n        class=\"form-check-input\"\n        type=\"checkbox\"\n        [id]=\"option.value + question?.id\"\n        [name]=\"option.value + 'Checkbox'\"\n        [value]=\"option.value\"\n        (change)=\"onCheckboxChange(option, $event)\"\n        [disabled]=\"isOptionDisabled(option)\"\n        [checked]=\"selectedOptions.includes(option)\"\n        [attr.data-value]=\"selectedOptions.includes(option)\"\n      />\n      <label\n        class=\"formCheckLabel me-4 mb-2\"\n        [for]=\"option.value + question?.id\"\n        >{{ option.label }}</label\n      >\n    </div>\n  </div>\n  <div\n    *ngIf=\"isInvalid && (!inLine || selectedOptions.length === 0)\"\n    class=\"error-message\"\n  >\n    {{ errorMessage }}\n  </div>\n  <div *ngIf=\"validationFailed && !isInvalid\" class=\"text-danger error-message\">\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"]}
422
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"check-box-fields.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/form-fields/check-box-fields/check-box-fields.component.ts","../../../../../projects/form-submission/src/form-fields/check-box-fields/check-box-fields.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { FormService } from '../../services/form.service';\nimport { ElementTrackerService } from '../../services/element-tracker.service';\nimport { ValidationService } from '../../services/validation.service';\nimport { ScoreCalculationService } from '../../services/score.service';\n\n@Component({\n  selector: 'lib-check-box-fields',\n  templateUrl: './check-box-fields.component.html',\n  styleUrls: ['./check-box-fields.component.scss'],\n})\nexport class CheckBoxFieldsComponent {\n  @Input() question: any = {};\n  @Input() inLine: boolean = false;\n  @Input() inCard: boolean = false;\n  @Input() submissionIndex!: number;\n  @Output() answerChange = new EventEmitter<{ answer: any; maxPossibleScore?: number }>();\n\n  count: number = 0;\n  required: boolean = false;\n  hint: string = '';\n  selectionType: string = '';\n  minimumSelection?: number;\n  maximumSelection?: number;\n  optionType: string = '';\n  lookupTable: any = {};\n  customOptions: any[] = [];\n  database: any = {};\n  api: any = {};\n  apiOptions: any[] = []; \n  selectedOptions: any[] = [];\n  validationFailed: boolean = false;\n  displayOptionsInColumn: boolean = false;\n  validationMessage: string = '';\n  private elementId: string='';\n  maxPossibleScore?:number;\n\n  constructor(\n    private formService: FormService,\n    private validationService: ValidationService,\n    private tracker: ElementTrackerService,\n    private scoreCalcService: ScoreCalculationService\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.selectionType = this.question.formElement.appearance.selectionType;\n    this.displayOptionsInColumn =\n      this.question.formElement.appearance.displayOptionsInColumn ?? false;\n    this.minimumSelection =\n      this.question.formElement.validation.minimumSelection;\n    this.maximumSelection =\n      this.question.formElement.validation.maximumSelection;\n    this.optionType = this.question.formElement.option.optionType;\n    switch (this.optionType) {\n      case 'OPTION':\n        this.customOptions = this.question.formElement.option.customOptions;\n         this.customOptions = this.question.formElement.option.customOptions.map((option:any) => ({\n          value: option.value,\n          label: option.value\n        }));\n        if (this.question.answer) {\n          this.initializeCustomOption();\n        }\n        break;\n      case 'LOOKUP':\n        this.lookupTable = this.question.formElement.option.lookupTable;\n        this.fetchDataFromLookup();\n        break;\n      case 'DATABASE':\n        this.database = this.question.formElement.option.database;\n        this.fetchDataFromDatabase();\n        break;\n      case 'API':\n        this.api = this.question.formElement.option.api;\n        this.fetchDataFromAPI();\n        break;\n      default:\n        console.warn('Unknown option type:', this.optionType);\n    }\n\n    if (this.selectionType === 'SINGLE') {\n      this.minimumSelection = 1;\n      this.maximumSelection = 1;\n    }\n\n    if (\n      this.selectionType === 'MULTIPLE' &&\n      !this.minimumSelection &&\n      !this.maximumSelection\n    ) {\n      this.minimumSelection = undefined;\n      this.maximumSelection = undefined;\n    }\n    if(this.question.formElement.scoring && this.question.formElement.scoring.enableScoring\n    ){\n      this.maxPossibleScore = this.scoreCalcService.getMaxPossibleScoreForQuestion(this.question);\n      this.question.maxPossibleScore = this.maxPossibleScore;\n    }\n  }\n\n  initializeCustomOption() {\n    this.selectedOptions = [];\n    this.customOptions?.forEach((option: any) => {\n      if (this.question?.answer?.find((a: any) => {\n        if (typeof a === 'string' && a.includes('|')) {\n          const parts = a.split('|');\n          return parts[1] === option.value.toString();\n        }\n        return a.toString() === option.value.toString();\n      })) {        \n        this.selectedOptions.push(option);\n      }      \n    });\n    if(this.question.childLogics && this.question.answer){\n      this.updateChildLogics(this.question)\n    }\n  }\n\n  onCheckboxChange(option: any, event: any) {\n    if (this.selectionType === 'SINGLE') {\n      if (event.target.checked) {\n        this.selectedOptions = [option];\n        this.question.answer = [`${option.label}|${option.value}`];\n      } else {\n        this.selectedOptions = [];\n        this.question.answer = [];\n      }\n      this.isMinimumSelectionValid();\n    } else if (this.selectionType === 'MULTIPLE') {\n      if (event.target.checked) {\n        if (!this.selectedOptions.includes(option)) {\n          this.selectedOptions.push(option);\n        }\n      } else {\n        this.selectedOptions = this.selectedOptions.filter(\n          (item) => item !== option\n        );\n      }\n      this.question.answer = this.selectedOptions.map(item => `${item.label}|${item.value}`);\n      this.isMinimumSelectionValid();\n    }\n  \n    if (\n      this.maximumSelection !== undefined &&\n      this.selectedOptions.length > this.maximumSelection\n    ) {\n      event.target.checked = false;\n      this.selectedOptions = this.selectedOptions.filter(\n        (item) => item !== option\n      );\n      this.question.answer = this.selectedOptions.map(item => `${item.label}|${item.value}`);\n      this.isMinimumSelectionValid();\n    }\n  \n    if (this.question.childLogics) {\n      this.updateChildLogics(this.question);\n    }\n    const scoreResult = this.scoreCalcService.calculateScoreFromAnswer(this.question.answer, this.question);\n    this.question.score = scoreResult?.scores;\n    this.answerChange.emit({answer:this.question.answer,maxPossibleScore:this.maxPossibleScore});\n  }\n\n  updateChildLogics(question: any) {    \n    if (question.childLogics && Array.isArray(question.childLogics)) {\n      question.childLogics.forEach((childLogic: any) => {\n        if (this.selectionType === 'SINGLE') {\n          if (this.selectedOptions.length === 0) {\n            childLogic.showLogic = false;\n            this.clearAnswersRecursively(childLogic);\n          } else { \n            if(this.evaluateCondition(this.selectedOptions[0]?.label, childLogic.condition, childLogic.inputValue)){\n              childLogic.showLogic = true;\n            }else{\n              childLogic.showLogic = false;\n              this.clearAnswersRecursively(childLogic);\n            }           \n          }\n        } else if (this.selectionType === 'MULTIPLE') {\n          if (this.selectedOptions.length === 0) {\n            childLogic.showLogic = false;\n            this.clearAnswersRecursively(childLogic);\n          } else {\n            const selectedLabels = this.selectedOptions.map((item: any) => item.label);\n            if(this.evaluateMultipleCondition(selectedLabels, childLogic.condition, childLogic.inputValue)){\n              childLogic.showLogic = true;\n            }else{\n              childLogic.showLogic = false;\n              this.clearAnswersRecursively(childLogic);\n            }\n          }\n        }\n      });\n    }\n  }\n\n  clearAnswersRecursively(logic: any) {\n    if (!logic || !logic.rows) return;\n  \n    logic.rows.forEach((row: any) => {\n      row.grid.forEach((item: any) => {\n        const element = item.element;\n  \n        if (item.entityType === 'QUESTION' && element) {\n          // Clear answer if present\n          if ('answer' in element) {\n            element.answer = '';\n          }\n  \n          // Recursively clear childLogics if any\n          if (element.childLogics && element.childLogics.length > 0) {\n            element.childLogics.forEach((childLogic: any) => {\n              this.clearAnswersRecursively(childLogic);\n            });\n          }\n        }\n  \n        if (item.entityType === 'SUBFORM' && element && element.rows) {\n          // SUBFORM contains its own rows structure like a form\n          this.clearAnswersRecursively({ rows: element.rows });\n        }\n      });\n    });\n  }\n  \n  \n  evaluateCondition(answer: any, condition: string, inputValue: any): boolean {    \n    const inputValues = Array.isArray(inputValue)\n      ? inputValue.map(val => val.toString())\n      : [inputValue.toString()];\n  \n    switch (condition) {\n      case \"!=\":\n        return !inputValues.includes(answer);\n      case \"=\":\n        return inputValues.includes(answer);\n      case \"IN\":\n        return inputValues.includes(answer);\n      case \"NOT IN\":\n        return !inputValues.includes(answer);\n      default:\n        return false;\n    }\n  }\n  \n  evaluateMultipleCondition(answers: any[], condition: string, inputValue: any): boolean {\n    const inputValues = Array.isArray(inputValue)\n      ? inputValue.map(val => val.toString())\n      : [inputValue.toString()];\n  \n    switch (condition) {\n      case \"!=\":\n        return answers.every(answer => !inputValues.includes(answer));\n      case \"=\":\n        return answers.some(answer => inputValues.includes(answer));\n      case \"IN\":\n        return answers.some(answer => inputValues.includes(answer));\n      case \"NOT IN\":\n        return answers.every(answer => !inputValues.includes(answer));\n      default:\n        return false;\n    }\n  }\n\n  fetchDataFromLookup() {\n    this.formService.fetchDataFromLookup(this.lookupTable).subscribe(\n      (response) => {\n        this.customOptions = response.result.values.map(\n          (item: { value: string; label: string }) => ({\n            value: item.value,\n            label: item.label,\n          })\n        );\n        if (this.question.answer) {\n          this.initializeCustomOption();\n        }\n      },\n      (error) => {\n        console.error('HTTP Error:', error);\n      }\n    );\n  }\n\n  fetchDataFromDatabase() {\n    const transformedDatabase = this.transformDatabaseObject(this.database);\n    this.formService.fetchDataFromDatabase(transformedDatabase).subscribe(\n      (response) => {\n        if (response.success) {\n          this.customOptions = response.result.map(\n            (item: { value: string; label: string }) => ({\n              value: item.value,\n              label: item.label,\n            })\n          );\n          if (this.question.answer) {\n            this.initializeCustomOption();\n          }\n        } else {\n          console.error('Error fetching data from database:', response.message);\n        }\n      },\n      (error) => {\n        console.error('HTTP Error:', error);\n      }\n    );\n  }\n\n  transformDatabaseObject(database: any) {\n    return {\n      tableName: database.tableName,\n      valueField: database.valueField,\n      labelField: database.labelField,\n      criteria: database.criteria.map((criteria: any) => ({\n        field: criteria?.field,\n        valueSource:criteria?.valueSource,\n        condition: criteria?.condition,\n        value: criteria?.inputValue,\n        logicalOperator: criteria?.logicalOperator,\n      })),\n    };\n  }\n\n  fetchDataFromAPI() {\n    const apiConfig = this.api;\n    this.formService.fetchDataFromExternalAPI(apiConfig).subscribe(\n      (response) => {\n        let data;\n        if(apiConfig.pathToValue) {\n          data = this.extractDataByPath(response, apiConfig.pathToValue);\n        } else {\n          data = response;\n        }\n        \n        this.customOptions = data.map((item: any) => ({\n          value: item[apiConfig.valueField],\n          label: item[apiConfig.labelField],\n        }));        \n        if (this.question.answer) {\n          \n          this.initializeCustomOption();\n          \n        }\n      },\n      (error) => {\n        console.error('HTTP Error:', error);\n      }\n    );\n  }\n\n  extractDataByPath(data: any, path: string) {\n    return path.split('.').reduce((acc, part) => acc && acc[part], data);\n  }\n\n  isMinimumSelectionValid() {\n    this.validationFailed = false;\n    \n    if (this.selectedOptions.length == 0 && this.required) {\n      this.validationService.clearInvalid(this.buildElementId());\n      this.validationFailed = true;\n      this.validationMessage = 'This is a required question';\n      this.question.validationMessage = 'This is a required question';\n      this.question.validation = false;\n    } else if (this.minimumSelection !== undefined) {\n      if(this.selectionType=='SINGLE'){\n        this.validationService.clearInvalid(this.buildElementId());\n        if (this.selectedOptions.length < this.minimumSelection && this.required) {\n          this.validationFailed = true;\n          this.validationMessage = `Minimum ${this.minimumSelection}  selection(s) required.`;\n          this.question.validationMessage = `Minimum ${this.minimumSelection}  selection(s) required.`;\n          this.question.validation = false;\n        }\n        else {\n          this.validationService.clearInvalid(this.buildElementId());\n          this.question.validation = true;\n        }\n      }\n      else{\n        if (this.selectedOptions.length < this.minimumSelection) {\n          this.validationService.clearInvalid(this.buildElementId());\n          this.validationFailed = true;\n          this.validationMessage = `Minimum ${this.minimumSelection}  selection(s) required.`;\n          this.question.validationMessage = `Minimum ${this.minimumSelection}  selection(s) required.`;\n          this.question.validation = false;\n        }\n        else {\n          this.validationService.clearInvalid(this.buildElementId());\n          this.question.validation = true;\n        }\n      }\n    } else {\n      this.validationService.clearInvalid(this.buildElementId());\n      this.question.validation = true;\n    }\n  }\n\n  getOptions() {\n    if (this.optionType === 'OPTION') {\n      return this.customOptions;\n    } else if (this.optionType === 'LOOKUP') {\n      return Object.values(this.lookupTable);\n    } else if (this.optionType === 'API') {\n      return this.apiOptions.map((option) => option.valueField);\n    } else {\n      return [];\n    }\n  }\n\n  isOptionDisabled(option: any): boolean {\n    return (\n      this.maximumSelection !== undefined &&\n      this.selectedOptions.length >= this.maximumSelection &&\n      !this.selectedOptions.includes(option)\n    );\n  }\n\n  \n  handleValidation(isValid: boolean, message: string = 'This field is required') {\n    if (isValid) {\n      this.validationService.clearInvalid(this.buildElementId());\n    } else {\n      // this.validationService.setInvalid(this.question.id, message);\n    }\n  }\n\n  private buildElementId(): string {\n    return (this.inLine || this.inCard)\n      ? `${this.submissionIndex}-${this.question.id}`\n      : `${this.question.id}`;\n  }\n\n  get isInvalid(): boolean {\n    return !!this.validationService.getErrorMessage(this.buildElementId());\n  }\n\n  get errorMessage(): string | null {\n    return this.validationService.getErrorMessage(this.buildElementId());\n  }\n\n  ngAfterViewInit() {\n    if (this.inLine || this.inCard) {\n      this.elementId = `question-${this.submissionIndex}-${this.question.id}`;\n    } else {\n      this.elementId = `question-${this.question.id}`;\n    }\n  \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]=\"(inLine || inCard) ? 'question-' + submissionIndex + '-' + question.id : 'question-' + question.id\"\n  [attr.name]=\"question.testElementName\"\n>\n  <div class=\"input-wrapper mb-3\" *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  <div\n    class=\"checkboxField-container\"\n    [class.two-column]=\"displayOptionsInColumn\"\n  >\n    <div class=\"form-check\" *ngFor=\"let option of customOptions\">\n      <input\n        class=\"form-check-input\"\n        type=\"checkbox\"\n        [id]=\"option.value + question?.id\"\n        [name]=\"option.value + 'Checkbox'\"\n        [value]=\"option.value\"\n        (change)=\"onCheckboxChange(option, $event)\"\n        [disabled]=\"isOptionDisabled(option)\"\n        [checked]=\"selectedOptions.includes(option)\"\n        [attr.data-value]=\"selectedOptions.includes(option)\"\n      />\n      <label\n        class=\"formCheckLabel me-4 mb-2\"\n        [for]=\"option.value + question?.id\"\n        >{{ option.label }}</label\n      >\n    </div>\n  </div>\n  <div\n    *ngIf=\"isInvalid && (!inLine || selectedOptions.length === 0)\"\n    class=\"error-message\"\n  >\n    {{ errorMessage }}\n  </div>\n  <div *ngIf=\"validationFailed && !isInvalid\" class=\"text-danger error-message\">\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"]}
@@ -0,0 +1,261 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "../../services/validation.service";
4
+ import * as i2 from "../../services/element-tracker.service";
5
+ import * as i3 from "../../services/aggregate.service";
6
+ import * as i4 from "@angular/common";
7
+ import * as i5 from "@angular/forms";
8
+ export class CurrencyFieldsComponent {
9
+ constructor(validationService, tracker, aggregateService) {
10
+ this.validationService = validationService;
11
+ this.tracker = tracker;
12
+ this.aggregateService = aggregateService;
13
+ this.question = {};
14
+ this.inLine = false;
15
+ this.inCard = false;
16
+ this.answerChange = new EventEmitter();
17
+ this.count = 0;
18
+ this.required = false;
19
+ this.hint = '';
20
+ this.placeholder = '';
21
+ this.currencySymbol = '';
22
+ this.symbolPosition = 'Before the value';
23
+ this.validationFailed = false;
24
+ this.validationMessage = '';
25
+ this.elementId = '';
26
+ }
27
+ ngOnInit() {
28
+ this.valueAssigned();
29
+ }
30
+ valueAssigned() {
31
+ this.count = this.question.count;
32
+ this.required = this.question.required;
33
+ this.hint = this.question.hint;
34
+ this.placeholder = this.question.formElement?.appearance?.placeholder || '';
35
+ this.currencySymbol = this.question.formElement?.appearance?.currencySymbol;
36
+ this.decimalPrecision = this.question.formElement?.appearance?.decimalPrecision;
37
+ this.symbolPosition = this.question.formElement?.appearance?.symbolPosition || 'Before the value';
38
+ this.thousandSeparator = this.question.formElement?.appearance?.thousandSeparator;
39
+ this.min = this.question.formElement.validation.min;
40
+ this.max = this.question.formElement.validation.max;
41
+ if (this.question.answer) {
42
+ this.initializeAnswer();
43
+ }
44
+ if (this.question.childLogics && this.question.answer) {
45
+ this.updateChildLogics(this.question);
46
+ }
47
+ this.aggregateService.setNumberField(this.rowId, this.question.id, this.question.answer);
48
+ }
49
+ initializeAnswer() {
50
+ let value = this.question?.answer;
51
+ if (!value)
52
+ return;
53
+ // check if numeric
54
+ if (!isNaN(Number(value))) {
55
+ if (this.thousandSeparator) {
56
+ const parts = value.split('.');
57
+ parts[0] = Number(parts[0]).toLocaleString('en-US'); // adds proper thousand separator
58
+ value = parts.join('.');
59
+ }
60
+ else {
61
+ value = value;
62
+ }
63
+ }
64
+ this.enteredAmount = value;
65
+ }
66
+ preventNumberScroll(event) {
67
+ if (document.activeElement === event.target) {
68
+ event.preventDefault();
69
+ }
70
+ }
71
+ validateNumber() {
72
+ this.validationFailed = false;
73
+ this.validationService.clearInvalid(this.buildElementId());
74
+ this.validationMessage = '';
75
+ let enteredAmount = this.parseCurrencyToNumber(this.enteredAmount);
76
+ if (this.required && !enteredAmount) {
77
+ this.validationFailed = true;
78
+ this.validationMessage = `Please enter a valid amount`;
79
+ this.question.validationMessage = `Please enter a valid amount`;
80
+ this.question.validation = false;
81
+ }
82
+ else if ((this.min !== undefined && enteredAmount < this.min) ||
83
+ (this.max !== undefined && enteredAmount > this.max)) {
84
+ this.validationFailed = true;
85
+ // Construct appropriate validation message based on whether min, max, or both are provided
86
+ if (this.min !== undefined && this.max !== undefined) {
87
+ this.validationMessage = `Please enter a valid amount between ${this.min} and ${this.max}`;
88
+ this.question.validationMessage = `Please enter a valid amount between ${this.min} and ${this.max}`;
89
+ }
90
+ else if (this.min !== undefined) {
91
+ this.validationMessage = `Please enter a amount greater than or equal to ${this.min}`;
92
+ this.question.validationMessage = `Please enter a amount greater than or equal to ${this.min}`;
93
+ }
94
+ else if (this.max !== undefined) {
95
+ this.validationMessage = `Please enter a amount less than or equal to ${this.max}`;
96
+ this.question.validationMessage = `Please enter a amount less than or equal to ${this.max}`;
97
+ }
98
+ this.question.validation = false;
99
+ }
100
+ else {
101
+ this.question.validation = true;
102
+ }
103
+ if (this.question.childLogics) {
104
+ this.updateChildLogics(this.question);
105
+ }
106
+ }
107
+ validateInput(event) {
108
+ this.validationService.clearInvalid(this.buildElementId());
109
+ // remove existing commas & currency symbol
110
+ let rawValue = event.target.value.replace(/,/g, '').replace(this.currencySymbol, '');
111
+ // ✅ allow numbers with optional single decimal
112
+ if (rawValue && !/^\d*\.?\d*$/.test(rawValue)) {
113
+ rawValue = rawValue.replace(/[^\d.]/g, '');
114
+ }
115
+ // ✅ apply decimal precision restriction (but don’t force zeros)
116
+ if (this.decimalPrecision !== undefined && rawValue.includes('.')) {
117
+ const [intPart, decimalPart = ''] = rawValue.split('.');
118
+ let trimmedDecimal = decimalPart.slice(0, this.decimalPrecision);
119
+ rawValue = trimmedDecimal ? `${intPart}.${trimmedDecimal}` : intPart + '.';
120
+ }
121
+ // format with thousand separator for display
122
+ let formattedValue = rawValue;
123
+ if (this.thousandSeparator && rawValue) {
124
+ const parts = rawValue.split('.');
125
+ if (parts[0]) {
126
+ parts[0] = Number(parts[0]).toLocaleString('en-US');
127
+ }
128
+ formattedValue = parts.join('.');
129
+ }
130
+ // keep numeric version for backend/calculations
131
+ this.question.answer = rawValue;
132
+ // update field display
133
+ event.target.value = formattedValue;
134
+ this.aggregateService.setNumberField(this.rowId, this.question.id, rawValue);
135
+ if (this.question.childLogics) {
136
+ this.updateChildLogics(this.question);
137
+ }
138
+ this.answerChange.emit({ answer: this.question.answer, maxPossibleScore: 0 });
139
+ this.validateNumber();
140
+ }
141
+ updateChildLogics(question) {
142
+ if (question.childLogics && Array.isArray(question.childLogics)) {
143
+ question.childLogics.forEach((childLogic) => {
144
+ if (this.evaluateCondition(question.answer, childLogic.condition, childLogic.inputValue)) {
145
+ childLogic.showLogic = true;
146
+ }
147
+ else {
148
+ childLogic.showLogic = false;
149
+ this.clearAnswersRecursively(childLogic);
150
+ }
151
+ });
152
+ }
153
+ }
154
+ parseCurrencyToNumber(value) {
155
+ if (!value)
156
+ return 0;
157
+ // Remove currency symbol, commas, spaces
158
+ const numericString = value
159
+ .replace(new RegExp(`\\${this.currencySymbol}`, 'g'), '') // remove symbol
160
+ .replace(/,/g, '') // remove thousand separators
161
+ .trim();
162
+ // Convert to number
163
+ const num = parseFloat(numericString);
164
+ return isNaN(num) ? 0 : num;
165
+ }
166
+ clearAnswersRecursively(logic) {
167
+ if (!logic || !logic.rows)
168
+ return;
169
+ logic.rows.forEach((row) => {
170
+ row.grid.forEach((item) => {
171
+ const element = item.element;
172
+ if (item.entityType === 'QUESTION' && element) {
173
+ // Clear answer if present
174
+ if ('answer' in element) {
175
+ element.answer = '';
176
+ }
177
+ // Recursively clear childLogics if any
178
+ if (element.childLogics && element.childLogics.length > 0) {
179
+ element.childLogics.forEach((childLogic) => {
180
+ this.clearAnswersRecursively(childLogic);
181
+ });
182
+ }
183
+ }
184
+ if (item.entityType === 'SUBFORM' && element && element.rows) {
185
+ // SUBFORM contains its own rows structure like a form
186
+ this.clearAnswersRecursively({ rows: element.rows });
187
+ }
188
+ });
189
+ });
190
+ }
191
+ evaluateCondition(answer, condition, inputValue) {
192
+ switch (condition) {
193
+ case '>':
194
+ return answer > Number(inputValue);
195
+ case '<':
196
+ return answer < Number(inputValue);
197
+ case '>=':
198
+ return answer >= Number(inputValue);
199
+ case '<=':
200
+ return answer <= Number(inputValue);
201
+ case '=':
202
+ return answer == inputValue;
203
+ case '!=':
204
+ return answer != inputValue;
205
+ default:
206
+ return false;
207
+ }
208
+ }
209
+ handleValidation(isValid, message = 'This field is required') {
210
+ if (isValid) {
211
+ this.validationService.clearInvalid(this.buildElementId());
212
+ }
213
+ else {
214
+ // this.validationService.setInvalid(this.question.id, message);
215
+ }
216
+ }
217
+ buildElementId() {
218
+ return (this.inLine || this.inCard)
219
+ ? `${this.submissionIndex}-${this.question.id}`
220
+ : `${this.question.id}`;
221
+ }
222
+ get isInvalid() {
223
+ return !!this.validationService.getErrorMessage(this.buildElementId());
224
+ }
225
+ get errorMessage() {
226
+ return this.validationService.getErrorMessage(this.buildElementId());
227
+ }
228
+ ngAfterViewInit() {
229
+ if (this.inLine || this.inCard) {
230
+ this.elementId = `question-${this.submissionIndex}-${this.question.id}`;
231
+ }
232
+ else {
233
+ this.elementId = `question-${this.question.id}`;
234
+ }
235
+ this.tracker.registerElement(this.elementId);
236
+ }
237
+ ngOnDestroy() {
238
+ if (this.elementId) {
239
+ this.tracker.unregisterElement(this.elementId);
240
+ }
241
+ }
242
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CurrencyFieldsComponent, deps: [{ token: i1.ValidationService }, { token: i2.ElementTrackerService }, { token: i3.AggregationFunctionService }], target: i0.ɵɵFactoryTarget.Component }); }
243
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CurrencyFieldsComponent, selector: "lib-currency-fields", inputs: { question: "question", inLine: "inLine", inCard: "inCard", submissionIndex: "submissionIndex", rowId: "rowId" }, outputs: { answerChange: "answerChange" }, ngImport: i0, template: "<div\n [ngClass]=\"{ 'mb-4': !inLine }\"\n class=\"px-3\"\n [id]=\"(inLine || inCard) ? 'question-' + submissionIndex + '-' + question.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>\n <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\n <div class=\"currency-input inside\">\n <span *ngIf=\"symbolPosition === 'Before the value'\" class=\"currency-symbol left\">\n {{ currencySymbol }}\n </span>\n\n <input\n type=\"text\"\n class=\"form-control mb-2 height\"\n [placeholder]=\"placeholder\"\n [class.hide-spin-buttons]=\"true\"\n (blur)=\"validateNumber()\"\n [(ngModel)]=\"enteredAmount\"\n [class.invalid]=\"validationFailed\"\n [class.invalid-question]=\"isInvalid && (!inLine || !enteredAmount)\"\n (input)=\"validateInput($event)\"\n [attr.min]=\"min\"\n [attr.max]=\"max\"\n (wheel)=\"preventNumberScroll($event)\"\n />\n\n <span *ngIf=\"symbolPosition === 'After the value'\" class=\"currency-symbol right\">\n {{ currencySymbol }}\n </span>\n\n </div>\n \n <div *ngIf=\"isInvalid && (!inLine || !enteredAmount)\" class=\"error-message\">\n {{ errorMessage }}\n </div>\n <div *ngIf=\"validationFailed && !isInvalid\" class=\"text-danger error-message\">\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", styles: [".input-wrapper{display:flex;align-items:flex-start}.svg-wrapper{margin-inline-start:auto;z-index:999}.hintIcon{position:relative;cursor:pointer}.hintIcon:hover:before{content:attr(data-title);position:absolute;top:calc(100% + 2px);right:0;padding:4px 8px;border-radius:4px;background-color:#1d252d;color:#8e9aa0;font-size:14px;min-width:300px;word-wrap:break-word;word-break:break-word;text-align:center;white-space:normal}.hintIcon:hover:after{content:\"\";position:absolute;top:calc(100% - 26px);left:50%;border:solid transparent;border-width:18px;border-bottom-color:#1d252d;transform:translate(-50%)}.height{height:42px}.invalid{border-color:red}.hintSvg{width:30px;height:30px;fill:none}.validationSvg{width:24px;height:24px;fill:none}::ng-deep html lib-formSubmission{font-family:var(--library-font-family)!important;font-size:var(--library-font-size)!important}::ng-deep .timepicker-overlay{z-index:1000!important}::ng-deep .timepicker-backdrop-overlay{z-index:1000!important}.space{width:5px}.error-message{color:#f44336;font-size:.8em;margin-top:4px;padding:0 8px}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.hide-spin-buttons::-webkit-outer-spin-button,.hide-spin-buttons::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.invalid-question{border:2px solid #f44336;border-radius:4px;padding:8px;margin-bottom:4px}.currency-input.inside{position:relative}.currency-input.inside input{padding-left:.75rem;padding-right:.75rem}.currency-input.inside .currency-symbol{position:absolute;top:50%;transform:translateY(-50%);color:#444;font-weight:700;pointer-events:none;white-space:nowrap}.currency-input.inside .currency-symbol.left{left:1%}.currency-input.inside .currency-symbol.left+input{padding-left:6ch}.currency-input.inside input+.currency-symbol.right{right:10px;padding-right:4ch}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
244
+ }
245
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CurrencyFieldsComponent, decorators: [{
246
+ type: Component,
247
+ args: [{ selector: 'lib-currency-fields', template: "<div\n [ngClass]=\"{ 'mb-4': !inLine }\"\n class=\"px-3\"\n [id]=\"(inLine || inCard) ? 'question-' + submissionIndex + '-' + question.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>\n <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\n <div class=\"currency-input inside\">\n <span *ngIf=\"symbolPosition === 'Before the value'\" class=\"currency-symbol left\">\n {{ currencySymbol }}\n </span>\n\n <input\n type=\"text\"\n class=\"form-control mb-2 height\"\n [placeholder]=\"placeholder\"\n [class.hide-spin-buttons]=\"true\"\n (blur)=\"validateNumber()\"\n [(ngModel)]=\"enteredAmount\"\n [class.invalid]=\"validationFailed\"\n [class.invalid-question]=\"isInvalid && (!inLine || !enteredAmount)\"\n (input)=\"validateInput($event)\"\n [attr.min]=\"min\"\n [attr.max]=\"max\"\n (wheel)=\"preventNumberScroll($event)\"\n />\n\n <span *ngIf=\"symbolPosition === 'After the value'\" class=\"currency-symbol right\">\n {{ currencySymbol }}\n </span>\n\n </div>\n \n <div *ngIf=\"isInvalid && (!inLine || !enteredAmount)\" class=\"error-message\">\n {{ errorMessage }}\n </div>\n <div *ngIf=\"validationFailed && !isInvalid\" class=\"text-danger error-message\">\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", styles: [".input-wrapper{display:flex;align-items:flex-start}.svg-wrapper{margin-inline-start:auto;z-index:999}.hintIcon{position:relative;cursor:pointer}.hintIcon:hover:before{content:attr(data-title);position:absolute;top:calc(100% + 2px);right:0;padding:4px 8px;border-radius:4px;background-color:#1d252d;color:#8e9aa0;font-size:14px;min-width:300px;word-wrap:break-word;word-break:break-word;text-align:center;white-space:normal}.hintIcon:hover:after{content:\"\";position:absolute;top:calc(100% - 26px);left:50%;border:solid transparent;border-width:18px;border-bottom-color:#1d252d;transform:translate(-50%)}.height{height:42px}.invalid{border-color:red}.hintSvg{width:30px;height:30px;fill:none}.validationSvg{width:24px;height:24px;fill:none}::ng-deep html lib-formSubmission{font-family:var(--library-font-family)!important;font-size:var(--library-font-size)!important}::ng-deep .timepicker-overlay{z-index:1000!important}::ng-deep .timepicker-backdrop-overlay{z-index:1000!important}.space{width:5px}.error-message{color:#f44336;font-size:.8em;margin-top:4px;padding:0 8px}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.hide-spin-buttons::-webkit-outer-spin-button,.hide-spin-buttons::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.invalid-question{border:2px solid #f44336;border-radius:4px;padding:8px;margin-bottom:4px}.currency-input.inside{position:relative}.currency-input.inside input{padding-left:.75rem;padding-right:.75rem}.currency-input.inside .currency-symbol{position:absolute;top:50%;transform:translateY(-50%);color:#444;font-weight:700;pointer-events:none;white-space:nowrap}.currency-input.inside .currency-symbol.left{left:1%}.currency-input.inside .currency-symbol.left+input{padding-left:6ch}.currency-input.inside input+.currency-symbol.right{right:10px;padding-right:4ch}\n"] }]
248
+ }], ctorParameters: function () { return [{ type: i1.ValidationService }, { type: i2.ElementTrackerService }, { type: i3.AggregationFunctionService }]; }, propDecorators: { question: [{
249
+ type: Input
250
+ }], inLine: [{
251
+ type: Input
252
+ }], inCard: [{
253
+ type: Input
254
+ }], submissionIndex: [{
255
+ type: Input
256
+ }], answerChange: [{
257
+ type: Output
258
+ }], rowId: [{
259
+ type: Input
260
+ }] } });
261
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"currency-fields.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/form-fields/currency-fields/currency-fields.component.ts","../../../../../projects/form-submission/src/form-fields/currency-fields/currency-fields.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { ValidationService } from '../../services/validation.service';\nimport { ElementTrackerService } from '../../services/element-tracker.service';\nimport { AggregationFunctionService } from '../../services/aggregate.service';\n\n@Component({\n  selector: 'lib-currency-fields',\n  templateUrl: './currency-fields.component.html',\n  styleUrls: ['./currency-fields.component.scss']\n})\nexport class CurrencyFieldsComponent {\n\n  @Input() question: any = {};\n  @Input() inLine: boolean = false;\n  @Input() inCard: boolean = false;\n  @Input() submissionIndex!: number;\n  @Output() answerChange = new EventEmitter<{ answer: any; maxPossibleScore?: number }>();\n  @Input() rowId: any;\n\n  count: number = 0;\n  required: boolean = false;\n  hint: string = '';\n  placeholder: string = '';\n  min!: number;\n  max!: number;\n  currencySymbol:string = '';\n  decimalPrecision!:number;\n  symbolPosition: string = 'Before the value';\n  thousandSeparator!:boolean;\n  enteredAmount!: string;\n  validationFailed: boolean = false;\n  validationMessage: string = '';\n  private elementId: string='';\n  constructor(\n      private validationService: ValidationService,\n      private tracker: ElementTrackerService,\n      private aggregateService:AggregationFunctionService\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.currencySymbol = this.question.formElement?.appearance?.currencySymbol;\n    this.decimalPrecision = this.question.formElement?.appearance?.decimalPrecision;\n    this.symbolPosition = this.question.formElement?.appearance?.symbolPosition || 'Before the value';\n    this.thousandSeparator = this.question.formElement?.appearance?.thousandSeparator;\n    this.min = this.question.formElement.validation.min;\n    this.max = this.question.formElement.validation.max;\n    \n    if(this.question.answer){\n       this.initializeAnswer();\n    }\n    if (this.question.childLogics && this.question.answer) {\n      this.updateChildLogics(this.question);\n    }\n    this.aggregateService.setNumberField(this.rowId,this.question.id,this.question.answer);\n  }\n\n  \n  initializeAnswer() {\n    let value = this.question?.answer;\n  \n    if (!value) return;\n  \n  \n    // check if numeric\n    if (!isNaN(Number(value))) {\n      if (this.thousandSeparator) {\n        const parts = value.split('.');\n        parts[0] = Number(parts[0]).toLocaleString('en-US'); // adds proper thousand separator\n        value = parts.join('.');\n      } else {\n        value = value;\n      }\n    }\n  \n    this.enteredAmount = value;\n  }\n  \n\n  preventNumberScroll(event: WheelEvent) {\n    if (document.activeElement === event.target) {\n      event.preventDefault();\n    }\n  }\n  \n  validateNumber() {\n    this.validationFailed = false;\n    this.validationService.clearInvalid(this.buildElementId());\n    this.validationMessage = '';\n    let enteredAmount = this.parseCurrencyToNumber(this.enteredAmount)\n    if (this.required && !enteredAmount) {\n      this.validationFailed = true;\n      this.validationMessage = `Please enter a valid amount`;\n      this.question.validationMessage = `Please enter a valid amount`;\n      this.question.validation = false;\n    } else if (\n      (this.min !== undefined && enteredAmount < this.min) ||\n      (this.max !== undefined && enteredAmount > this.max)\n    ) {\n      this.validationFailed = true;\n\n      // Construct appropriate validation message based on whether min, max, or both are provided\n      if (this.min !== undefined && this.max !== undefined) {\n        this.validationMessage = `Please enter a valid amount between ${this.min} and ${this.max}`;\n        this.question.validationMessage = `Please enter a valid amount between ${this.min} and ${this.max}`;\n      } else if (this.min !== undefined) {\n        this.validationMessage = `Please enter a amount greater than or equal to ${this.min}`;\n        this.question.validationMessage = `Please enter a amount greater than or equal to ${this.min}`;\n      } else if (this.max !== undefined) {\n        this.validationMessage = `Please enter a amount less than or equal to ${this.max}`;\n        this.question.validationMessage = `Please enter a amount less than or equal to ${this.max}`;\n      }\n\n      this.question.validation = false;\n    } else {\n      this.question.validation = true;\n    }\n    if (this.question.childLogics) {\n      this.updateChildLogics(this.question);\n    }\n  }\n\n  validateInput(event: any) {\n    this.validationService.clearInvalid(this.buildElementId());\n  \n    // remove existing commas & currency symbol\n    let rawValue = event.target.value.replace(/,/g, '').replace(this.currencySymbol, '');\n  \n    // ✅ allow numbers with optional single decimal\n    if (rawValue && !/^\\d*\\.?\\d*$/.test(rawValue)) {\n      rawValue = rawValue.replace(/[^\\d.]/g, '');\n    }\n  \n    // ✅ apply decimal precision restriction (but don’t force zeros)\n    if (this.decimalPrecision !== undefined && rawValue.includes('.')) {\n      const [intPart, decimalPart = ''] = rawValue.split('.');\n      let trimmedDecimal = decimalPart.slice(0, this.decimalPrecision);\n      rawValue = trimmedDecimal ? `${intPart}.${trimmedDecimal}` : intPart + '.';\n    }\n  \n    // format with thousand separator for display\n    let formattedValue = rawValue;\n    if (this.thousandSeparator && rawValue) {\n      const parts = rawValue.split('.');\n      if (parts[0]) {\n        parts[0] = Number(parts[0]).toLocaleString('en-US');\n      }\n      formattedValue = parts.join('.');\n    }\n  \n    // keep numeric version for backend/calculations\n    this.question.answer = rawValue;\n  \n    // update field display\n    event.target.value = formattedValue;\n  \n    this.aggregateService.setNumberField(this.rowId, this.question.id, rawValue);\n  \n    if (this.question.childLogics) {\n      this.updateChildLogics(this.question);\n    }\n  \n    this.answerChange.emit({ answer: this.question.answer, maxPossibleScore: 0 });\n    this.validateNumber();\n  }\n  \n  updateChildLogics(question: any) {\n    if (question.childLogics && Array.isArray(question.childLogics)) {\n      question.childLogics.forEach((childLogic: any) => {\n        if (\n          this.evaluateCondition(\n            question.answer,\n            childLogic.condition,\n            childLogic.inputValue\n          )\n        ) {\n          childLogic.showLogic = true;\n        } else {\n          childLogic.showLogic = false;\n          this.clearAnswersRecursively(childLogic);\n        }\n      });\n    }\n  }\n\n  parseCurrencyToNumber(value: string): number {\n    if (!value) return 0;\n  \n    // Remove currency symbol, commas, spaces\n    const numericString = value\n      .replace(new RegExp(`\\\\${this.currencySymbol}`, 'g'), '') // remove symbol\n      .replace(/,/g, '')                                   // remove thousand separators\n      .trim();\n  \n    // Convert to number\n    const num = parseFloat(numericString);\n    return isNaN(num) ? 0 : num;\n  }\n  \n  \n  clearAnswersRecursively(logic: any) {\n    if (!logic || !logic.rows) return;\n  \n    logic.rows.forEach((row: any) => {\n      row.grid.forEach((item: any) => {\n        const element = item.element;\n  \n        if (item.entityType === 'QUESTION' && element) {\n          // Clear answer if present\n          if ('answer' in element) {\n            element.answer = '';\n          }\n  \n          // Recursively clear childLogics if any\n          if (element.childLogics && element.childLogics.length > 0) {\n            element.childLogics.forEach((childLogic: any) => {\n              this.clearAnswersRecursively(childLogic);\n            });\n          }\n        }\n  \n        if (item.entityType === 'SUBFORM' && element && element.rows) {\n          // SUBFORM contains its own rows structure like a form\n          this.clearAnswersRecursively({ rows: element.rows });\n        }\n      });\n    });\n  }\n\n  evaluateCondition(answer: any, condition: any, inputValue: any) {\n    switch (condition) {\n      case '>':\n        return answer > Number(inputValue);\n      case '<':\n        return answer < Number(inputValue);\n      case '>=':\n        return answer >= Number(inputValue);\n      case '<=':\n        return answer <= Number(inputValue);\n      case '=':\n        return answer == inputValue;\n      case '!=':\n        return answer != inputValue;\n      default:\n        return false;\n    }\n  }\n\n\n  \n  handleValidation(isValid: boolean, message: string = 'This field is required') {\n    if (isValid) {\n      this.validationService.clearInvalid(this.buildElementId());\n    } else {\n      // this.validationService.setInvalid(this.question.id, message);\n    }\n  }\n\n  private buildElementId(): string {\n    return (this.inLine || this.inCard)\n      ? `${this.submissionIndex}-${this.question.id}`\n      : `${this.question.id}`;\n  }\n\n  get isInvalid(): boolean {\n    return !!this.validationService.getErrorMessage(this.buildElementId());\n  }\n\n  get errorMessage(): string | null {\n    return this.validationService.getErrorMessage(this.buildElementId());\n  }\n\n  ngAfterViewInit() {\n    if (this.inLine || this.inCard) {\n      this.elementId = `question-${this.submissionIndex}-${this.question.id}`;\n    } else {\n      this.elementId = `question-${this.question.id}`;\n    }\n  \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]=\"(inLine || inCard) ? 'question-' + submissionIndex + '-' + question.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>\n    <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\n  <div class=\"currency-input inside\">\n    <span *ngIf=\"symbolPosition === 'Before the value'\" class=\"currency-symbol left\">\n      {{ currencySymbol }}\n    </span>\n\n    <input\n    type=\"text\"\n    class=\"form-control mb-2 height\"\n    [placeholder]=\"placeholder\"\n    [class.hide-spin-buttons]=\"true\"\n    (blur)=\"validateNumber()\"\n    [(ngModel)]=\"enteredAmount\"\n    [class.invalid]=\"validationFailed\"\n    [class.invalid-question]=\"isInvalid && (!inLine || !enteredAmount)\"\n    (input)=\"validateInput($event)\"\n    [attr.min]=\"min\"\n    [attr.max]=\"max\"\n    (wheel)=\"preventNumberScroll($event)\"\n    />\n\n    <span *ngIf=\"symbolPosition === 'After the value'\" class=\"currency-symbol right\">\n        {{ currencySymbol }}\n    </span>\n\n  </div>\n  \n  <div *ngIf=\"isInvalid && (!inLine || !enteredAmount)\" class=\"error-message\">\n    {{ errorMessage }}\n  </div>\n  <div *ngIf=\"validationFailed && !isInvalid\" class=\"text-danger error-message\">\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"]}