@piserve-tech/form-submission 1.3.232 → 1.3.234

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.
@@ -64,19 +64,26 @@ export class MobileFieldsComponent {
64
64
  initializeAnswer(param) {
65
65
  let countryCode;
66
66
  let mobileNumber;
67
- if (param === 'answer' && this.question?.answer) {
68
- [countryCode, mobileNumber] = this.question.answer.split(' ');
67
+ const value = param === 'answer' && this.question?.answer
68
+ ? this.question.answer
69
+ : this.question?.defaultValue;
70
+ if (this.displayCountryCode) {
71
+ // Expect "countryCode mobileNumber"
72
+ [countryCode, mobileNumber] = (value || '').split(' ');
69
73
  }
70
74
  else {
71
- [countryCode, mobileNumber] = this.question.defaultValue.split(' ');
75
+ // Only mobile number present
76
+ mobileNumber = value || '';
72
77
  }
73
78
  this.mobileNumber = mobileNumber || '';
74
- if (!this.selectedCountry) {
75
- this.selectedCountry = [];
76
- }
77
- const matchedCountry = this.countryDetails.find((country) => country.value === countryCode);
78
- if (matchedCountry) {
79
- this.selectedCountry.push(matchedCountry);
79
+ if (this.displayCountryCode) {
80
+ if (!this.selectedCountry) {
81
+ this.selectedCountry = [];
82
+ }
83
+ const matchedCountry = this.countryDetails.find((country) => country.value === countryCode);
84
+ if (matchedCountry) {
85
+ this.selectedCountry = [matchedCountry];
86
+ }
80
87
  }
81
88
  }
82
89
  onCountryChange() {
@@ -128,7 +135,7 @@ export class MobileFieldsComponent {
128
135
  this.updateAnswer();
129
136
  }
130
137
  }
131
- loadCountry(id, currentPage, size, searchKey) {
138
+ loadCountry(id, currentPage, size, searchKey, isSearch = false) {
132
139
  this.countryService.loadCountryDetails(this.questionId, currentPage, size, searchKey).subscribe((data) => {
133
140
  if (this.totalPages === 0) {
134
141
  this.totalPages = data.result.totalPages;
@@ -148,10 +155,10 @@ export class MobileFieldsComponent {
148
155
  ...this.countryDetails
149
156
  ];
150
157
  }
151
- if (this.defaultValue) {
158
+ if (this.defaultValue && !isSearch) {
152
159
  this.initializeAnswer('default');
153
160
  }
154
- if (this.question.answer) {
161
+ if (this.question.answer && !isSearch) {
155
162
  this.initializeAnswer('answer');
156
163
  }
157
164
  });
@@ -185,11 +192,11 @@ export class MobileFieldsComponent {
185
192
  }
186
193
  search(searchTerm) {
187
194
  if (searchTerm == '') {
188
- this.loadCountry(this.questionId, this.currentPage, this.size, "");
195
+ this.loadCountry(this.questionId, this.currentPage, this.size, "", true);
189
196
  }
190
197
  else {
191
198
  this.countryDetails = [];
192
- this.loadCountry(this.questionId, this.currentPage, this.size, searchTerm);
199
+ this.loadCountry(this.questionId, this.currentPage, this.size, searchTerm, true);
193
200
  }
194
201
  }
195
202
  handleValidation(isValid, message = 'This field is required') {
@@ -228,4 +235,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
228
235
  }], answerChange: [{
229
236
  type: Output
230
237
  }] } });
231
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mobile-fields.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/form-fields/mobile-fields/mobile-fields.component.ts","../../../../../projects/form-submission/src/form-fields/mobile-fields/mobile-fields.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { CountryService } from '../../services/countryService';\nimport { ElementTrackerService } from '../../services/element-tracker.service';\nimport { ValidationService } from '../../services/validation.service';\n\ninterface CountryData {\n  value: string;\n  label: string;\n  image: string;\n}\n\n@Component({\n  selector: 'lib-mobile-fields',\n  templateUrl: './mobile-fields.component.html',\n  styleUrls: ['./mobile-fields.component.scss'],\n})\nexport class MobileFieldsComponent implements OnInit {\n  @Input() question: any = {};\n  @Input() inLine: boolean = false;\n  @Output() answerChange = new EventEmitter<{ answer: any; maxPossibleScore?: number }>();\n\n  count: number = 0;\n  required: boolean = false;\n  hint: string = '';\n  placeholder: string = '';\n  displayCountryCode: boolean = true;\n  displayFlag: boolean = true;\n  displayCode: boolean = true;\n  showCountryName: boolean = true;\n  beautifyNumbers: boolean = true;\n  countryWiseValidation: boolean = true;\n  countryDetails: CountryData[] = [];\n  selectedCountry: CountryData[] = [];\n  validationFailed: boolean = false;\n  validationMessage: string = '';\n  mobileNumber: string = '';\n  questionId: string = '';\n  currentPage: number = 0;\n  size: number = 30;\n  totalPages: number = 0;\n  searchKey: string = '';\n  lastPage:boolean=false;\n  isFirstPage: boolean = false;\n  defaultValue: string = '';\n  disableEdit: boolean = false;\n\n private elementId: string='';\n\n  constructor(\n    private countryService: CountryService,\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.displayCountryCode =\n      this.question.formElement.appearance.displayCountryCode;\n    this.displayFlag = this.question.formElement.appearance.displayFlag;\n    this.displayCode = this.question.formElement.appearance.displayCode;\n    this.showCountryName = this.question.formElement.appearance.showCountryName;\n    this.beautifyNumbers = this.question.formElement.appearance.beautifyNumbers;\n    this.countryWiseValidation =\n      this.question.formElement.validation.countryWiseValidation;\n    this.questionId = this.question.id;\n    this.defaultValue = this.question?.defaultValue;\n    this.disableEdit = this.question.disableEdit;\n    this.loadCountry(this.questionId, this.currentPage, this.size, this.searchKey);\n  }\n\n\n  initializeAnswer(param?: string): void {\n    let countryCode: string | undefined;\n    let mobileNumber: string | undefined;\n  \n    if (param === 'answer' && this.question?.answer) {\n      [countryCode, mobileNumber] = this.question.answer.split(' ');\n    }else{\n      [countryCode, mobileNumber] = this.question.defaultValue.split(' ');\n    }\n  \n    this.mobileNumber = mobileNumber || '';\n  \n    if (!this.selectedCountry) {\n      this.selectedCountry = [];\n    }\n  \n    const matchedCountry = this.countryDetails.find(\n      (country) => country.value === countryCode\n    );\n  \n    if (matchedCountry) {\n      this.selectedCountry.push(matchedCountry);\n    }\n  }\n\n  onCountryChange() {\n    this.validationFailed = false;\n    this.validationMessage = '';\n    this.updateAnswer();\n  }\n\n  onInput(event: Event) {\n    this.validationService.clearInvalid(this.question.id);\n    const input = event.target as HTMLInputElement;\n  \n    // Regular expression to allow only numbers and multiple hyphens, but ensure only one hyphen between numbers\n    const regex = /^(\\d+)(-\\d+)*$/;\n  \n    if (!regex.test(input.value)) {\n      // Remove invalid characters\n      input.value = input.value.replace(/[^\\d-]/g, '');\n  \n      // Ensure only one hyphen is present between numbers\n      input.value = input.value\n        .split('-')\n        .filter((segment, index, array) => segment || index === 0 || index === array.length - 1)\n        .join('-');\n    }\n  \n    // Update the model\n    this.mobileNumber = input.value;\n    \n    this.updateAnswer();\n  }\n  onMobileNumberChange() {\n  }\n\n  updateAnswer() {  \n    if(this.displayCountryCode){\n      if (this.selectedCountry.length > 0 && this.mobileNumber) {\n        const countryCode = this.selectedCountry[0].value;\n        this.question.answer = `${countryCode} ${this.mobileNumber}`;\n      }\n    }else {\n      this.question.answer = this.mobileNumber;\n    }\n    this.answerChange.emit({answer:this.question.answer,maxPossibleScore:0});\n  }\n\n  validateMobile() {\n    this.validationFailed = false;\n    this.validationMessage = '';\n  \n    if (this.required && (!this.mobileNumber || (this.displayCountryCode && this.selectedCountry.length === 0))) {\n      this.validationFailed = true;\n      this.validationService.clearInvalid(this.question.id);\n      this.validationMessage = 'This is a required question';\n    } else {\n      this.updateAnswer();\n    }\n  }\n\n  loadCountry(id: string, currentPage: number, size: number, searchKey: string) {\n    this.countryService.loadCountryDetails(this.questionId, currentPage, size, searchKey).subscribe((data) => {\n      if (this.totalPages === 0) {\n        this.totalPages = data.result.totalPages;\n      }\n      this.lastPage=data.result.last;\n      this.isFirstPage = data.result.first;\n      let newCountries=this.countryService.processCountryDetails(\n        data.result.content,\n        this.displayFlag,\n        this.displayCode,\n        this.showCountryName\n      )      \n\n      if (this.currentPage > 0) {\n        this.countryDetails = [\n          ...this.countryDetails,\n          ...newCountries.filter(item => !this.countryDetails.some((existing: any) => existing.value === item.value))\n          ];\n      } else {\n        this.countryDetails = [\n          ...newCountries.filter(item => !this.countryDetails.some((existing: any) => existing.value === item.value)),\n          ...this.countryDetails\n          ];\n      }\n      if(this.defaultValue){\n        this.initializeAnswer('default')\n      }\n      if (this.question.answer) {\n        this.initializeAnswer('answer');\n      }\n    });\n\n  }\n\n  getNextSetOfItems(event: any) {\n    const element = event.target;\n    if(!this.lastPage){\n      if (Math.floor(element.scrollHeight - element.scrollTop) <= element.clientHeight) {\n        this.loadMoreData();\n      }\n    }\n    if (!this.isFirstPage && element.scrollTop <= 150) {\n      this.loadPreviousData();\n    }\n  }\n\n  loadMoreData() {\n    setTimeout(() => {\n      this.currentPage++;\n      if (this.currentPage >= 0) {\n        this.loadCountry(this.questionId,this.currentPage, this.size, \"\");\n      }\n    }, 0);\n  }\n\n  loadPreviousData() {\n    setTimeout(() => {\n      this.currentPage--;\n      if (this.currentPage >= 0) {\n        this.loadCountry(this.questionId,this.currentPage, this.size, \"\");\n      }\n    }, 0);\n  }\n\n  search(searchTerm: any) {\n    if (searchTerm == '') {\n      this.loadCountry(this.questionId,this.currentPage, this.size, \"\");\n    }\n    else {\n      this.countryDetails = []; \n      this.loadCountry(this.questionId,this.currentPage, this.size, searchTerm);\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}\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  <div class=\"input-group mb-2\">\n    <ng-container *ngIf=\"displayCountryCode; else fullWidthInput\">\n      <div class=\"col-xs-5 col-5 col-md-3 px-0 pe-2 ps-2\"\n      [ngClass]=\"{'disable':disableEdit}\">\n        <lib-dropdown\n          [items]=\"countryDetails\"\n          [multiple]=\"false\"\n          [(selectedItems)]=\"selectedCountry\"\n          (selectedItemsChange)=\"onCountryChange()\"\n          (onDropdownScroll)=\"getNextSetOfItems($event)\"\n          (onSearch)=\"search($event)\"\n        ></lib-dropdown>\n      </div>\n      <input\n        type=\"text\"\n        class=\"form-control col-xs-7 col-7 col-md-9 height mobileField\"\n        [placeholder]=\"placeholder\"\n        aria-label=\"Mobile Number\"\n        (blur)=\"validateMobile()\"\n        [(ngModel)]=\"mobileNumber\"\n        (ngModelChange)=\"onMobileNumberChange()\"\n        (input)=\"onInput($event)\"\n        [disabled]=\"disableEdit\"\n      />\n    </ng-container>\n\n    <!-- Full-width input when displayCountryCode is false -->\n    <ng-template #fullWidthInput>\n      <input\n        type=\"text\"\n        class=\"form-control col-12 height mobileField\"\n        [placeholder]=\"placeholder\"\n        aria-label=\"Mobile Number\"\n        [class.invalid]=\"validationFailed\"\n        [class.invalid-question]=\"isInvalid\"\n        (blur)=\"validateMobile()\"\n        [(ngModel)]=\"mobileNumber\"\n        (ngModelChange)=\"onMobileNumberChange()\"\n        (input)=\"onInput($event)\"\n      />\n    </ng-template>\n  </div>\n  <div *ngIf=\"isInvalid && (!inLine || !mobileNumber)\" 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"]}
238
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mobile-fields.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/form-fields/mobile-fields/mobile-fields.component.ts","../../../../../projects/form-submission/src/form-fields/mobile-fields/mobile-fields.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { CountryService } from '../../services/countryService';\nimport { ElementTrackerService } from '../../services/element-tracker.service';\nimport { ValidationService } from '../../services/validation.service';\n\ninterface CountryData {\n  value: string;\n  label: string;\n  image: string;\n}\n\n@Component({\n  selector: 'lib-mobile-fields',\n  templateUrl: './mobile-fields.component.html',\n  styleUrls: ['./mobile-fields.component.scss'],\n})\nexport class MobileFieldsComponent implements OnInit {\n  @Input() question: any = {};\n  @Input() inLine: boolean = false;\n  @Output() answerChange = new EventEmitter<{ answer: any; maxPossibleScore?: number }>();\n\n  count: number = 0;\n  required: boolean = false;\n  hint: string = '';\n  placeholder: string = '';\n  displayCountryCode: boolean = true;\n  displayFlag: boolean = true;\n  displayCode: boolean = true;\n  showCountryName: boolean = true;\n  beautifyNumbers: boolean = true;\n  countryWiseValidation: boolean = true;\n  countryDetails: CountryData[] = [];\n  selectedCountry: CountryData[] = [];\n  validationFailed: boolean = false;\n  validationMessage: string = '';\n  mobileNumber: string = '';\n  questionId: string = '';\n  currentPage: number = 0;\n  size: number = 30;\n  totalPages: number = 0;\n  searchKey: string = '';\n  lastPage:boolean=false;\n  isFirstPage: boolean = false;\n  defaultValue: string = '';\n  disableEdit: boolean = false;\n\n private elementId: string='';\n\n  constructor(\n    private countryService: CountryService,\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.displayCountryCode =\n      this.question.formElement.appearance.displayCountryCode;\n    this.displayFlag = this.question.formElement.appearance.displayFlag;\n    this.displayCode = this.question.formElement.appearance.displayCode;\n    this.showCountryName = this.question.formElement.appearance.showCountryName;\n    this.beautifyNumbers = this.question.formElement.appearance.beautifyNumbers;\n    this.countryWiseValidation =\n      this.question.formElement.validation.countryWiseValidation;\n    this.questionId = this.question.id;\n    this.defaultValue = this.question?.defaultValue;\n    this.disableEdit = this.question.disableEdit;\n    this.loadCountry(this.questionId, this.currentPage, this.size, this.searchKey);\n  }\n\n\n  initializeAnswer(param?: string): void {\n    let countryCode: string | undefined;\n    let mobileNumber: string | undefined;\n  \n    const value = param === 'answer' && this.question?.answer\n      ? this.question.answer\n      : this.question?.defaultValue;\n  \n    if (this.displayCountryCode) {\n      // Expect \"countryCode mobileNumber\"\n      [countryCode, mobileNumber] = (value || '').split(' ');\n    } else {\n      // Only mobile number present\n      mobileNumber = value || '';\n    }\n    \n    this.mobileNumber = mobileNumber || '';\n  \n    if (this.displayCountryCode) {\n      if (!this.selectedCountry) {\n        this.selectedCountry = [];\n      }\n  \n      const matchedCountry = this.countryDetails.find(\n        (country) => country.value === countryCode\n      );\n  \n      if (matchedCountry) {\n        this.selectedCountry= [matchedCountry];\n      }\n    }\n  }\n  \n\n  onCountryChange() {\n    this.validationFailed = false;\n    this.validationMessage = '';\n    this.updateAnswer();\n  }\n\n  onInput(event: Event) {\n    this.validationService.clearInvalid(this.question.id);\n    const input = event.target as HTMLInputElement;\n  \n    // Regular expression to allow only numbers and multiple hyphens, but ensure only one hyphen between numbers\n    const regex = /^(\\d+)(-\\d+)*$/;\n  \n    if (!regex.test(input.value)) {\n      // Remove invalid characters\n      input.value = input.value.replace(/[^\\d-]/g, '');\n  \n      // Ensure only one hyphen is present between numbers\n      input.value = input.value\n        .split('-')\n        .filter((segment, index, array) => segment || index === 0 || index === array.length - 1)\n        .join('-');\n    }\n  \n    // Update the model\n    this.mobileNumber = input.value;\n    \n    this.updateAnswer();\n  }\n  onMobileNumberChange() {\n  }\n\n  updateAnswer() {  \n    if(this.displayCountryCode){\n      if (this.selectedCountry.length > 0 && this.mobileNumber) {\n        const countryCode = this.selectedCountry[0].value;\n        this.question.answer = `${countryCode} ${this.mobileNumber}`;\n      }\n    }else {\n      this.question.answer = this.mobileNumber;\n    }\n    this.answerChange.emit({answer:this.question.answer,maxPossibleScore:0});\n  }\n\n  validateMobile() {\n    this.validationFailed = false;\n    this.validationMessage = '';\n  \n    if (this.required && (!this.mobileNumber || (this.displayCountryCode && this.selectedCountry.length === 0))) {\n      this.validationFailed = true;\n      this.validationService.clearInvalid(this.question.id);\n      this.validationMessage = 'This is a required question';\n    } else {\n      this.updateAnswer();\n    }\n  }\n\n  loadCountry(id: string, currentPage: number, size: number, searchKey: string, isSearch: boolean = false) {\n    this.countryService.loadCountryDetails(this.questionId, currentPage, size, searchKey).subscribe((data) => {\n      if (this.totalPages === 0) {\n        this.totalPages = data.result.totalPages;\n      }\n      this.lastPage=data.result.last;\n      this.isFirstPage = data.result.first;\n      let newCountries=this.countryService.processCountryDetails(\n        data.result.content,\n        this.displayFlag,\n        this.displayCode,\n        this.showCountryName\n      )      \n\n      if (this.currentPage > 0) {\n        this.countryDetails = [\n          ...this.countryDetails,\n          ...newCountries.filter(item => !this.countryDetails.some((existing: any) => existing.value === item.value))\n          ];\n      } else {\n        this.countryDetails = [\n          ...newCountries.filter(item => !this.countryDetails.some((existing: any) => existing.value === item.value)),\n          ...this.countryDetails\n          ];\n      }\n      if(this.defaultValue && !isSearch){\n        this.initializeAnswer('default')\n      }\n      if (this.question.answer && !isSearch) {\n        this.initializeAnswer('answer');\n      }\n    });\n\n  }\n\n  getNextSetOfItems(event: any) {\n    const element = event.target;\n    if(!this.lastPage){\n      if (Math.floor(element.scrollHeight - element.scrollTop) <= element.clientHeight) {\n        this.loadMoreData();\n      }\n    }\n    if (!this.isFirstPage && element.scrollTop <= 150) {\n      this.loadPreviousData();\n    }\n  }\n\n  loadMoreData() {\n    setTimeout(() => {\n      this.currentPage++;\n      if (this.currentPage >= 0) {\n        this.loadCountry(this.questionId,this.currentPage, this.size, \"\");\n      }\n    }, 0);\n  }\n\n  loadPreviousData() {\n    setTimeout(() => {\n      this.currentPage--;\n      if (this.currentPage >= 0) {\n        this.loadCountry(this.questionId,this.currentPage, this.size, \"\");\n      }\n    }, 0);\n  }\n\n  search(searchTerm: any) {\n    if (searchTerm == '') {\n      this.loadCountry(this.questionId,this.currentPage, this.size, \"\",true);\n    }\n    else {\n      this.countryDetails = []; \n      this.loadCountry(this.questionId,this.currentPage, this.size, searchTerm,true);\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}\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  <div class=\"input-group mb-2\">\n    <ng-container *ngIf=\"displayCountryCode; else fullWidthInput\">\n      <div class=\"col-xs-5 col-5 col-md-3 px-0 pe-2 ps-2\"\n      [ngClass]=\"{'disable':disableEdit}\">\n        <lib-dropdown\n          [items]=\"countryDetails\"\n          [multiple]=\"false\"\n          [(selectedItems)]=\"selectedCountry\"\n          (selectedItemsChange)=\"onCountryChange()\"\n          (onDropdownScroll)=\"getNextSetOfItems($event)\"\n          (onSearch)=\"search($event)\"\n        ></lib-dropdown>\n      </div>\n      <input\n        type=\"text\"\n        class=\"form-control col-xs-7 col-7 col-md-9 height mobileField\"\n        [placeholder]=\"placeholder\"\n        aria-label=\"Mobile Number\"\n        (blur)=\"validateMobile()\"\n        [(ngModel)]=\"mobileNumber\"\n        (ngModelChange)=\"onMobileNumberChange()\"\n        (input)=\"onInput($event)\"\n        [disabled]=\"disableEdit\"\n      />\n    </ng-container>\n\n    <!-- Full-width input when displayCountryCode is false -->\n    <ng-template #fullWidthInput>\n      <input\n        type=\"text\"\n        class=\"form-control col-12 height mobileField\"\n        [placeholder]=\"placeholder\"\n        aria-label=\"Mobile Number\"\n        [class.invalid]=\"validationFailed\"\n        [class.invalid-question]=\"isInvalid\"\n        (blur)=\"validateMobile()\"\n        [(ngModel)]=\"mobileNumber\"\n        (ngModelChange)=\"onMobileNumberChange()\"\n        (input)=\"onInput($event)\"\n      />\n    </ng-template>\n  </div>\n  <div *ngIf=\"isInvalid && (!inLine || !mobileNumber)\" 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"]}