@piserve-tech/form-submission 1.3.214 → 1.3.216

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 (33) hide show
  1. package/assets/icons/copy-icon.svg +6 -0
  2. package/esm2022/form-fields/text-fields/text-fields.component.mjs +1 -1
  3. package/esm2022/form-submission/navigation-tabs/navigation-tabs.component.mjs +3 -4
  4. package/esm2022/form-submission/next-prev-navigation/next-prev-navigation.component.mjs +2 -3
  5. package/esm2022/form-submission/submit-form/submit-form.component.mjs +44 -2
  6. package/esm2022/models/emitters.model.mjs +2 -0
  7. package/esm2022/models/publicForm.model.mjs +1 -1
  8. package/esm2022/models/subForm.model.mjs +1 -1
  9. package/esm2022/models/subformPropery.model.mjs +1 -1
  10. package/esm2022/question/card-subform/card-subform.component.mjs +1 -1
  11. package/esm2022/question/confirm-dialog/confirm-dialog.component.mjs +23 -0
  12. package/esm2022/question/form-elements/form-elements.component.mjs +6 -3
  13. package/esm2022/question/recursive-logic/recursive-logic.component.mjs +6 -3
  14. package/esm2022/question/sub-form/sub-form.component.mjs +117 -31
  15. package/esm2022/services/countryService.mjs +2 -2
  16. package/esm2022/services/mapper.service.mjs +20 -5
  17. package/esm2022/services/subform-copy.service.mjs +120 -0
  18. package/esm2022/shared/shared.module.mjs +16 -4
  19. package/fesm2022/piserve-tech-form-submission.mjs +320 -29
  20. package/fesm2022/piserve-tech-form-submission.mjs.map +1 -1
  21. package/form-submission/submit-form/submit-form.component.d.ts +16 -0
  22. package/models/emitters.model.d.ts +8 -0
  23. package/models/publicForm.model.d.ts +2 -0
  24. package/models/subForm.model.d.ts +1 -0
  25. package/models/subformPropery.model.d.ts +2 -1
  26. package/package.json +3 -2
  27. package/question/confirm-dialog/confirm-dialog.component.d.ts +11 -0
  28. package/question/form-elements/form-elements.component.d.ts +2 -1
  29. package/question/recursive-logic/recursive-logic.component.d.ts +2 -1
  30. package/question/sub-form/sub-form.component.d.ts +18 -1
  31. package/services/mapper.service.d.ts +2 -0
  32. package/services/subform-copy.service.d.ts +10 -0
  33. package/shared/shared.module.d.ts +4 -1
@@ -0,0 +1,6 @@
1
+ <svg width="38" height="36" viewBox="0 0 38 36" fill="none" xmlns="http://www.w3.org/2000/svg">
2
+ <rect x="0.5" y="0.5" width="37" height="35" rx="5.5" fill="white" stroke="#D8D8D8"/>
3
+ <rect x="13.998" y="13.9922" width="14.0058" height="14.0058" rx="2" stroke="#084FFF" stroke-linecap="round" stroke-linejoin="round"/>
4
+ <path d="M13.9982 23.998H11.9974C10.8924 23.998 9.99658 23.1022 9.99658 21.9972V11.993C9.99658 10.888 10.8924 9.99219 11.9974 9.99219H22.0016C23.1066 9.99219 24.0024 10.888 24.0024 11.993V13.9939" stroke="#084FFF" stroke-linecap="round" stroke-linejoin="round"/>
5
+ </svg>
6
+
@@ -203,4 +203,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
203
203
  }], answerChange: [{
204
204
  type: Output
205
205
  }] } });
206
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-fields.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/form-fields/text-fields/text-fields.component.ts","../../../../../projects/form-submission/src/form-fields/text-fields/text-fields.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { Logic } from '../../models/logic.model';\nimport { ValidationService } from '../../services/validation.service';\nimport { ElementTrackerService } from '../../services/element-tracker.service';\n\n@Component({\n  selector: 'lib-text-fields',\n  templateUrl: './text-fields.component.html',\n  styleUrls: ['./text-fields.component.scss'],\n})\nexport class TextFieldsComponent {\n  @Input() question: any = {};\n  @Input() inLine: boolean = false;\n  @Input() inCard: boolean = false;\n  @Output() answerChange = new EventEmitter<any>();\n  answer: string = '';\n  count: number = 0;\n  required: boolean = false;\n  hint: string = '';\n  placeholder: string = '';\n  defaultValue: string = '';\n  disableEdit: boolean = false;\n  validationType: string = '';\n  validation: string = '';\n  regex!: RegExp;\n  enteredText: string = '';\n  validationFailed: boolean = false;\n  validationMessage: string = '';\n  private elementId: string='';\n    \n   constructor(\n        private validationService: ValidationService,\n        private tracker: ElementTrackerService\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.defaultValue = this.question?.defaultValue;\n    this.disableEdit = this.question.disableEdit;\n    this.enteredText = this.defaultValue;\n    this.validationType = this.question.formElement.validation?.validationType;\n    if (this.validationType == 'CUSTOM_VALIDATION') {\n      this.validation = this.question.formElement.validation?.validation;\n    } else if (this.validationType == 'REGULAR_EXPRESSION') {\n      this.regex = this.question.formElement.validation?.regex;\n    }\n\n    if (\n      this.question.answer !== null &&\n      this.question.answer !== undefined &&\n      ((typeof this.question.answer === 'string' &&\n        this.question.answer.trim() !== '') ||\n        (Array.isArray(this.question.answer) &&\n          this.question.answer.length > 0) ||\n        (typeof this.question.answer === 'object' &&\n          Object.keys(this.question.answer).length > 0))\n    ) {\n      this.enteredText = this.question.answer;\n    }else if(this.defaultValue && !this.question.answer){\n      this.question.answer = this.defaultValue;\n    }\n    if (this.question.childLogics && this.question.answer) {\n      this.updateChildLogics(this.question)\n    }\n  }\n\n  validatetextField() {\n    this.validationService.clearInvalid(this.question.id);\n    this.validationFailed = false;\n    this.validationMessage = '';\n    if (this.required && !this.enteredText) {\n      this.validationFailed = true;\n      this.validationMessage = 'This is a required question';\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.question.id);\n    let value = event.target.value;\n    if (this.validation == 'Numbers only') {\n      event.target.value = value?.replace(/\\D/g, '');\n    } else if (this.validation == 'Alphanumeric') {\n      event.target.value = value?.replace(/[^a-zA-Z0-9]/g, '');\n    } else if (this.validationType == 'REGULAR_EXPRESSION' && this.regex) {\n      //event.target.value = value?.replace(this.regex, '');\n      const regex = new RegExp(this.regex);\n\n      if (regex.test(value)) {\n        event.target.value = value;\n      } else {\n        event.target.value = value.slice(0, -1);\n      }\n    }\n    this.question.answer = event.target.value;\n    this.answerChange.emit(event.target.value);\n    this.validatetextField();\n    if(!this.inLine && !this.inCard) {\n      setTimeout(() => {\n        const el = document.getElementById(this.question.id);\n        if (el) {\n          (el as HTMLElement).focus();\n        }\n      });\n    }\n    \n  }\n\n  updateChildLogics(question: any) {\n    if (question.childLogics && Array.isArray(question.childLogics)) {\n      question.childLogics.forEach((childLogic: any) => {\n        if (this.evaluateCondition(this.enteredText, childLogic.condition, childLogic.inputValue)) {\n          childLogic.showLogic = true;\n        }\n        else {\n          childLogic.showLogic = false;\n          this.clearAnswersRecursively(childLogic);\n        }\n      });\n    }\n  }\n\n  evaluateCondition(answer: any, condition: string, inputValue: any): boolean {\n    const stringInputValue = inputValue;\n\n    switch (condition) {\n      case '!=':\n        return answer != inputValue;\n      case '=':\n        return answer == inputValue;\n      case 'LIKE':\n        return answer.includes(inputValue);\n      case 'NOT LIKE':\n        return !answer.includes(inputValue);\n      case 'BEGIN WITH':\n        return answer.startsWith(inputValue);\n      case 'END WITH':\n        return answer.endsWith(inputValue);\n      default:\n        return false;\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  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\n  <input\n    type=\"text\"\n    class=\"form-control mb-2 height\"\n    [placeholder]=\"placeholder\"\n    [(ngModel)]=\"enteredText\"\n    (blur)=\"validatetextField()\"\n    (input)=\"validateInput($event)\"\n    [class.invalid]=\"validationFailed\"\n    [class.invalid-question]=\"isInvalid && (!inLine || !enteredText)\"\n    [id]=\"question.id\"\n    [disabled]=\"disableEdit\"\n  />\n  <div *ngIf=\"isInvalid && (!inLine || !enteredText)\" 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"]}
206
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-fields.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/form-fields/text-fields/text-fields.component.ts","../../../../../projects/form-submission/src/form-fields/text-fields/text-fields.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { Logic } from '../../models/logic.model';\nimport { ValidationService } from '../../services/validation.service';\nimport { ElementTrackerService } from '../../services/element-tracker.service';\n\n@Component({\n  selector: 'lib-text-fields',\n  templateUrl: './text-fields.component.html',\n  styleUrls: ['./text-fields.component.scss'],\n})\nexport class TextFieldsComponent {\n  @Input() question: any = {};\n  @Input() inLine: boolean = false;\n  @Input() inCard: boolean = false;\n  @Output() answerChange = new EventEmitter<any>();\n  answer: string = '';\n  count: number = 0;\n  required: boolean = false;\n  hint: string = '';\n  placeholder: string = '';\n  defaultValue: string = '';\n  disableEdit: boolean = false;\n  validationType: string = '';\n  validation: string = '';\n  regex!: RegExp;\n  enteredText: string = '';\n  validationFailed: boolean = false;\n  validationMessage: string = '';\n  private elementId: string='';\n    \n   constructor(\n        private validationService: ValidationService,\n        private tracker: ElementTrackerService\n      )  { }\n\n  ngOnInit() {\n    \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.defaultValue = this.question?.defaultValue;\n    this.disableEdit = this.question.disableEdit;\n    this.enteredText = this.defaultValue;\n    this.validationType = this.question.formElement.validation?.validationType;\n    if (this.validationType == 'CUSTOM_VALIDATION') {\n      this.validation = this.question.formElement.validation?.validation;\n    } else if (this.validationType == 'REGULAR_EXPRESSION') {\n      this.regex = this.question.formElement.validation?.regex;\n    }\n\n    if (\n      this.question.answer !== null &&\n      this.question.answer !== undefined &&\n      ((typeof this.question.answer === 'string' &&\n        this.question.answer.trim() !== '') ||\n        (Array.isArray(this.question.answer) &&\n          this.question.answer.length > 0) ||\n        (typeof this.question.answer === 'object' &&\n          Object.keys(this.question.answer).length > 0))\n    ) {\n      this.enteredText = this.question.answer;\n    }else if(this.defaultValue && !this.question.answer){\n      this.question.answer = this.defaultValue;\n    }\n    if (this.question.childLogics && this.question.answer) {\n      this.updateChildLogics(this.question)\n    }\n  }\n\n  validatetextField() {\n    this.validationService.clearInvalid(this.question.id);\n    this.validationFailed = false;\n    this.validationMessage = '';\n    if (this.required && !this.enteredText) {\n      this.validationFailed = true;\n      this.validationMessage = 'This is a required question';\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.question.id);\n    let value = event.target.value;\n    if (this.validation == 'Numbers only') {\n      event.target.value = value?.replace(/\\D/g, '');\n    } else if (this.validation == 'Alphanumeric') {\n      event.target.value = value?.replace(/[^a-zA-Z0-9]/g, '');\n    } else if (this.validationType == 'REGULAR_EXPRESSION' && this.regex) {\n      //event.target.value = value?.replace(this.regex, '');\n      const regex = new RegExp(this.regex);\n\n      if (regex.test(value)) {\n        event.target.value = value;\n      } else {\n        event.target.value = value.slice(0, -1);\n      }\n    }\n    this.question.answer = event.target.value;\n    this.answerChange.emit(event.target.value);\n    this.validatetextField();\n    if(!this.inLine && !this.inCard) {\n      setTimeout(() => {\n        const el = document.getElementById(this.question.id);\n        if (el) {\n          (el as HTMLElement).focus();\n        }\n      });\n    }\n    \n  }\n\n  updateChildLogics(question: any) {\n    if (question.childLogics && Array.isArray(question.childLogics)) {\n      question.childLogics.forEach((childLogic: any) => {\n        if (this.evaluateCondition(this.enteredText, childLogic.condition, childLogic.inputValue)) {\n          childLogic.showLogic = true;\n        }\n        else {\n          childLogic.showLogic = false;\n          this.clearAnswersRecursively(childLogic);\n        }\n      });\n    }\n  }\n\n  evaluateCondition(answer: any, condition: string, inputValue: any): boolean {\n    const stringInputValue = inputValue;\n\n    switch (condition) {\n      case '!=':\n        return answer != inputValue;\n      case '=':\n        return answer == inputValue;\n      case 'LIKE':\n        return answer.includes(inputValue);\n      case 'NOT LIKE':\n        return !answer.includes(inputValue);\n      case 'BEGIN WITH':\n        return answer.startsWith(inputValue);\n      case 'END WITH':\n        return answer.endsWith(inputValue);\n      default:\n        return false;\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  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\n  <input\n    type=\"text\"\n    class=\"form-control mb-2 height\"\n    [placeholder]=\"placeholder\"\n    [(ngModel)]=\"enteredText\"\n    (blur)=\"validatetextField()\"\n    (input)=\"validateInput($event)\"\n    [class.invalid]=\"validationFailed\"\n    [class.invalid-question]=\"isInvalid && (!inLine || !enteredText)\"\n    [id]=\"question.id\"\n    [disabled]=\"disableEdit\"\n  />\n  <div *ngIf=\"isInvalid && (!inLine || !enteredText)\" 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"]}
@@ -31,7 +31,6 @@ export class NavigationTabsComponent {
31
31
  this.loadedPages[this.currentPageIndex] = true;
32
32
  }
33
33
  ngOnInit() {
34
- console.log('skip margin on form navigation tab', this.isActionTriggered);
35
34
  this.checkPageDetails();
36
35
  }
37
36
  ngAfterViewInit() {
@@ -97,11 +96,11 @@ export class NavigationTabsComponent {
97
96
  }
98
97
  }
99
98
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NavigationTabsComponent, deps: [{ token: i1.FormValidationService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
100
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NavigationTabsComponent, selector: "lib-navigation-tabs", inputs: { pages: "pages", currentPageIndex: "currentPageIndex", edit: "edit", acceptedLanguage: "acceptedLanguage", eligibleForSubmission: "eligibleForSubmission", pageDetails: "pageDetails", markAllQuestionsAsRequired: "markAllQuestionsAsRequired", skipMargin: "skipMargin", primaryColor: "primaryColor", secondaryColor: "secondaryColor", isActionTriggered: "isActionTriggered" }, outputs: { pageChanged: "pageChanged", submitEmit: "submitEmit", subFormChange: "subFormChange", rowSetIndex: "rowSetIndex" }, ngImport: i0, template: "<div class=\"tab-inner-container\" [ngClass]=\"{ 'skip-margin': skipMargin}\">\n <div class=\"d-flex gap-2\">\n <div class=\"tab-navigation\" *ngIf=\"!hideTabs\">\n <ul class=\"nav nav-tabs navTabs\" id=\"myTab\" role=\"tablist\">\n <li\n class=\"nav-item\"\n role=\"presentation\"\n *ngFor=\"let page of pageDetails; let i = index; trackBy: trackByIndex\"\n [ngClass]=\"{'nav-item-ara': acceptedLanguage === 'ara', 'nav-item-default': acceptedLanguage !== 'ara'}\"\n >\n <button\n class=\"nav-link\"\n [title]=\"page.name\"\n data-bs-toggle=\"tooltip\"\n data-bs-placement=\"top\"\n data-bs-custom-class=\"custom-tooltip\"\n [class.active]=\"i === currentPageIndex\"\n id=\"tab-{{ i }}\"\n type=\"button\"\n role=\"tab\"\n [attr.aria-controls]=\"'content-' + i\"\n [attr.aria-selected]=\"i === currentPageIndex\"\n (click)=\"setCurrentPage(i)\"\n >\n {{ page.name }}\n </button>\n </li>\n </ul>\n </div>\n <div class=\"d-flex align-items-center\" *ngIf=\"showNavArrows\">\n <button class=\"nav-arrow\">\n <img src=\"assets/icons/left_arrow.svg\" alt=\"left arrow\"\n (click)=\"scrollTabs(-1)\">\n <img src=\"assets/icons/right_arrow.svg\" alt=\"right arrow\"\n (click)=\"scrollTabs(1)\">\n </button>\n </div>\n </div>\n\n\n\n <div class=\"tab-content pt-5 pb-3 px-1\" [attr.name]=\"pages[currentPageIndex].testElementName\">\n <ng-container *ngIf=\"pages[currentPageIndex]\">\n <div\n class=\"tab-pane fade show active\"\n id=\"content-{{ currentPageIndex }}\"\n role=\"tabpanel\"\n [attr.aria-labelledby]=\"'tab-' + currentPageIndex\"\n >\n <div *ngIf=\"loadedPages[currentPageIndex]\">\n <div class=\"data-container\"\n infiniteScroll\n [infiniteScrollDistance]=\"2\"\n [infiniteScrollThrottle]=\"200\"\n (scrolled)=\"loadMoreData()\">\n <div *ngFor=\"let row of pages[currentPageIndex].rows\">\n <div class=\"margin d-flex\">\n <div *ngFor=\"let grid of row.grid\"\n [ngStyle]=\"{'width.%': (grid.element.count) * (100 / 12)}\">\n <lib-form-elements\n [grid]=\"grid\"\n [edit]=\"edit\"\n [acceptedLanguage]=\"acceptedLanguage\"\n (subFormChange)=\"updateSubFormWithSubmissions($event)\"\n ></lib-form-elements>\n </div>\n </div>\n </div>\n </div>\n <div class=\"footerButton d-flex justify-content-between align-items-center me-4 ms-4 position-relative\">\n <!-- Hover detection container -->\n <div [ngStyle]=\"{ display: currentPageIndex === pageDetails.length - 1 ? 'block' : 'none' }\" id=\"captcha-container\"></div>\n <div\n class=\"button-container position-relative\"\n (mouseenter)=\"showTooltip = true\"\n (mouseleave)=\"showTooltip = false\"\n >\n\n <div *ngIf=\"currentPageIndex == pageDetails.length - 1\">\n <button\n *ngIf=\"!isActionTriggered\"\n class=\"btn rounded-pill submitButton text-white\"\n [ngStyle]=\"{ 'background-color': primaryColor ? primaryColor: '#084fff' }\"\n type=\"button\"\n (click)=\"submitForm()\"\n [disabled]=\"!eligibleForSubmission.status\"\n >\n Submit\n </button>\n\n <div *ngIf=\"showTooltip && !eligibleForSubmission.status\" class=\"custom-tooltip\">\n {{eligibleForSubmission.message}}\n </div>\n </div>\n </div>\n\n </div>\n\n\n </div>\n </div>\n </ng-container>\n </div>\n</div>\n", styles: [".tab-inner-container{width:100%;position:relative;padding:3rem}@media (max-width: 1024px){.tab-inner-container{padding-left:1rem;padding-right:1rem}}@media (max-width: 576px){.tab-inner-container{padding:2rem .5rem}}.skip-margin{padding:0}.custom-tooltip{visibility:hidden;position:absolute;top:-40px;right:0;background:#efefef;color:#7b7878;padding:8px 12px;border-radius:12px;box-shadow:0 4px 8px #00000026;font-size:14px;white-space:nowrap;z-index:10}.custom-tooltip.warning{background:linear-gradient(135deg,gold,#ffb400)}.fade-in{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.footerButton:hover .custom-tooltip{visibility:visible}.navTabs{overflow-x:auto;overflow-y:hidden;flex-wrap:unset;margin:0 0 -1px!important;padding-right:0}.nav-item{background-color:#fff;border-radius:5px}.nav-item.nav-item-default{margin-right:.5%}.nav-item.nav-item-ara{margin-left:.5%}.nav-link{position:relative;margin-bottom:-2px;padding-left:25px;padding-right:25px}.nav-link:after{content:\"\";position:absolute;left:0;bottom:0;width:101%;height:6px;background:#efefef}.nav-link.active:after{display:none}.tab-content{background-color:#fff}.custom-tooltip{--bs-tooltip-bg: var(--bd-violet-bg);--bs-tooltip-color: var(--bs-white)}.tab-navigation{position:relative;display:flex;align-items:center;width:95%}.navTabs{display:flex;overflow-x:auto;scroll-behavior:smooth;white-space:nowrap;width:100%;padding:0;margin:0;scrollbar-width:none;-ms-overflow-style:none}.navTabs::-webkit-scrollbar{display:none}.nav-arrow{position:absolute;background:#fff;border:none;cursor:pointer;font-size:20px;font-weight:700;padding:5px 10px;z-index:1000;box-shadow:0 2px 5px #0003;width:45px;height:27px;gap:13px;display:flex;justify-content:center;align-items:center;border-radius:6px}.nav-arrow img{width:8px;height:15px}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i3.FormElementsComponent, selector: "lib-form-elements", inputs: ["currentPageIndex", "edit", "acceptedLanguage", "answer", "grid", "state"], outputs: ["subFormChange"] }, { kind: "directive", type: i4.InfiniteScrollDirective, selector: "[infiniteScroll], [infinite-scroll], [data-infinite-scroll]", inputs: ["infiniteScrollDistance", "infiniteScrollUpDistance", "infiniteScrollThrottle", "infiniteScrollDisabled", "infiniteScrollContainer", "scrollWindow", "immediateCheck", "horizontal", "alwaysCallback", "fromRoot"], outputs: ["scrolled", "scrolledUp"] }] }); }
99
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NavigationTabsComponent, selector: "lib-navigation-tabs", inputs: { pages: "pages", currentPageIndex: "currentPageIndex", edit: "edit", acceptedLanguage: "acceptedLanguage", eligibleForSubmission: "eligibleForSubmission", pageDetails: "pageDetails", markAllQuestionsAsRequired: "markAllQuestionsAsRequired", skipMargin: "skipMargin", primaryColor: "primaryColor", secondaryColor: "secondaryColor", isActionTriggered: "isActionTriggered" }, outputs: { pageChanged: "pageChanged", submitEmit: "submitEmit", subFormChange: "subFormChange", rowSetIndex: "rowSetIndex" }, ngImport: i0, template: "<div class=\"tab-inner-container\" [ngClass]=\"{ 'skip-margin': skipMargin}\">\n <div class=\"d-flex gap-2\">\n <div class=\"tab-navigation\" *ngIf=\"!hideTabs\">\n <ul class=\"nav nav-tabs navTabs\" id=\"myTab\" role=\"tablist\">\n <li\n class=\"nav-item\"\n role=\"presentation\"\n *ngFor=\"let page of pageDetails; let i = index; trackBy: trackByIndex\"\n [ngClass]=\"{'nav-item-ara': acceptedLanguage === 'ara', 'nav-item-default': acceptedLanguage !== 'ara'}\"\n >\n <button\n class=\"nav-link\"\n [title]=\"page.name\"\n data-bs-toggle=\"tooltip\"\n data-bs-placement=\"top\"\n data-bs-custom-class=\"custom-tooltip\"\n [class.active]=\"i === currentPageIndex\"\n id=\"tab-{{ i }}\"\n type=\"button\"\n role=\"tab\"\n [attr.aria-controls]=\"'content-' + i\"\n [attr.aria-selected]=\"i === currentPageIndex\"\n (click)=\"setCurrentPage(i)\"\n >\n {{ page.name }}\n </button>\n </li>\n </ul>\n </div>\n <div class=\"d-flex align-items-center\" *ngIf=\"showNavArrows\">\n <button class=\"nav-arrow\">\n <img src=\"assets/icons/left_arrow.svg\" alt=\"left arrow\"\n (click)=\"scrollTabs(-1)\">\n <img src=\"assets/icons/right_arrow.svg\" alt=\"right arrow\"\n (click)=\"scrollTabs(1)\">\n </button>\n </div>\n </div>\n\n\n\n <div class=\"tab-content pt-5 pb-3 px-1\" [attr.name]=\"pages[currentPageIndex].testElementName\">\n <ng-container *ngIf=\"pages[currentPageIndex]\">\n <div\n class=\"tab-pane fade show active\"\n id=\"content-{{ currentPageIndex }}\"\n role=\"tabpanel\"\n [attr.aria-labelledby]=\"'tab-' + currentPageIndex\"\n >\n <div *ngIf=\"loadedPages[currentPageIndex]\">\n <div class=\"data-container\"\n infiniteScroll\n [infiniteScrollDistance]=\"2\"\n [infiniteScrollThrottle]=\"200\"\n (scrolled)=\"loadMoreData()\">\n <div *ngFor=\"let row of pages[currentPageIndex].rows\">\n <div class=\"margin d-flex\">\n <div *ngFor=\"let grid of row.grid\"\n [ngStyle]=\"{'width.%': (grid.element.count) * (100 / 12)}\">\n <lib-form-elements\n [grid]=\"grid\"\n [edit]=\"edit\"\n [acceptedLanguage]=\"acceptedLanguage\"\n [pages]=\"pages\"\n (subFormChange)=\"updateSubFormWithSubmissions($event)\"\n ></lib-form-elements>\n </div>\n </div>\n </div>\n </div>\n <div class=\"footerButton d-flex justify-content-between align-items-center me-4 ms-4 position-relative\">\n <!-- Hover detection container -->\n <div [ngStyle]=\"{ display: currentPageIndex === pageDetails.length - 1 ? 'block' : 'none' }\" id=\"captcha-container\"></div>\n <div\n class=\"button-container position-relative\"\n (mouseenter)=\"showTooltip = true\"\n (mouseleave)=\"showTooltip = false\"\n >\n\n <div *ngIf=\"currentPageIndex == pageDetails.length - 1\">\n <button\n *ngIf=\"!isActionTriggered\"\n class=\"btn rounded-pill submitButton text-white\"\n [ngStyle]=\"{ 'background-color': primaryColor ? primaryColor: '#084fff' }\"\n type=\"button\"\n (click)=\"submitForm()\"\n [disabled]=\"!eligibleForSubmission.status\"\n >\n Submit\n </button>\n\n <div *ngIf=\"showTooltip && !eligibleForSubmission.status\" class=\"custom-tooltip\">\n {{eligibleForSubmission.message}}\n </div>\n </div>\n </div>\n\n </div>\n\n\n </div>\n </div>\n </ng-container>\n </div>\n</div>\n", styles: [".tab-inner-container{width:100%;position:relative;padding:3rem}@media (max-width: 1024px){.tab-inner-container{padding-left:1rem;padding-right:1rem}}@media (max-width: 576px){.tab-inner-container{padding:2rem .5rem}}.skip-margin{padding:0}.custom-tooltip{visibility:hidden;position:absolute;top:-40px;right:0;background:#efefef;color:#7b7878;padding:8px 12px;border-radius:12px;box-shadow:0 4px 8px #00000026;font-size:14px;white-space:nowrap;z-index:10}.custom-tooltip.warning{background:linear-gradient(135deg,gold,#ffb400)}.fade-in{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.footerButton:hover .custom-tooltip{visibility:visible}.navTabs{overflow-x:auto;overflow-y:hidden;flex-wrap:unset;margin:0 0 -1px!important;padding-right:0}.nav-item{background-color:#fff;border-radius:5px}.nav-item.nav-item-default{margin-right:.5%}.nav-item.nav-item-ara{margin-left:.5%}.nav-link{position:relative;margin-bottom:-2px;padding-left:25px;padding-right:25px}.nav-link:after{content:\"\";position:absolute;left:0;bottom:0;width:101%;height:6px;background:#efefef}.nav-link.active:after{display:none}.tab-content{background-color:#fff}.custom-tooltip{--bs-tooltip-bg: var(--bd-violet-bg);--bs-tooltip-color: var(--bs-white)}.tab-navigation{position:relative;display:flex;align-items:center;width:95%}.navTabs{display:flex;overflow-x:auto;scroll-behavior:smooth;white-space:nowrap;width:100%;padding:0;margin:0;scrollbar-width:none;-ms-overflow-style:none}.navTabs::-webkit-scrollbar{display:none}.nav-arrow{position:absolute;background:#fff;border:none;cursor:pointer;font-size:20px;font-weight:700;padding:5px 10px;z-index:1000;box-shadow:0 2px 5px #0003;width:45px;height:27px;gap:13px;display:flex;justify-content:center;align-items:center;border-radius:6px}.nav-arrow img{width:8px;height:15px}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i3.FormElementsComponent, selector: "lib-form-elements", inputs: ["currentPageIndex", "edit", "acceptedLanguage", "answer", "grid", "state", "pages"], outputs: ["subFormChange"] }, { kind: "directive", type: i4.InfiniteScrollDirective, selector: "[infiniteScroll], [infinite-scroll], [data-infinite-scroll]", inputs: ["infiniteScrollDistance", "infiniteScrollUpDistance", "infiniteScrollThrottle", "infiniteScrollDisabled", "infiniteScrollContainer", "scrollWindow", "immediateCheck", "horizontal", "alwaysCallback", "fromRoot"], outputs: ["scrolled", "scrolledUp"] }] }); }
101
100
  }
102
101
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NavigationTabsComponent, decorators: [{
103
102
  type: Component,
104
- args: [{ selector: 'lib-navigation-tabs', template: "<div class=\"tab-inner-container\" [ngClass]=\"{ 'skip-margin': skipMargin}\">\n <div class=\"d-flex gap-2\">\n <div class=\"tab-navigation\" *ngIf=\"!hideTabs\">\n <ul class=\"nav nav-tabs navTabs\" id=\"myTab\" role=\"tablist\">\n <li\n class=\"nav-item\"\n role=\"presentation\"\n *ngFor=\"let page of pageDetails; let i = index; trackBy: trackByIndex\"\n [ngClass]=\"{'nav-item-ara': acceptedLanguage === 'ara', 'nav-item-default': acceptedLanguage !== 'ara'}\"\n >\n <button\n class=\"nav-link\"\n [title]=\"page.name\"\n data-bs-toggle=\"tooltip\"\n data-bs-placement=\"top\"\n data-bs-custom-class=\"custom-tooltip\"\n [class.active]=\"i === currentPageIndex\"\n id=\"tab-{{ i }}\"\n type=\"button\"\n role=\"tab\"\n [attr.aria-controls]=\"'content-' + i\"\n [attr.aria-selected]=\"i === currentPageIndex\"\n (click)=\"setCurrentPage(i)\"\n >\n {{ page.name }}\n </button>\n </li>\n </ul>\n </div>\n <div class=\"d-flex align-items-center\" *ngIf=\"showNavArrows\">\n <button class=\"nav-arrow\">\n <img src=\"assets/icons/left_arrow.svg\" alt=\"left arrow\"\n (click)=\"scrollTabs(-1)\">\n <img src=\"assets/icons/right_arrow.svg\" alt=\"right arrow\"\n (click)=\"scrollTabs(1)\">\n </button>\n </div>\n </div>\n\n\n\n <div class=\"tab-content pt-5 pb-3 px-1\" [attr.name]=\"pages[currentPageIndex].testElementName\">\n <ng-container *ngIf=\"pages[currentPageIndex]\">\n <div\n class=\"tab-pane fade show active\"\n id=\"content-{{ currentPageIndex }}\"\n role=\"tabpanel\"\n [attr.aria-labelledby]=\"'tab-' + currentPageIndex\"\n >\n <div *ngIf=\"loadedPages[currentPageIndex]\">\n <div class=\"data-container\"\n infiniteScroll\n [infiniteScrollDistance]=\"2\"\n [infiniteScrollThrottle]=\"200\"\n (scrolled)=\"loadMoreData()\">\n <div *ngFor=\"let row of pages[currentPageIndex].rows\">\n <div class=\"margin d-flex\">\n <div *ngFor=\"let grid of row.grid\"\n [ngStyle]=\"{'width.%': (grid.element.count) * (100 / 12)}\">\n <lib-form-elements\n [grid]=\"grid\"\n [edit]=\"edit\"\n [acceptedLanguage]=\"acceptedLanguage\"\n (subFormChange)=\"updateSubFormWithSubmissions($event)\"\n ></lib-form-elements>\n </div>\n </div>\n </div>\n </div>\n <div class=\"footerButton d-flex justify-content-between align-items-center me-4 ms-4 position-relative\">\n <!-- Hover detection container -->\n <div [ngStyle]=\"{ display: currentPageIndex === pageDetails.length - 1 ? 'block' : 'none' }\" id=\"captcha-container\"></div>\n <div\n class=\"button-container position-relative\"\n (mouseenter)=\"showTooltip = true\"\n (mouseleave)=\"showTooltip = false\"\n >\n\n <div *ngIf=\"currentPageIndex == pageDetails.length - 1\">\n <button\n *ngIf=\"!isActionTriggered\"\n class=\"btn rounded-pill submitButton text-white\"\n [ngStyle]=\"{ 'background-color': primaryColor ? primaryColor: '#084fff' }\"\n type=\"button\"\n (click)=\"submitForm()\"\n [disabled]=\"!eligibleForSubmission.status\"\n >\n Submit\n </button>\n\n <div *ngIf=\"showTooltip && !eligibleForSubmission.status\" class=\"custom-tooltip\">\n {{eligibleForSubmission.message}}\n </div>\n </div>\n </div>\n\n </div>\n\n\n </div>\n </div>\n </ng-container>\n </div>\n</div>\n", styles: [".tab-inner-container{width:100%;position:relative;padding:3rem}@media (max-width: 1024px){.tab-inner-container{padding-left:1rem;padding-right:1rem}}@media (max-width: 576px){.tab-inner-container{padding:2rem .5rem}}.skip-margin{padding:0}.custom-tooltip{visibility:hidden;position:absolute;top:-40px;right:0;background:#efefef;color:#7b7878;padding:8px 12px;border-radius:12px;box-shadow:0 4px 8px #00000026;font-size:14px;white-space:nowrap;z-index:10}.custom-tooltip.warning{background:linear-gradient(135deg,gold,#ffb400)}.fade-in{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.footerButton:hover .custom-tooltip{visibility:visible}.navTabs{overflow-x:auto;overflow-y:hidden;flex-wrap:unset;margin:0 0 -1px!important;padding-right:0}.nav-item{background-color:#fff;border-radius:5px}.nav-item.nav-item-default{margin-right:.5%}.nav-item.nav-item-ara{margin-left:.5%}.nav-link{position:relative;margin-bottom:-2px;padding-left:25px;padding-right:25px}.nav-link:after{content:\"\";position:absolute;left:0;bottom:0;width:101%;height:6px;background:#efefef}.nav-link.active:after{display:none}.tab-content{background-color:#fff}.custom-tooltip{--bs-tooltip-bg: var(--bd-violet-bg);--bs-tooltip-color: var(--bs-white)}.tab-navigation{position:relative;display:flex;align-items:center;width:95%}.navTabs{display:flex;overflow-x:auto;scroll-behavior:smooth;white-space:nowrap;width:100%;padding:0;margin:0;scrollbar-width:none;-ms-overflow-style:none}.navTabs::-webkit-scrollbar{display:none}.nav-arrow{position:absolute;background:#fff;border:none;cursor:pointer;font-size:20px;font-weight:700;padding:5px 10px;z-index:1000;box-shadow:0 2px 5px #0003;width:45px;height:27px;gap:13px;display:flex;justify-content:center;align-items:center;border-radius:6px}.nav-arrow img{width:8px;height:15px}\n"] }]
103
+ args: [{ selector: 'lib-navigation-tabs', template: "<div class=\"tab-inner-container\" [ngClass]=\"{ 'skip-margin': skipMargin}\">\n <div class=\"d-flex gap-2\">\n <div class=\"tab-navigation\" *ngIf=\"!hideTabs\">\n <ul class=\"nav nav-tabs navTabs\" id=\"myTab\" role=\"tablist\">\n <li\n class=\"nav-item\"\n role=\"presentation\"\n *ngFor=\"let page of pageDetails; let i = index; trackBy: trackByIndex\"\n [ngClass]=\"{'nav-item-ara': acceptedLanguage === 'ara', 'nav-item-default': acceptedLanguage !== 'ara'}\"\n >\n <button\n class=\"nav-link\"\n [title]=\"page.name\"\n data-bs-toggle=\"tooltip\"\n data-bs-placement=\"top\"\n data-bs-custom-class=\"custom-tooltip\"\n [class.active]=\"i === currentPageIndex\"\n id=\"tab-{{ i }}\"\n type=\"button\"\n role=\"tab\"\n [attr.aria-controls]=\"'content-' + i\"\n [attr.aria-selected]=\"i === currentPageIndex\"\n (click)=\"setCurrentPage(i)\"\n >\n {{ page.name }}\n </button>\n </li>\n </ul>\n </div>\n <div class=\"d-flex align-items-center\" *ngIf=\"showNavArrows\">\n <button class=\"nav-arrow\">\n <img src=\"assets/icons/left_arrow.svg\" alt=\"left arrow\"\n (click)=\"scrollTabs(-1)\">\n <img src=\"assets/icons/right_arrow.svg\" alt=\"right arrow\"\n (click)=\"scrollTabs(1)\">\n </button>\n </div>\n </div>\n\n\n\n <div class=\"tab-content pt-5 pb-3 px-1\" [attr.name]=\"pages[currentPageIndex].testElementName\">\n <ng-container *ngIf=\"pages[currentPageIndex]\">\n <div\n class=\"tab-pane fade show active\"\n id=\"content-{{ currentPageIndex }}\"\n role=\"tabpanel\"\n [attr.aria-labelledby]=\"'tab-' + currentPageIndex\"\n >\n <div *ngIf=\"loadedPages[currentPageIndex]\">\n <div class=\"data-container\"\n infiniteScroll\n [infiniteScrollDistance]=\"2\"\n [infiniteScrollThrottle]=\"200\"\n (scrolled)=\"loadMoreData()\">\n <div *ngFor=\"let row of pages[currentPageIndex].rows\">\n <div class=\"margin d-flex\">\n <div *ngFor=\"let grid of row.grid\"\n [ngStyle]=\"{'width.%': (grid.element.count) * (100 / 12)}\">\n <lib-form-elements\n [grid]=\"grid\"\n [edit]=\"edit\"\n [acceptedLanguage]=\"acceptedLanguage\"\n [pages]=\"pages\"\n (subFormChange)=\"updateSubFormWithSubmissions($event)\"\n ></lib-form-elements>\n </div>\n </div>\n </div>\n </div>\n <div class=\"footerButton d-flex justify-content-between align-items-center me-4 ms-4 position-relative\">\n <!-- Hover detection container -->\n <div [ngStyle]=\"{ display: currentPageIndex === pageDetails.length - 1 ? 'block' : 'none' }\" id=\"captcha-container\"></div>\n <div\n class=\"button-container position-relative\"\n (mouseenter)=\"showTooltip = true\"\n (mouseleave)=\"showTooltip = false\"\n >\n\n <div *ngIf=\"currentPageIndex == pageDetails.length - 1\">\n <button\n *ngIf=\"!isActionTriggered\"\n class=\"btn rounded-pill submitButton text-white\"\n [ngStyle]=\"{ 'background-color': primaryColor ? primaryColor: '#084fff' }\"\n type=\"button\"\n (click)=\"submitForm()\"\n [disabled]=\"!eligibleForSubmission.status\"\n >\n Submit\n </button>\n\n <div *ngIf=\"showTooltip && !eligibleForSubmission.status\" class=\"custom-tooltip\">\n {{eligibleForSubmission.message}}\n </div>\n </div>\n </div>\n\n </div>\n\n\n </div>\n </div>\n </ng-container>\n </div>\n</div>\n", styles: [".tab-inner-container{width:100%;position:relative;padding:3rem}@media (max-width: 1024px){.tab-inner-container{padding-left:1rem;padding-right:1rem}}@media (max-width: 576px){.tab-inner-container{padding:2rem .5rem}}.skip-margin{padding:0}.custom-tooltip{visibility:hidden;position:absolute;top:-40px;right:0;background:#efefef;color:#7b7878;padding:8px 12px;border-radius:12px;box-shadow:0 4px 8px #00000026;font-size:14px;white-space:nowrap;z-index:10}.custom-tooltip.warning{background:linear-gradient(135deg,gold,#ffb400)}.fade-in{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.footerButton:hover .custom-tooltip{visibility:visible}.navTabs{overflow-x:auto;overflow-y:hidden;flex-wrap:unset;margin:0 0 -1px!important;padding-right:0}.nav-item{background-color:#fff;border-radius:5px}.nav-item.nav-item-default{margin-right:.5%}.nav-item.nav-item-ara{margin-left:.5%}.nav-link{position:relative;margin-bottom:-2px;padding-left:25px;padding-right:25px}.nav-link:after{content:\"\";position:absolute;left:0;bottom:0;width:101%;height:6px;background:#efefef}.nav-link.active:after{display:none}.tab-content{background-color:#fff}.custom-tooltip{--bs-tooltip-bg: var(--bd-violet-bg);--bs-tooltip-color: var(--bs-white)}.tab-navigation{position:relative;display:flex;align-items:center;width:95%}.navTabs{display:flex;overflow-x:auto;scroll-behavior:smooth;white-space:nowrap;width:100%;padding:0;margin:0;scrollbar-width:none;-ms-overflow-style:none}.navTabs::-webkit-scrollbar{display:none}.nav-arrow{position:absolute;background:#fff;border:none;cursor:pointer;font-size:20px;font-weight:700;padding:5px 10px;z-index:1000;box-shadow:0 2px 5px #0003;width:45px;height:27px;gap:13px;display:flex;justify-content:center;align-items:center;border-radius:6px}.nav-arrow img{width:8px;height:15px}\n"] }]
105
104
  }], ctorParameters: function () { return [{ type: i1.FormValidationService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { pages: [{
106
105
  type: Input
107
106
  }], currentPageIndex: [{
@@ -133,4 +132,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
133
132
  }], isActionTriggered: [{
134
133
  type: Input
135
134
  }] } });
136
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navigation-tabs.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/form-submission/navigation-tabs/navigation-tabs.component.ts","../../../../../projects/form-submission/src/form-submission/navigation-tabs/navigation-tabs.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAqB,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;;;;;;AAQ1F,MAAM,OAAO,uBAAuB;IAqBlC,YACU,qBAA4C,EAC5C,GAAsB;QADtB,0BAAqB,GAArB,qBAAqB,CAAuB;QAC5C,QAAG,GAAH,GAAG,CAAmB;QAtBvB,UAAK,GAAU,EAAE,CAAC;QAClB,qBAAgB,GAAW,CAAC,CAAC;QAC5B,gBAAW,GAAG,IAAI,YAAY,EAAU,CAAC;QACzC,eAAU,GAAsB,IAAI,YAAY,EAAO,CAAC;QACzD,SAAI,GAAa,KAAK,CAAC;QACvB,qBAAgB,GAAU,EAAE,CAAC;QAC5B,0BAAqB,GAAwC,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;QAC3F,kBAAa,GAAG,IAAI,YAAY,EAAO,CAAC;QACzC,gBAAW,GAAU,EAAE,CAAC;QACxB,+BAA0B,GAAa,KAAK,CAAC;QAC7C,eAAU,GAAY,KAAK,CAAC;QAC3B,gBAAW,GAAG,IAAI,YAAY,EAAU,CAAC;QAC1C,iBAAY,GAAW,EAAE,CAAC;QAC1B,mBAAc,GAAW,EAAE,CAAC;QAC5B,sBAAiB,GAAY,KAAK,CAAC;QAC5C,gBAAW,GAA+B,EAAE,CAAC;QAC7C,gBAAW,GAAY,KAAK,CAAC;QAC7B,kBAAa,GAAY,KAAK,CAAC;QAC/B,aAAQ,GAAY,KAAK,CAAC;QAMxB,gCAAgC;QAChC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,gBAAgB,CAAC,GAAG,IAAI,CAAC;IACjD,CAAC;IAGD,QAAQ;QACN,OAAO,CAAC,GAAG,CAAC,oCAAoC,EAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;QACzE,IAAI,CAAC,gBAAgB,EAAE,CAAA;IACzB,CAAC;IAED,eAAe;QACb,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC;QACvC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAED,gBAAgB;QACd,IAAG,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,EAAE,MAAM,IAAE,CAAC,IAAI,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,IAAI,IAAE,EAAE,EAAC;YAClF,IAAI,CAAC,QAAQ,GAAC,IAAI,CAAC;SACpB;IACH,CAAC;IAED,4BAA4B,CAAC,KAAS;QACpC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED,eAAe,CAAC,KAAa;QAC3B,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;IAC7B,CAAC;IAED,cAAc,CAAC,KAAa;QAC1B,IAAG,IAAI,CAAC,0BAA0B,EAAC;YACjC,MAAM,eAAe,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;YAC1D,MAAM,kBAAkB,GAAG,IAAI,CAAC,qBAAqB,CAAC,yBAAyB,CAAC,eAAe,CAAC,CAAC;YACjG,IAAI,kBAAkB,CAAC,OAAO,EAAE;gBAC9B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAC7B,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;gBAC9B,8CAA8C;gBAC9C,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE;oBAC5B,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC;iBAChC;aACF;SACF;aAAI;YACH,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC7B,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;YAC9B,8CAA8C;YAC9C,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE;gBAC5B,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC;aAChC;SACF;IACH,CAAC;IAED,UAAU;QACR,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC;IAED,YAAY,CAAC,KAAa,EAAE,IAAS;QACnC,OAAO,KAAK,CAAC;IACf,CAAC;IAED,YAAY;QACV,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;IAChD,CAAC;IAED,aAAa;QACZ,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC;IACxD,CAAC;IAED,UAAU,CAAC,SAAiB;QAC1B,MAAM,YAAY,GAAG,QAAQ,CAAC,aAAa,CAAC,UAAU,CAAgB,CAAC;QACvE,IAAI,YAAY,EAAE;YAChB,YAAY,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,SAAS,GAAG,GAAG,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;YACrE,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,aAAa,EAAE,EAAE,GAAG,CAAC,CAAC;SAC7C;IACH,CAAC;IAED,aAAa;QACX,MAAM,YAAY,GAAG,QAAQ,CAAC,aAAa,CAAC,UAAU,CAAgB,CAAC;QACvE,IAAI,YAAY,EAAE;YAChB,IAAI,CAAC,aAAa,GAAG,CAAC,YAAY,CAAC,WAAW,GAAG,YAAY,CAAC,WAAW,CAAC,CAAC;SAC5E;IACH,CAAC;+GAzGY,uBAAuB;mGAAvB,uBAAuB,wjBCRpC,66HAwGA;;4FDhGa,uBAAuB;kBALnC,SAAS;+BACE,qBAAqB;4IAKtB,KAAK;sBAAb,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACI,WAAW;sBAApB,MAAM;gBACG,UAAU;sBAAnB,MAAM;gBACE,IAAI;sBAAZ,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACI,qBAAqB;sBAA9B,KAAK;gBACI,aAAa;sBAAtB,MAAM;gBACE,WAAW;sBAAnB,KAAK;gBACG,0BAA0B;sBAAlC,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACI,WAAW;sBAApB,MAAM;gBACE,YAAY;sBAApB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK","sourcesContent":["import { ChangeDetectorRef, Component, EventEmitter, Input, Output } from '@angular/core';\nimport { FormValidationService } from '../../services/form-validation.service';\n\n@Component({\n  selector: 'lib-navigation-tabs',\n  templateUrl: './navigation-tabs.component.html',\n  styleUrls: ['./navigation-tabs.component.scss'],\n})\nexport class NavigationTabsComponent {\n  @Input() pages: any[] = [];\n  @Input() currentPageIndex: number = 0;\n  @Output() pageChanged = new EventEmitter<number>();\n  @Output() submitEmit: EventEmitter<any> = new EventEmitter<any>();\n  @Input() edit : boolean = false;\n  @Input() acceptedLanguage: string ='';\n  @Input()  eligibleForSubmission:{ status: boolean; message: string } = { status: true, message: '' };\n  @Output() subFormChange = new EventEmitter<any>();\n  @Input() pageDetails: any[] = [];\n  @Input() markAllQuestionsAsRequired : boolean = false;\n  @Input() skipMargin: boolean = false;\n  @Output() rowSetIndex = new EventEmitter<number>();\n  @Input() primaryColor: string = '';\n  @Input() secondaryColor: string = '';\n  @Input() isActionTriggered: boolean = false;\n  loadedPages: { [key: number]: boolean } = {};\n  showTooltip: boolean = false;\n  showNavArrows: boolean = false;\n  hideTabs: boolean = false;\n\n  constructor(\n    private formValidationService: FormValidationService,\n    private cdr: ChangeDetectorRef\n  ) {\n    // Load the first page initially\n    this.loadedPages[this.currentPageIndex] = true;\n  }\n\n\n  ngOnInit() {\n    console.log('skip margin on form navigation tab',this.isActionTriggered);\n    this.checkPageDetails()\n  }\n\n  ngAfterViewInit() {\n    setTimeout(() => this.checkOverflow());\n    this.cdr.detectChanges();\n  }\n\n  checkPageDetails(){\n    if(this.pageDetails && this.pageDetails?.length==1 && this.pageDetails[0]?.name==''){\n      this.hideTabs=true;\n    }\n  }\n\n  updateSubFormWithSubmissions(event:any){\n    this.subFormChange.emit(event);\n  }\n\n  triggerFunction(event: number) {\n    this.setCurrentPage(event); \n  }\n\n  setCurrentPage(index: number) {\n    if(this.markAllQuestionsAsRequired){\n      const currentPageData = this.pages[this.currentPageIndex];\n      const validationResponse = this.formValidationService.validateRequiredQuestions(currentPageData);\n      if (validationResponse.isValid) {\n        this.pageChanged.emit(index);\n        this.currentPageIndex = index;\n        // Mark this page as loaded to avoid reloading\n        if (!this.loadedPages[index]) {\n          this.loadedPages[index] = true;\n        }\n      } \n    }else{\n      this.pageChanged.emit(index);\n      this.currentPageIndex = index;\n      // Mark this page as loaded to avoid reloading\n      if (!this.loadedPages[index]) {\n        this.loadedPages[index] = true;\n      }\n    }\n  }\n\n  submitForm() {\n    this.submitEmit.emit();\n  }\n\n  trackByIndex(index: number, item: any): number {\n    return index;\n  }\n\n  loadMoreData(): void {\n    this.rowSetIndex.emit(this.currentPageIndex);\n }\n\n toggleTooltip() {\n  this.showTooltip = !this.eligibleForSubmission.status;\n}\n\nscrollTabs(direction: number) {\n  const tabContainer = document.querySelector('.navTabs') as HTMLElement;\n  if (tabContainer) {\n    tabContainer.scrollBy({ left: direction * 100, behavior: 'smooth' });\n    setTimeout(() => this.checkOverflow(), 300);\n  }\n}\n\ncheckOverflow() {\n  const tabContainer = document.querySelector('.navTabs') as HTMLElement;\n  if (tabContainer) {\n    this.showNavArrows = (tabContainer.scrollWidth > tabContainer.clientWidth);\n  }\n}\n}\n","<div class=\"tab-inner-container\" [ngClass]=\"{ 'skip-margin': skipMargin}\">\n  <div class=\"d-flex gap-2\">\n    <div class=\"tab-navigation\" *ngIf=\"!hideTabs\">\n      <ul class=\"nav nav-tabs navTabs\" id=\"myTab\" role=\"tablist\">\n        <li\n          class=\"nav-item\"\n          role=\"presentation\"\n          *ngFor=\"let page of pageDetails; let i = index; trackBy: trackByIndex\"\n          [ngClass]=\"{'nav-item-ara': acceptedLanguage === 'ara', 'nav-item-default': acceptedLanguage !== 'ara'}\"\n        >\n          <button\n            class=\"nav-link\"\n            [title]=\"page.name\"\n            data-bs-toggle=\"tooltip\"\n            data-bs-placement=\"top\"\n            data-bs-custom-class=\"custom-tooltip\"\n            [class.active]=\"i === currentPageIndex\"\n            id=\"tab-{{ i }}\"\n            type=\"button\"\n            role=\"tab\"\n            [attr.aria-controls]=\"'content-' + i\"\n            [attr.aria-selected]=\"i === currentPageIndex\"\n            (click)=\"setCurrentPage(i)\"\n          >\n            {{ page.name }}\n          </button>\n        </li>\n      </ul>\n    </div>\n    <div class=\"d-flex align-items-center\" *ngIf=\"showNavArrows\">\n      <button class=\"nav-arrow\">\n        <img src=\"assets/icons/left_arrow.svg\" alt=\"left arrow\"\n        (click)=\"scrollTabs(-1)\">\n        <img src=\"assets/icons/right_arrow.svg\" alt=\"right arrow\"\n        (click)=\"scrollTabs(1)\">\n      </button>\n    </div>\n  </div>\n\n\n\n  <div class=\"tab-content pt-5 pb-3 px-1\" [attr.name]=\"pages[currentPageIndex].testElementName\">\n    <ng-container *ngIf=\"pages[currentPageIndex]\">\n      <div\n        class=\"tab-pane fade show active\"\n        id=\"content-{{ currentPageIndex }}\"\n        role=\"tabpanel\"\n        [attr.aria-labelledby]=\"'tab-' + currentPageIndex\"\n      >\n        <div *ngIf=\"loadedPages[currentPageIndex]\">\n          <div class=\"data-container\"\n          infiniteScroll\n          [infiniteScrollDistance]=\"2\"\n          [infiniteScrollThrottle]=\"200\"\n          (scrolled)=\"loadMoreData()\">\n          <div *ngFor=\"let row of pages[currentPageIndex].rows\">\n            <div class=\"margin d-flex\">\n              <div *ngFor=\"let grid of row.grid\"\n                   [ngStyle]=\"{'width.%': (grid.element.count) * (100 / 12)}\">\n                <lib-form-elements\n                  [grid]=\"grid\"\n                  [edit]=\"edit\"\n                  [acceptedLanguage]=\"acceptedLanguage\"\n                  (subFormChange)=\"updateSubFormWithSubmissions($event)\"\n                ></lib-form-elements>\n              </div>\n            </div>\n          </div>\n          </div>\n          <div class=\"footerButton d-flex justify-content-between align-items-center me-4 ms-4 position-relative\">\n          <!-- Hover detection container -->\n                    <div  [ngStyle]=\"{ display: currentPageIndex === pageDetails.length - 1 ? 'block' : 'none' }\" id=\"captcha-container\"></div>\n          <div\n            class=\"button-container position-relative\"\n            (mouseenter)=\"showTooltip = true\"\n            (mouseleave)=\"showTooltip = false\"\n          >\n\n          <div  *ngIf=\"currentPageIndex == pageDetails.length - 1\">\n            <button\n            *ngIf=\"!isActionTriggered\"\n              class=\"btn rounded-pill submitButton text-white\"\n              [ngStyle]=\"{ 'background-color': primaryColor ? primaryColor: '#084fff' }\"\n              type=\"button\"\n              (click)=\"submitForm()\"\n              [disabled]=\"!eligibleForSubmission.status\"\n            >\n              Submit\n            </button>\n\n            <div *ngIf=\"showTooltip && !eligibleForSubmission.status\" class=\"custom-tooltip\">\n              {{eligibleForSubmission.message}}\n            </div>\n              </div>\n          </div>\n\n        </div>\n\n\n        </div>\n      </div>\n    </ng-container>\n  </div>\n</div>\n"]}
135
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navigation-tabs.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/form-submission/navigation-tabs/navigation-tabs.component.ts","../../../../../projects/form-submission/src/form-submission/navigation-tabs/navigation-tabs.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, EventEmitter, Input, Output } from '@angular/core';\nimport { FormValidationService } from '../../services/form-validation.service';\n\n@Component({\n  selector: 'lib-navigation-tabs',\n  templateUrl: './navigation-tabs.component.html',\n  styleUrls: ['./navigation-tabs.component.scss'],\n})\nexport class NavigationTabsComponent {\n  @Input() pages: any[] = [];\n  @Input() currentPageIndex: number = 0;\n  @Output() pageChanged = new EventEmitter<number>();\n  @Output() submitEmit: EventEmitter<any> = new EventEmitter<any>();\n  @Input() edit : boolean = false;\n  @Input() acceptedLanguage: string ='';\n  @Input()  eligibleForSubmission:{ status: boolean; message: string } = { status: true, message: '' };\n  @Output() subFormChange = new EventEmitter<any>();\n  @Input() pageDetails: any[] = [];\n  @Input() markAllQuestionsAsRequired : boolean = false;\n  @Input() skipMargin: boolean = false;\n  @Output() rowSetIndex = new EventEmitter<number>();\n  @Input() primaryColor: string = '';\n  @Input() secondaryColor: string = '';\n  @Input() isActionTriggered: boolean = false;\n  loadedPages: { [key: number]: boolean } = {};\n  showTooltip: boolean = false;\n  showNavArrows: boolean = false;\n  hideTabs: boolean = false;\n\n  constructor(\n    private formValidationService: FormValidationService,\n    private cdr: ChangeDetectorRef\n  ) {\n    // Load the first page initially\n    this.loadedPages[this.currentPageIndex] = true;\n  }\n\n\n  ngOnInit() {\n    this.checkPageDetails()\n  }\n\n  ngAfterViewInit() {\n    setTimeout(() => this.checkOverflow());\n    this.cdr.detectChanges();\n  }\n\n  checkPageDetails(){\n    if(this.pageDetails && this.pageDetails?.length==1 && this.pageDetails[0]?.name==''){\n      this.hideTabs=true;\n    }\n  }\n\n  updateSubFormWithSubmissions(event:any){\n    this.subFormChange.emit(event);\n  }\n\n  triggerFunction(event: number) {\n    this.setCurrentPage(event); \n  }\n\n  setCurrentPage(index: number) {\n    if(this.markAllQuestionsAsRequired){\n      const currentPageData = this.pages[this.currentPageIndex];\n      const validationResponse = this.formValidationService.validateRequiredQuestions(currentPageData);\n      if (validationResponse.isValid) {\n        this.pageChanged.emit(index);\n        this.currentPageIndex = index;\n        // Mark this page as loaded to avoid reloading\n        if (!this.loadedPages[index]) {\n          this.loadedPages[index] = true;\n        }\n      } \n    }else{\n      this.pageChanged.emit(index);\n      this.currentPageIndex = index;\n      // Mark this page as loaded to avoid reloading\n      if (!this.loadedPages[index]) {\n        this.loadedPages[index] = true;\n      }\n    }\n  }\n\n  submitForm() {\n    this.submitEmit.emit();\n  }\n\n  trackByIndex(index: number, item: any): number {\n    return index;\n  }\n\n  loadMoreData(): void {\n    this.rowSetIndex.emit(this.currentPageIndex);\n }\n\n toggleTooltip() {\n  this.showTooltip = !this.eligibleForSubmission.status;\n}\n\nscrollTabs(direction: number) {\n  const tabContainer = document.querySelector('.navTabs') as HTMLElement;\n  if (tabContainer) {\n    tabContainer.scrollBy({ left: direction * 100, behavior: 'smooth' });\n    setTimeout(() => this.checkOverflow(), 300);\n  }\n}\n\ncheckOverflow() {\n  const tabContainer = document.querySelector('.navTabs') as HTMLElement;\n  if (tabContainer) {\n    this.showNavArrows = (tabContainer.scrollWidth > tabContainer.clientWidth);\n  }\n}\n}\n","<div class=\"tab-inner-container\" [ngClass]=\"{ 'skip-margin': skipMargin}\">\n  <div class=\"d-flex gap-2\">\n    <div class=\"tab-navigation\" *ngIf=\"!hideTabs\">\n      <ul class=\"nav nav-tabs navTabs\" id=\"myTab\" role=\"tablist\">\n        <li\n          class=\"nav-item\"\n          role=\"presentation\"\n          *ngFor=\"let page of pageDetails; let i = index; trackBy: trackByIndex\"\n          [ngClass]=\"{'nav-item-ara': acceptedLanguage === 'ara', 'nav-item-default': acceptedLanguage !== 'ara'}\"\n        >\n          <button\n            class=\"nav-link\"\n            [title]=\"page.name\"\n            data-bs-toggle=\"tooltip\"\n            data-bs-placement=\"top\"\n            data-bs-custom-class=\"custom-tooltip\"\n            [class.active]=\"i === currentPageIndex\"\n            id=\"tab-{{ i }}\"\n            type=\"button\"\n            role=\"tab\"\n            [attr.aria-controls]=\"'content-' + i\"\n            [attr.aria-selected]=\"i === currentPageIndex\"\n            (click)=\"setCurrentPage(i)\"\n          >\n            {{ page.name }}\n          </button>\n        </li>\n      </ul>\n    </div>\n    <div class=\"d-flex align-items-center\" *ngIf=\"showNavArrows\">\n      <button class=\"nav-arrow\">\n        <img src=\"assets/icons/left_arrow.svg\" alt=\"left arrow\"\n        (click)=\"scrollTabs(-1)\">\n        <img src=\"assets/icons/right_arrow.svg\" alt=\"right arrow\"\n        (click)=\"scrollTabs(1)\">\n      </button>\n    </div>\n  </div>\n\n\n\n  <div class=\"tab-content pt-5 pb-3 px-1\" [attr.name]=\"pages[currentPageIndex].testElementName\">\n    <ng-container *ngIf=\"pages[currentPageIndex]\">\n      <div\n        class=\"tab-pane fade show active\"\n        id=\"content-{{ currentPageIndex }}\"\n        role=\"tabpanel\"\n        [attr.aria-labelledby]=\"'tab-' + currentPageIndex\"\n      >\n        <div *ngIf=\"loadedPages[currentPageIndex]\">\n          <div class=\"data-container\"\n          infiniteScroll\n          [infiniteScrollDistance]=\"2\"\n          [infiniteScrollThrottle]=\"200\"\n          (scrolled)=\"loadMoreData()\">\n          <div *ngFor=\"let row of pages[currentPageIndex].rows\">\n            <div class=\"margin d-flex\">\n              <div *ngFor=\"let grid of row.grid\"\n                   [ngStyle]=\"{'width.%': (grid.element.count) * (100 / 12)}\">\n                <lib-form-elements\n                  [grid]=\"grid\"\n                  [edit]=\"edit\"\n                  [acceptedLanguage]=\"acceptedLanguage\"\n                  [pages]=\"pages\"\n                  (subFormChange)=\"updateSubFormWithSubmissions($event)\"\n                ></lib-form-elements>\n              </div>\n            </div>\n          </div>\n          </div>\n          <div class=\"footerButton d-flex justify-content-between align-items-center me-4 ms-4 position-relative\">\n          <!-- Hover detection container -->\n                    <div  [ngStyle]=\"{ display: currentPageIndex === pageDetails.length - 1 ? 'block' : 'none' }\" id=\"captcha-container\"></div>\n          <div\n            class=\"button-container position-relative\"\n            (mouseenter)=\"showTooltip = true\"\n            (mouseleave)=\"showTooltip = false\"\n          >\n\n          <div  *ngIf=\"currentPageIndex == pageDetails.length - 1\">\n            <button\n            *ngIf=\"!isActionTriggered\"\n              class=\"btn rounded-pill submitButton text-white\"\n              [ngStyle]=\"{ 'background-color': primaryColor ? primaryColor: '#084fff' }\"\n              type=\"button\"\n              (click)=\"submitForm()\"\n              [disabled]=\"!eligibleForSubmission.status\"\n            >\n              Submit\n            </button>\n\n            <div *ngIf=\"showTooltip && !eligibleForSubmission.status\" class=\"custom-tooltip\">\n              {{eligibleForSubmission.message}}\n            </div>\n              </div>\n          </div>\n\n        </div>\n\n\n        </div>\n      </div>\n    </ng-container>\n  </div>\n</div>\n"]}
@@ -26,7 +26,6 @@ export class NextPrevNavigationComponent {
26
26
  this.showTooltip = false;
27
27
  }
28
28
  ngOnInit() {
29
- console.log('skip margin on form next prev', this.skipMargin);
30
29
  }
31
30
  updateSubFormWithSubmissions(event) {
32
31
  this.subFormChange.emit(event);
@@ -47,7 +46,7 @@ export class NextPrevNavigationComponent {
47
46
  this.showTooltip = !this.eligibleForSubmission.status;
48
47
  }
49
48
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NextPrevNavigationComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
50
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NextPrevNavigationComponent, selector: "lib-next-prev-navigation", inputs: { currentPageIndex: "currentPageIndex", pages: "pages", previousPage: "previousPage", nextPage: "nextPage", currentPage: "currentPage", pageDetails: "pageDetails", skipMargin: "skipMargin", edit: "edit", acceptedLanguage: "acceptedLanguage", primaryColor: "primaryColor", secondaryColor: "secondaryColor", isActionTriggered: "isActionTriggered", eligibleForSubmission: "eligibleForSubmission" }, outputs: { navigateNext: "navigateNext", navigatePrevious: "navigatePrevious", submitEmit: "submitEmit", subFormChange: "subFormChange", rowSetIndex: "rowSetIndex" }, ngImport: i0, template: "<div class=\"pageTitleDiv\" *ngIf=\"!skipMargin\">\n <p class=\"pageTitle\">{{pageDetails[currentPageIndex]?.name}}</p>\n</div>\n<div class=\"button-inner-container rounded\" [ngClass]=\"{ 'skip-margin': skipMargin}\">\n <div class=\"tab-content pt-5 pb-3 row\" [attr.name]=\"pages[currentPageIndex].testElementName\">\n <div class=\"data-container\"\n infiniteScroll\n [infiniteScrollDistance]=\"2\"\n [infiniteScrollThrottle]=\"200\"\n (scrolled)=\"loadMoreData()\">\n\n <div *ngFor=\"let row of pages[currentPageIndex]?.rows\" class=\"marginSize d-flex\">\n <div *ngFor=\"let grid of row.grid\"\n [ngStyle]=\"{'width.%': (grid.element.count) * (100 / (12))}\">\n <lib-form-elements\n [grid]=\"grid\"\n [currentPageIndex]=\"currentPageIndex\"\n [edit]=\"edit\"\n [acceptedLanguage]=\"acceptedLanguage\"\n (subFormChange)=\"updateSubFormWithSubmissions($event)\"\n state=\"parent\"\n ></lib-form-elements>\n </div>\n </div>\n </div>\n <div [ngStyle]=\"{ display: currentPageIndex === pageDetails.length - 1 ? 'block' : 'none' }\" id=\"captcha-container\"></div>\n\n <div class=\"footerButton\">\n <div\n class=\"prevButtonDiv\"\n [ngClass]=\"{ 'prevDirection-rtl': acceptedLanguage === 'ara' }\">\n <button\n class=\"me-md-2 rounded-pill navButton\"\n [ngStyle]=\"{ 'background-color': primaryColor ? primaryColor: '#084fff' }\"\n type=\"button\"\n (click)=\"onNavigatePrevious()\"\n *ngIf=\"0 < currentPageIndex\"\n >\n <ng-container *ngIf=\"acceptedLanguage === 'ara'; else defaultSvg\">\n <svg\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M19.4897 12.0117L4.49975 12.0117\"\n stroke=\"white\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n <path\n d=\"M13.486 6.02344L19.502 12.0004L13.486 17.9774\"\n stroke=\"white\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n </svg>\n </ng-container>\n <ng-template #defaultSvg>\n <svg\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M4.51025 11.9883L19.5003 11.9883\"\n stroke=\"white\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n <path\n d=\"M10.514 17.9766L4.49805 11.9996L10.514 6.02256\"\n stroke=\"white\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n </svg>\n </ng-template>\n Previous | {{ previousPage.name }}\n </button>\n </div>\n <div\n class=\"nextButtonDiv\"\n [ngClass]=\"{ 'nextDirection-rtl': acceptedLanguage === 'ara' }\"\n >\n <button\n class=\"md-2 rounded-pill navButton\"\n [ngStyle]=\"{ 'background-color': primaryColor ? primaryColor: '#084fff' }\"\n type=\"button\"\n (click)=\"onNavigateNext()\"\n *ngIf=\"currentPageIndex < pageDetails.length - 1\"\n >\n Next | {{ nextPage.name }}\n <ng-container *ngIf=\"acceptedLanguage === 'ara'; else defaultSvg\">\n <svg\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M4.51025 11.9883L19.5003 11.9883\"\n stroke=\"white\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n <path\n d=\"M10.514 17.9766L4.49805 11.9996L10.514 6.02256\"\n stroke=\"white\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n </svg>\n </ng-container>\n <ng-template #defaultSvg>\n <svg\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M19.4897 12.0117L4.49975 12.0117\"\n stroke=\"white\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n <path\n d=\"M13.486 6.02344L19.502 12.0004L13.486 17.9774\"\n stroke=\"white\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n </svg>\n </ng-template>\n </button>\n\n <div\n class=\"button-container position-relative\"\n (mouseenter)=\"showTooltip = true\"\n (mouseleave)=\"showTooltip = false\"\n >\n <button\n class=\"submitBtn ms-md-2 me-md-2 rounded-pill\"\n [ngStyle]=\"{ 'background-color': primaryColor ? primaryColor: '#084fff' }\"\n type=\"button\"\n *ngIf=\"currentPageIndex == pageDetails.length - 1 && !isActionTriggered\"\n (click)=\"submitForm()\"\n [disabled]=\"!eligibleForSubmission.status\"\n >\n Submit\n </button>\n <div *ngIf=\"showTooltip && !eligibleForSubmission.status\" class=\"custom-tooltip\">\n {{eligibleForSubmission.message}}\n </div>\n </div>\n </div>\n </div>\n</div>\n", styles: [".pageTitle{font-size:15px;font-weight:500}#captcha-container{display:flex;justify-content:center;align-items:center;padding-left:1.8rem}.grecaptcha-popup{position:fixed!important;top:50%!important;left:50%!important;transform:translate(-50%,-50%)!important;z-index:9999;border-radius:50%}@media (max-width: 480px){.g-recaptcha{transform:scale(.85);transform-origin:center}}.pageTitleDiv{padding-left:3rem;padding-top:3rem;padding-right:3rem}@media (max-width: 1024px){.pageTitleDiv{padding-left:1rem;padding-right:1rem;padding-top:2rem}}@media (max-width: 576px){.pageTitleDiv{padding-left:.4rem;padding-right:.4rem;padding-top:1.5rem}}.button-inner-container{width:100%;position:relative;padding:0rem 3rem 3rem}@media (max-width: 1024px){.button-inner-container{padding-left:1rem;padding-right:1rem}}@media (max-width: 576px){.button-inner-container{padding:.1rem .5rem 2rem}}.skip-margin{padding:0}@media (max-width: 576px){.marginSize{padding:0!important}}.footerButton{padding:10px 32px 16px 30px;display:flex;flex-wrap:wrap}@media (max-width: 576px){.footerButton{padding-left:20px;padding-right:17px}}.navButton{color:#fff;border:none;padding:10px 8px;width:auto}.submitBtn{color:#fff;border:none;padding:10px 27px;width:auto}.prevButtonDiv{display:flex;justify-content:center;margin-bottom:5px}.nextButtonDiv{display:flex;justify-content:flex-end;margin-left:auto;margin-bottom:5px}.nextDirection-rtl{margin-left:0;margin-right:auto}.tab-content,.row{background-color:#fff}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i2.FormElementsComponent, selector: "lib-form-elements", inputs: ["currentPageIndex", "edit", "acceptedLanguage", "answer", "grid", "state"], outputs: ["subFormChange"] }, { kind: "directive", type: i3.InfiniteScrollDirective, selector: "[infiniteScroll], [infinite-scroll], [data-infinite-scroll]", inputs: ["infiniteScrollDistance", "infiniteScrollUpDistance", "infiniteScrollThrottle", "infiniteScrollDisabled", "infiniteScrollContainer", "scrollWindow", "immediateCheck", "horizontal", "alwaysCallback", "fromRoot"], outputs: ["scrolled", "scrolledUp"] }] }); }
49
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NextPrevNavigationComponent, selector: "lib-next-prev-navigation", inputs: { currentPageIndex: "currentPageIndex", pages: "pages", previousPage: "previousPage", nextPage: "nextPage", currentPage: "currentPage", pageDetails: "pageDetails", skipMargin: "skipMargin", edit: "edit", acceptedLanguage: "acceptedLanguage", primaryColor: "primaryColor", secondaryColor: "secondaryColor", isActionTriggered: "isActionTriggered", eligibleForSubmission: "eligibleForSubmission" }, outputs: { navigateNext: "navigateNext", navigatePrevious: "navigatePrevious", submitEmit: "submitEmit", subFormChange: "subFormChange", rowSetIndex: "rowSetIndex" }, ngImport: i0, template: "<div class=\"pageTitleDiv\" *ngIf=\"!skipMargin\">\n <p class=\"pageTitle\">{{pageDetails[currentPageIndex]?.name}}</p>\n</div>\n<div class=\"button-inner-container rounded\" [ngClass]=\"{ 'skip-margin': skipMargin}\">\n <div class=\"tab-content pt-5 pb-3 row\" [attr.name]=\"pages[currentPageIndex].testElementName\">\n <div class=\"data-container\"\n infiniteScroll\n [infiniteScrollDistance]=\"2\"\n [infiniteScrollThrottle]=\"200\"\n (scrolled)=\"loadMoreData()\">\n\n <div *ngFor=\"let row of pages[currentPageIndex]?.rows\" class=\"marginSize d-flex\">\n <div *ngFor=\"let grid of row.grid\"\n [ngStyle]=\"{'width.%': (grid.element.count) * (100 / (12))}\">\n <lib-form-elements\n [grid]=\"grid\"\n [currentPageIndex]=\"currentPageIndex\"\n [edit]=\"edit\"\n [acceptedLanguage]=\"acceptedLanguage\"\n (subFormChange)=\"updateSubFormWithSubmissions($event)\"\n state=\"parent\"\n ></lib-form-elements>\n </div>\n </div>\n </div>\n <div [ngStyle]=\"{ display: currentPageIndex === pageDetails.length - 1 ? 'block' : 'none' }\" id=\"captcha-container\"></div>\n\n <div class=\"footerButton\">\n <div\n class=\"prevButtonDiv\"\n [ngClass]=\"{ 'prevDirection-rtl': acceptedLanguage === 'ara' }\">\n <button\n class=\"me-md-2 rounded-pill navButton\"\n [ngStyle]=\"{ 'background-color': primaryColor ? primaryColor: '#084fff' }\"\n type=\"button\"\n (click)=\"onNavigatePrevious()\"\n *ngIf=\"0 < currentPageIndex\"\n >\n <ng-container *ngIf=\"acceptedLanguage === 'ara'; else defaultSvg\">\n <svg\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M19.4897 12.0117L4.49975 12.0117\"\n stroke=\"white\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n <path\n d=\"M13.486 6.02344L19.502 12.0004L13.486 17.9774\"\n stroke=\"white\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n </svg>\n </ng-container>\n <ng-template #defaultSvg>\n <svg\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M4.51025 11.9883L19.5003 11.9883\"\n stroke=\"white\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n <path\n d=\"M10.514 17.9766L4.49805 11.9996L10.514 6.02256\"\n stroke=\"white\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n </svg>\n </ng-template>\n Previous | {{ previousPage.name }}\n </button>\n </div>\n <div\n class=\"nextButtonDiv\"\n [ngClass]=\"{ 'nextDirection-rtl': acceptedLanguage === 'ara' }\"\n >\n <button\n class=\"md-2 rounded-pill navButton\"\n [ngStyle]=\"{ 'background-color': primaryColor ? primaryColor: '#084fff' }\"\n type=\"button\"\n (click)=\"onNavigateNext()\"\n *ngIf=\"currentPageIndex < pageDetails.length - 1\"\n >\n Next | {{ nextPage.name }}\n <ng-container *ngIf=\"acceptedLanguage === 'ara'; else defaultSvg\">\n <svg\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M4.51025 11.9883L19.5003 11.9883\"\n stroke=\"white\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n <path\n d=\"M10.514 17.9766L4.49805 11.9996L10.514 6.02256\"\n stroke=\"white\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n </svg>\n </ng-container>\n <ng-template #defaultSvg>\n <svg\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M19.4897 12.0117L4.49975 12.0117\"\n stroke=\"white\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n <path\n d=\"M13.486 6.02344L19.502 12.0004L13.486 17.9774\"\n stroke=\"white\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n </svg>\n </ng-template>\n </button>\n\n <div\n class=\"button-container position-relative\"\n (mouseenter)=\"showTooltip = true\"\n (mouseleave)=\"showTooltip = false\"\n >\n <button\n class=\"submitBtn ms-md-2 me-md-2 rounded-pill\"\n [ngStyle]=\"{ 'background-color': primaryColor ? primaryColor: '#084fff' }\"\n type=\"button\"\n *ngIf=\"currentPageIndex == pageDetails.length - 1 && !isActionTriggered\"\n (click)=\"submitForm()\"\n [disabled]=\"!eligibleForSubmission.status\"\n >\n Submit\n </button>\n <div *ngIf=\"showTooltip && !eligibleForSubmission.status\" class=\"custom-tooltip\">\n {{eligibleForSubmission.message}}\n </div>\n </div>\n </div>\n </div>\n</div>\n", styles: [".pageTitle{font-size:15px;font-weight:500}#captcha-container{display:flex;justify-content:center;align-items:center;padding-left:1.8rem}.grecaptcha-popup{position:fixed!important;top:50%!important;left:50%!important;transform:translate(-50%,-50%)!important;z-index:9999;border-radius:50%}@media (max-width: 480px){.g-recaptcha{transform:scale(.85);transform-origin:center}}.pageTitleDiv{padding-left:3rem;padding-top:3rem;padding-right:3rem}@media (max-width: 1024px){.pageTitleDiv{padding-left:1rem;padding-right:1rem;padding-top:2rem}}@media (max-width: 576px){.pageTitleDiv{padding-left:.4rem;padding-right:.4rem;padding-top:1.5rem}}.button-inner-container{width:100%;position:relative;padding:0rem 3rem 3rem}@media (max-width: 1024px){.button-inner-container{padding-left:1rem;padding-right:1rem}}@media (max-width: 576px){.button-inner-container{padding:.1rem .5rem 2rem}}.skip-margin{padding:0}@media (max-width: 576px){.marginSize{padding:0!important}}.footerButton{padding:10px 32px 16px 30px;display:flex;flex-wrap:wrap}@media (max-width: 576px){.footerButton{padding-left:20px;padding-right:17px}}.navButton{color:#fff;border:none;padding:10px 8px;width:auto}.submitBtn{color:#fff;border:none;padding:10px 27px;width:auto}.prevButtonDiv{display:flex;justify-content:center;margin-bottom:5px}.nextButtonDiv{display:flex;justify-content:flex-end;margin-left:auto;margin-bottom:5px}.nextDirection-rtl{margin-left:0;margin-right:auto}.tab-content,.row{background-color:#fff}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i2.FormElementsComponent, selector: "lib-form-elements", inputs: ["currentPageIndex", "edit", "acceptedLanguage", "answer", "grid", "state", "pages"], outputs: ["subFormChange"] }, { kind: "directive", type: i3.InfiniteScrollDirective, selector: "[infiniteScroll], [infinite-scroll], [data-infinite-scroll]", inputs: ["infiniteScrollDistance", "infiniteScrollUpDistance", "infiniteScrollThrottle", "infiniteScrollDisabled", "infiniteScrollContainer", "scrollWindow", "immediateCheck", "horizontal", "alwaysCallback", "fromRoot"], outputs: ["scrolled", "scrolledUp"] }] }); }
51
50
  }
52
51
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NextPrevNavigationComponent, decorators: [{
53
52
  type: Component,
@@ -89,4 +88,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
89
88
  }], eligibleForSubmission: [{
90
89
  type: Input
91
90
  }] } });
92
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"next-prev-navigation.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/form-submission/next-prev-navigation/next-prev-navigation.component.ts","../../../../../projects/form-submission/src/form-submission/next-prev-navigation/next-prev-navigation.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;;;;;AAOvE,MAAM,OAAO,2BAA2B;IALxC;QAOW,qBAAgB,GAAW,CAAC,CAAC;QAC7B,UAAK,GAAU,EAAE,CAAC;QAClB,iBAAY,GAAQ,EAAE,CAAC;QACvB,aAAQ,GAAQ,EAAE,CAAC;QACnB,gBAAW,GAAQ,EAAE,CAAC;QACtB,gBAAW,GAAU,EAAE,CAAC;QACxB,eAAU,GAAY,KAAK,CAAC;QAC3B,iBAAY,GAAG,IAAI,YAAY,EAAQ,CAAC;QACxC,qBAAgB,GAAG,IAAI,YAAY,EAAQ,CAAC;QAC5C,eAAU,GAAsB,IAAI,YAAY,EAAO,CAAC;QACzD,SAAI,GAAY,KAAK,CAAC;QACtB,qBAAgB,GAAU,EAAE,CAAC;QAC5B,kBAAa,GAAG,IAAI,YAAY,EAAO,CAAC;QACxC,gBAAW,GAAG,IAAI,YAAY,EAAU,CAAC;QAC1C,iBAAY,GAAW,EAAE,CAAC;QAC1B,mBAAc,GAAW,EAAE,CAAC;QAC5B,sBAAiB,GAAY,KAAK,CAAC;QAClC,0BAAqB,GAAwC,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;QACrG,gBAAW,GAAY,KAAK,CAAC;KA6B9B;IA5BC,QAAQ;QACN,OAAO,CAAC,GAAG,CAAC,+BAA+B,EAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC/D,CAAC;IAGD,4BAA4B,CAAC,KAAU;QACrC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC;IAC/B,CAAC;IAED,UAAU;QACR,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC;IAED,YAAY;QACV,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;IAChD,CAAC;IAEA,aAAa;QACb,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC;IACxD,CAAC;+GAhDY,2BAA2B;mGAA3B,2BAA2B,2nBCPxC,o3LAqKA;;4FD9Ja,2BAA2B;kBALvC,SAAS;+BACE,0BAA0B;8BAM3B,gBAAgB;sBAAxB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACI,YAAY;sBAArB,MAAM;gBACG,gBAAgB;sBAAzB,MAAM;gBACG,UAAU;sBAAnB,MAAM;gBACE,IAAI;sBAAZ,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACI,aAAa;sBAAtB,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACE,YAAY;sBAApB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACI,qBAAqB;sBAA9B,KAAK","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\n\n@Component({\n  selector: 'lib-next-prev-navigation',\n  templateUrl: './next-prev-navigation.component.html',\n  styleUrls: ['./next-prev-navigation.component.scss']\n})\nexport class NextPrevNavigationComponent {\n\n  @Input() currentPageIndex: number = 0;\n  @Input() pages: any[] = [];\n  @Input() previousPage: any = {};\n  @Input() nextPage: any = {};\n  @Input() currentPage: any = {};\n  @Input() pageDetails: any[] = [];\n  @Input() skipMargin: boolean = false;\n  @Output() navigateNext = new EventEmitter<void>();\n  @Output() navigatePrevious = new EventEmitter<void>();\n  @Output() submitEmit: EventEmitter<any> = new EventEmitter<any>();\n  @Input() edit: boolean = false;\n  @Input() acceptedLanguage: string ='';\n  @Output() subFormChange = new EventEmitter<any>();\n  @Output() rowSetIndex = new EventEmitter<number>();\n  @Input() primaryColor: string = '';\n  @Input() secondaryColor: string = '';\n  @Input() isActionTriggered: boolean = false;\n  @Input()  eligibleForSubmission:{ status: boolean; message: string } = { status: true, message: '' };\n  showTooltip: boolean = false;\n  ngOnInit(){\n    console.log('skip margin on form next prev',this.skipMargin);\n  }\n\n\n  updateSubFormWithSubmissions(event: any) {\n    this.subFormChange.emit(event);\n  }\n\n  onNavigateNext() {\n    this.navigateNext.emit();\n  }\n\n  onNavigatePrevious() {\n    this.navigatePrevious.emit();\n  }\n\n  submitForm() {\n    this.submitEmit.emit();\n  }\n\n  loadMoreData(): void {\n    this.rowSetIndex.emit(this.currentPageIndex);\n }\n\n  toggleTooltip() {\n  this.showTooltip = !this.eligibleForSubmission.status;\n}\n}\n","<div class=\"pageTitleDiv\" *ngIf=\"!skipMargin\">\n  <p class=\"pageTitle\">{{pageDetails[currentPageIndex]?.name}}</p>\n</div>\n<div class=\"button-inner-container rounded\" [ngClass]=\"{ 'skip-margin': skipMargin}\">\n  <div class=\"tab-content pt-5 pb-3 row\" [attr.name]=\"pages[currentPageIndex].testElementName\">\n    <div class=\"data-container\"\n    infiniteScroll\n    [infiniteScrollDistance]=\"2\"\n    [infiniteScrollThrottle]=\"200\"\n    (scrolled)=\"loadMoreData()\">\n\n    <div *ngFor=\"let row of pages[currentPageIndex]?.rows\" class=\"marginSize d-flex\">\n      <div *ngFor=\"let grid of row.grid\"\n      [ngStyle]=\"{'width.%': (grid.element.count) * (100 / (12))}\">\n        <lib-form-elements\n          [grid]=\"grid\"\n          [currentPageIndex]=\"currentPageIndex\"\n          [edit]=\"edit\"\n          [acceptedLanguage]=\"acceptedLanguage\"\n          (subFormChange)=\"updateSubFormWithSubmissions($event)\"\n          state=\"parent\"\n        ></lib-form-elements>\n      </div>\n    </div>\n    </div>\n   <div [ngStyle]=\"{ display: currentPageIndex === pageDetails.length - 1 ? 'block' : 'none' }\" id=\"captcha-container\"></div>\n\n    <div class=\"footerButton\">\n      <div\n        class=\"prevButtonDiv\"\n        [ngClass]=\"{ 'prevDirection-rtl': acceptedLanguage === 'ara' }\">\n        <button\n          class=\"me-md-2 rounded-pill navButton\"\n          [ngStyle]=\"{ 'background-color': primaryColor ? primaryColor: '#084fff' }\"\n          type=\"button\"\n          (click)=\"onNavigatePrevious()\"\n          *ngIf=\"0 < currentPageIndex\"\n        >\n          <ng-container *ngIf=\"acceptedLanguage === 'ara'; else defaultSvg\">\n            <svg\n              width=\"24\"\n              height=\"24\"\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n              xmlns=\"http://www.w3.org/2000/svg\"\n            >\n              <path\n                d=\"M19.4897 12.0117L4.49975 12.0117\"\n                stroke=\"white\"\n                stroke-linecap=\"round\"\n                stroke-linejoin=\"round\"\n              />\n              <path\n                d=\"M13.486 6.02344L19.502 12.0004L13.486 17.9774\"\n                stroke=\"white\"\n                stroke-linecap=\"round\"\n                stroke-linejoin=\"round\"\n              />\n            </svg>\n          </ng-container>\n          <ng-template #defaultSvg>\n            <svg\n              width=\"24\"\n              height=\"24\"\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n              xmlns=\"http://www.w3.org/2000/svg\"\n            >\n              <path\n                d=\"M4.51025 11.9883L19.5003 11.9883\"\n                stroke=\"white\"\n                stroke-linecap=\"round\"\n                stroke-linejoin=\"round\"\n              />\n              <path\n                d=\"M10.514 17.9766L4.49805 11.9996L10.514 6.02256\"\n                stroke=\"white\"\n                stroke-linecap=\"round\"\n                stroke-linejoin=\"round\"\n              />\n            </svg>\n          </ng-template>\n          Previous | {{ previousPage.name }}\n        </button>\n      </div>\n      <div\n        class=\"nextButtonDiv\"\n        [ngClass]=\"{ 'nextDirection-rtl': acceptedLanguage === 'ara' }\"\n      >\n        <button\n          class=\"md-2 rounded-pill navButton\"\n          [ngStyle]=\"{ 'background-color': primaryColor ? primaryColor: '#084fff' }\"\n          type=\"button\"\n          (click)=\"onNavigateNext()\"\n          *ngIf=\"currentPageIndex < pageDetails.length - 1\"\n        >\n          Next | {{ nextPage.name }}\n          <ng-container *ngIf=\"acceptedLanguage === 'ara'; else defaultSvg\">\n            <svg\n              width=\"24\"\n              height=\"24\"\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n              xmlns=\"http://www.w3.org/2000/svg\"\n            >\n              <path\n                d=\"M4.51025 11.9883L19.5003 11.9883\"\n                stroke=\"white\"\n                stroke-linecap=\"round\"\n                stroke-linejoin=\"round\"\n              />\n              <path\n                d=\"M10.514 17.9766L4.49805 11.9996L10.514 6.02256\"\n                stroke=\"white\"\n                stroke-linecap=\"round\"\n                stroke-linejoin=\"round\"\n              />\n            </svg>\n          </ng-container>\n          <ng-template #defaultSvg>\n            <svg\n              width=\"24\"\n              height=\"24\"\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n              xmlns=\"http://www.w3.org/2000/svg\"\n            >\n              <path\n                d=\"M19.4897 12.0117L4.49975 12.0117\"\n                stroke=\"white\"\n                stroke-linecap=\"round\"\n                stroke-linejoin=\"round\"\n              />\n              <path\n                d=\"M13.486 6.02344L19.502 12.0004L13.486 17.9774\"\n                stroke=\"white\"\n                stroke-linecap=\"round\"\n                stroke-linejoin=\"round\"\n              />\n            </svg>\n          </ng-template>\n        </button>\n\n  <div\n            class=\"button-container position-relative\"\n            (mouseenter)=\"showTooltip = true\"\n            (mouseleave)=\"showTooltip = false\"\n          >\n        <button\n          class=\"submitBtn ms-md-2 me-md-2 rounded-pill\"\n          [ngStyle]=\"{ 'background-color': primaryColor ? primaryColor: '#084fff' }\"\n          type=\"button\"\n          *ngIf=\"currentPageIndex == pageDetails.length - 1 && !isActionTriggered\"\n          (click)=\"submitForm()\"\n            [disabled]=\"!eligibleForSubmission.status\"\n        >\n          Submit\n        </button>\n           <div *ngIf=\"showTooltip && !eligibleForSubmission.status\" class=\"custom-tooltip\">\n              {{eligibleForSubmission.message}}\n            </div>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
91
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"next-prev-navigation.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/form-submission/next-prev-navigation/next-prev-navigation.component.ts","../../../../../projects/form-submission/src/form-submission/next-prev-navigation/next-prev-navigation.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;;;;;AAOvE,MAAM,OAAO,2BAA2B;IALxC;QAOW,qBAAgB,GAAW,CAAC,CAAC;QAC7B,UAAK,GAAU,EAAE,CAAC;QAClB,iBAAY,GAAQ,EAAE,CAAC;QACvB,aAAQ,GAAQ,EAAE,CAAC;QACnB,gBAAW,GAAQ,EAAE,CAAC;QACtB,gBAAW,GAAU,EAAE,CAAC;QACxB,eAAU,GAAY,KAAK,CAAC;QAC3B,iBAAY,GAAG,IAAI,YAAY,EAAQ,CAAC;QACxC,qBAAgB,GAAG,IAAI,YAAY,EAAQ,CAAC;QAC5C,eAAU,GAAsB,IAAI,YAAY,EAAO,CAAC;QACzD,SAAI,GAAY,KAAK,CAAC;QACtB,qBAAgB,GAAU,EAAE,CAAC;QAC5B,kBAAa,GAAG,IAAI,YAAY,EAAO,CAAC;QACxC,gBAAW,GAAG,IAAI,YAAY,EAAU,CAAC;QAC1C,iBAAY,GAAW,EAAE,CAAC;QAC1B,mBAAc,GAAW,EAAE,CAAC;QAC5B,sBAAiB,GAAY,KAAK,CAAC;QAClC,0BAAqB,GAAwC,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;QACrG,gBAAW,GAAY,KAAK,CAAC;KA4B9B;IA3BC,QAAQ;IACR,CAAC;IAGD,4BAA4B,CAAC,KAAU;QACrC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC;IAC/B,CAAC;IAED,UAAU;QACR,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC;IAED,YAAY;QACV,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;IAChD,CAAC;IAEA,aAAa;QACb,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC;IACxD,CAAC;+GA/CY,2BAA2B;mGAA3B,2BAA2B,2nBCPxC,o3LAqKA;;4FD9Ja,2BAA2B;kBALvC,SAAS;+BACE,0BAA0B;8BAM3B,gBAAgB;sBAAxB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACI,YAAY;sBAArB,MAAM;gBACG,gBAAgB;sBAAzB,MAAM;gBACG,UAAU;sBAAnB,MAAM;gBACE,IAAI;sBAAZ,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACI,aAAa;sBAAtB,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACE,YAAY;sBAApB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACI,qBAAqB;sBAA9B,KAAK","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\n\n@Component({\n  selector: 'lib-next-prev-navigation',\n  templateUrl: './next-prev-navigation.component.html',\n  styleUrls: ['./next-prev-navigation.component.scss']\n})\nexport class NextPrevNavigationComponent {\n\n  @Input() currentPageIndex: number = 0;\n  @Input() pages: any[] = [];\n  @Input() previousPage: any = {};\n  @Input() nextPage: any = {};\n  @Input() currentPage: any = {};\n  @Input() pageDetails: any[] = [];\n  @Input() skipMargin: boolean = false;\n  @Output() navigateNext = new EventEmitter<void>();\n  @Output() navigatePrevious = new EventEmitter<void>();\n  @Output() submitEmit: EventEmitter<any> = new EventEmitter<any>();\n  @Input() edit: boolean = false;\n  @Input() acceptedLanguage: string ='';\n  @Output() subFormChange = new EventEmitter<any>();\n  @Output() rowSetIndex = new EventEmitter<number>();\n  @Input() primaryColor: string = '';\n  @Input() secondaryColor: string = '';\n  @Input() isActionTriggered: boolean = false;\n  @Input()  eligibleForSubmission:{ status: boolean; message: string } = { status: true, message: '' };\n  showTooltip: boolean = false;\n  ngOnInit(){\n  }\n\n\n  updateSubFormWithSubmissions(event: any) {\n    this.subFormChange.emit(event);\n  }\n\n  onNavigateNext() {\n    this.navigateNext.emit();\n  }\n\n  onNavigatePrevious() {\n    this.navigatePrevious.emit();\n  }\n\n  submitForm() {\n    this.submitEmit.emit();\n  }\n\n  loadMoreData(): void {\n    this.rowSetIndex.emit(this.currentPageIndex);\n }\n\n  toggleTooltip() {\n  this.showTooltip = !this.eligibleForSubmission.status;\n}\n}\n","<div class=\"pageTitleDiv\" *ngIf=\"!skipMargin\">\n  <p class=\"pageTitle\">{{pageDetails[currentPageIndex]?.name}}</p>\n</div>\n<div class=\"button-inner-container rounded\" [ngClass]=\"{ 'skip-margin': skipMargin}\">\n  <div class=\"tab-content pt-5 pb-3 row\" [attr.name]=\"pages[currentPageIndex].testElementName\">\n    <div class=\"data-container\"\n    infiniteScroll\n    [infiniteScrollDistance]=\"2\"\n    [infiniteScrollThrottle]=\"200\"\n    (scrolled)=\"loadMoreData()\">\n\n    <div *ngFor=\"let row of pages[currentPageIndex]?.rows\" class=\"marginSize d-flex\">\n      <div *ngFor=\"let grid of row.grid\"\n      [ngStyle]=\"{'width.%': (grid.element.count) * (100 / (12))}\">\n        <lib-form-elements\n          [grid]=\"grid\"\n          [currentPageIndex]=\"currentPageIndex\"\n          [edit]=\"edit\"\n          [acceptedLanguage]=\"acceptedLanguage\"\n          (subFormChange)=\"updateSubFormWithSubmissions($event)\"\n          state=\"parent\"\n        ></lib-form-elements>\n      </div>\n    </div>\n    </div>\n   <div [ngStyle]=\"{ display: currentPageIndex === pageDetails.length - 1 ? 'block' : 'none' }\" id=\"captcha-container\"></div>\n\n    <div class=\"footerButton\">\n      <div\n        class=\"prevButtonDiv\"\n        [ngClass]=\"{ 'prevDirection-rtl': acceptedLanguage === 'ara' }\">\n        <button\n          class=\"me-md-2 rounded-pill navButton\"\n          [ngStyle]=\"{ 'background-color': primaryColor ? primaryColor: '#084fff' }\"\n          type=\"button\"\n          (click)=\"onNavigatePrevious()\"\n          *ngIf=\"0 < currentPageIndex\"\n        >\n          <ng-container *ngIf=\"acceptedLanguage === 'ara'; else defaultSvg\">\n            <svg\n              width=\"24\"\n              height=\"24\"\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n              xmlns=\"http://www.w3.org/2000/svg\"\n            >\n              <path\n                d=\"M19.4897 12.0117L4.49975 12.0117\"\n                stroke=\"white\"\n                stroke-linecap=\"round\"\n                stroke-linejoin=\"round\"\n              />\n              <path\n                d=\"M13.486 6.02344L19.502 12.0004L13.486 17.9774\"\n                stroke=\"white\"\n                stroke-linecap=\"round\"\n                stroke-linejoin=\"round\"\n              />\n            </svg>\n          </ng-container>\n          <ng-template #defaultSvg>\n            <svg\n              width=\"24\"\n              height=\"24\"\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n              xmlns=\"http://www.w3.org/2000/svg\"\n            >\n              <path\n                d=\"M4.51025 11.9883L19.5003 11.9883\"\n                stroke=\"white\"\n                stroke-linecap=\"round\"\n                stroke-linejoin=\"round\"\n              />\n              <path\n                d=\"M10.514 17.9766L4.49805 11.9996L10.514 6.02256\"\n                stroke=\"white\"\n                stroke-linecap=\"round\"\n                stroke-linejoin=\"round\"\n              />\n            </svg>\n          </ng-template>\n          Previous | {{ previousPage.name }}\n        </button>\n      </div>\n      <div\n        class=\"nextButtonDiv\"\n        [ngClass]=\"{ 'nextDirection-rtl': acceptedLanguage === 'ara' }\"\n      >\n        <button\n          class=\"md-2 rounded-pill navButton\"\n          [ngStyle]=\"{ 'background-color': primaryColor ? primaryColor: '#084fff' }\"\n          type=\"button\"\n          (click)=\"onNavigateNext()\"\n          *ngIf=\"currentPageIndex < pageDetails.length - 1\"\n        >\n          Next | {{ nextPage.name }}\n          <ng-container *ngIf=\"acceptedLanguage === 'ara'; else defaultSvg\">\n            <svg\n              width=\"24\"\n              height=\"24\"\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n              xmlns=\"http://www.w3.org/2000/svg\"\n            >\n              <path\n                d=\"M4.51025 11.9883L19.5003 11.9883\"\n                stroke=\"white\"\n                stroke-linecap=\"round\"\n                stroke-linejoin=\"round\"\n              />\n              <path\n                d=\"M10.514 17.9766L4.49805 11.9996L10.514 6.02256\"\n                stroke=\"white\"\n                stroke-linecap=\"round\"\n                stroke-linejoin=\"round\"\n              />\n            </svg>\n          </ng-container>\n          <ng-template #defaultSvg>\n            <svg\n              width=\"24\"\n              height=\"24\"\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n              xmlns=\"http://www.w3.org/2000/svg\"\n            >\n              <path\n                d=\"M19.4897 12.0117L4.49975 12.0117\"\n                stroke=\"white\"\n                stroke-linecap=\"round\"\n                stroke-linejoin=\"round\"\n              />\n              <path\n                d=\"M13.486 6.02344L19.502 12.0004L13.486 17.9774\"\n                stroke=\"white\"\n                stroke-linecap=\"round\"\n                stroke-linejoin=\"round\"\n              />\n            </svg>\n          </ng-template>\n        </button>\n\n  <div\n            class=\"button-container position-relative\"\n            (mouseenter)=\"showTooltip = true\"\n            (mouseleave)=\"showTooltip = false\"\n          >\n        <button\n          class=\"submitBtn ms-md-2 me-md-2 rounded-pill\"\n          [ngStyle]=\"{ 'background-color': primaryColor ? primaryColor: '#084fff' }\"\n          type=\"button\"\n          *ngIf=\"currentPageIndex == pageDetails.length - 1 && !isActionTriggered\"\n          (click)=\"submitForm()\"\n            [disabled]=\"!eligibleForSubmission.status\"\n        >\n          Submit\n        </button>\n           <div *ngIf=\"showTooltip && !eligibleForSubmission.status\" class=\"custom-tooltip\">\n              {{eligibleForSubmission.message}}\n            </div>\n      </div>\n    </div>\n  </div>\n</div>\n"]}