@piserve-tech/form-submission 1.0.38 → 1.1.1
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.
- package/esm2022/form-fields/check-box-fields/check-box-fields.component.mjs +8 -4
- package/esm2022/form-fields/mobile-fields/mobile-fields.component.mjs +40 -7
- package/esm2022/form-fields/password-fields/password-fields.component.mjs +64 -37
- package/esm2022/form-fields/rich-text-editor-fields/rich-text-editor-fields.component.mjs +7 -3
- package/esm2022/form-fields/text-fields/text-fields.component.mjs +8 -1
- package/esm2022/models/validation.model.mjs +1 -1
- package/esm2022/services/mapper.service.mjs +3 -3
- package/fesm2022/piserve-tech-form-submission.mjs +124 -49
- package/fesm2022/piserve-tech-form-submission.mjs.map +1 -1
- package/form-fields/mobile-fields/mobile-fields.component.d.ts +3 -0
- package/form-fields/password-fields/password-fields.component.d.ts +3 -1
- package/form-fields/rich-text-editor-fields/rich-text-editor-fields.component.d.ts +1 -0
- package/models/validation.model.d.ts +2 -2
- package/package.json +1 -1
|
@@ -73,17 +73,21 @@ export class CheckBoxFieldsComponent {
|
|
|
73
73
|
this.question.answer.push(option.value);
|
|
74
74
|
}
|
|
75
75
|
if (event.target.checked) {
|
|
76
|
-
|
|
76
|
+
this.question.answer = [];
|
|
77
77
|
if (!this.selectedOptions.includes(option)) {
|
|
78
78
|
this.selectedOptions.push(option);
|
|
79
|
-
this.
|
|
79
|
+
this.selectedOptions.map(option => {
|
|
80
|
+
this.question.answer.push(option.value);
|
|
81
|
+
});
|
|
80
82
|
this.isMinimumSelectionValid();
|
|
81
83
|
}
|
|
82
84
|
}
|
|
83
85
|
else {
|
|
84
86
|
// Remove the selected option
|
|
85
87
|
this.selectedOptions = this.selectedOptions.filter((item) => item !== option);
|
|
86
|
-
this.
|
|
88
|
+
this.selectedOptions.map(option => {
|
|
89
|
+
this.question.answer.push(option.value);
|
|
90
|
+
});
|
|
87
91
|
this.isMinimumSelectionValid();
|
|
88
92
|
}
|
|
89
93
|
// Check if the number of selected options exceeds the maximum allowed
|
|
@@ -196,4 +200,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
196
200
|
}], ctorParameters: function () { return [{ type: i1.FormService }]; }, propDecorators: { question: [{
|
|
197
201
|
type: Input
|
|
198
202
|
}] } });
|
|
199
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"check-box-fields.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/form-fields/check-box-fields/check-box-fields.component.ts","../../../../../projects/form-submission/src/form-fields/check-box-fields/check-box-fields.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { FormService } from '../../services/form.service';\n\n@Component({\n  selector: 'lib-check-box-fields',\n  templateUrl: './check-box-fields.component.html',\n  styleUrls: ['./check-box-fields.component.scss'],\n})\nexport class CheckBoxFieldsComponent {\n  @Input() question: any = {};\n  count: number = 0;\n  required: boolean = false;\n  hint: string = '';\n  selectionType: string = '';\n  minimumSelection?: number;\n  maximumSelection?: number;\n  optionType: string = '';\n  lookupTable: any = {};\n  customOptions: any[] = [];\n  database: any = {};\n  api: any = {};\n  apiOptions: any[] = []; // Assuming you have a property to store API options\n  selectedOptions: any[] = [];\n  validationFailed: boolean = false;\n  validationMessage: string = '';\n\n  constructor(private formService: FormService) { }\n\n  ngOnInit() {\n    this.valueAssigned();\n  }\n\n  valueAssigned() {\n    this.count = this.question.count;\n    this.required = this.question.required;\n    this.hint = this.question.hint;\n    this.selectionType = this.question.formElement.appearance.selectionType;\n    this.minimumSelection =\n      this.question.formElement.validation.minimumSelection;\n    this.maximumSelection =\n      this.question.formElement.validation.maximumSelection;\n    this.optionType = this.question.formElement.option.optionType;\n    this.question.answer = [];\n    switch (this.optionType) {\n      case 'OPTION':\n        this.customOptions = this.question.formElement.option.customOptions;\n        break;\n      case 'LOOKUP':\n        this.lookupTable = this.question.formElement.option.lookupTable;\n        this.fetchDataFromLookup();\n        break;\n      case 'DATABASE':\n        this.database = this.question.formElement.option.database;\n        this.fetchDataFromDatabase();\n        break;\n      case 'API':\n        this.api = this.question.formElement.option.api;\n        this.fetchDataFromAPI();\n        break;\n      default:\n        console.warn('Unknown option type:', this.optionType);\n    }\n\n    // If selectionType is 'SINGLE', set minimumSelection and maximumSelection to 1\n    if (this.selectionType === 'SINGLE') {\n      this.minimumSelection = 1;\n      this.maximumSelection = 1;\n    }\n\n    // If selectionType is 'MULTIPLE' and minSelection and maxSelection are not specified, set them to undefined\n    if (\n      this.selectionType === 'MULTIPLE' &&\n      !this.minimumSelection &&\n      !this.maximumSelection\n    ) {\n      this.minimumSelection = undefined;\n      this.maximumSelection = undefined;\n    }\n  }\n\n  onCheckboxChange(option: any, event: any) {\n    if (this.selectionType === 'SINGLE') {\n      // Clear previously selected options for single selection type\n      this.selectedOptions = [];\n      this.question.answer.push(option.value);\n    }\n\n    if (event.target.checked) {\n      // Add the selected option if it's not already in the list\n      if (!this.selectedOptions.includes(option)) {\n        this.selectedOptions.push(option);\n        this.question.answer = this.selectedOptions;\n        this.isMinimumSelectionValid();\n      }\n    } else {\n      // Remove the selected option\n      this.selectedOptions = this.selectedOptions.filter(\n        (item) => item !== option\n      );\n      this.question.answer = this.selectedOptions;\n      this.isMinimumSelectionValid();\n    }\n\n    // Check if the number of selected options exceeds the maximum allowed\n    if (\n      this.maximumSelection !== undefined &&\n      this.selectedOptions.length > this.maximumSelection\n    ) {\n      // If exceeded, uncheck the last selected option\n      event.target.checked = false;\n      // Remove the unchecked option from the selectedOptions array\n      this.selectedOptions = this.selectedOptions.filter(\n        (item) => item !== option\n      );\n      // You can add a message to inform the user about the maximum selection limit if needed\n    }\n  }\n\n  fetchDataFromLookup() {\n    this.formService.fetchDataFromLookup(this.lookupTable).subscribe(\n      (response) => {\n        this.customOptions = response.result.values.map(\n          (item: { value: string; label: string }) => ({\n            value: item.value,\n            label: item.label,\n          })\n        );\n      },\n      (error) => {\n        console.error('HTTP Error:', error);\n      }\n    );\n  }\n\n  fetchDataFromDatabase() {\n    const transformedDatabase = this.transformDatabaseObject(this.database);\n    this.formService.fetchDataFromDatabase(transformedDatabase).subscribe(\n      (response) => {\n        if (response.success) {\n          this.customOptions = response.result.map(\n            (item: { value: string; label: string }) => ({\n              value: item.value,\n              label: item.label,\n            })\n          );\n        } else {\n          console.error('Error fetching data from database:', response.message);\n        }\n      },\n      (error) => {\n        console.error('HTTP Error:', error);\n      }\n    );\n  }\n\n  transformDatabaseObject(database: any) {\n    return {\n      tableName: database.tableName,\n      valueField: database.valueField,\n      labelField: database.labelField,\n      criteria: database.criteria.map((criteria: any) => ({\n        field: criteria.field,\n        condition: criteria.condition,\n        value: criteria.inputValue,\n        logicalOperator: criteria.logicalOperator,\n      })),\n    };\n  }\n\n  fetchDataFromAPI() {\n    const apiConfig = this.api;\n    this.formService.fetchDataFromExternalAPI(apiConfig.url).subscribe(\n      (response) => {\n        const data = this.extractDataByPath(response, apiConfig.pathToValue);\n        this.customOptions = data.map((item: any) => ({\n          value: item[apiConfig.valueField],\n          label: item[apiConfig.labelField],\n        }));\n      },\n      (error) => {\n        console.error('HTTP Error:', error);\n      }\n    );\n  }\n\n  extractDataByPath(data: any, path: string) {\n    return path.split('.').reduce((acc, part) => acc && acc[part], data);\n  }\n\n  isMinimumSelectionValid() {\n    this.validationFailed = false;\n    if (this.selectedOptions.length == 0 && this.required) {\n      this.validationFailed = true;\n      this.validationMessage = 'This is a required question';\n      this.question.validation = false;\n    } else if (this.minimumSelection !== undefined) {\n      if (this.selectedOptions.length < this.minimumSelection) {\n        this.validationFailed = true;\n        this.validationMessage = `Minimum ${this.minimumSelection}  selection(s) required.`;\n        this.question.validation = false;\n      }\n    } else {\n      this.question.validation = true;\n    }\n  }\n\n  getOptions() {\n    if (this.optionType === 'OPTION') {\n      return this.customOptions;\n    } else if (this.optionType === 'LOOKUP') {\n      return Object.values(this.lookupTable);\n    } else if (this.optionType === 'API') {\n      return this.apiOptions.map((option) => option.valueField);\n    } else {\n      return [];\n    }\n  }\n\n  isOptionDisabled(option: any): boolean {\n    return (\n      this.maximumSelection !== undefined &&\n      this.selectedOptions.length >= this.maximumSelection &&\n      !this.selectedOptions.includes(option)\n    );\n  }\n}\n","<div [ngClass]=\"'col-' + count\" class=\"mb-5 px-3\">\n  <div class=\"input-wrapper mb-2\">\n    <label for=\"\">{{question.questionNumber}}.</label> &nbsp;&nbsp;\n    <label>{{ question.question }}</label\n    >&nbsp;\n    <span class=\"text-danger\" *ngIf=\"required\">*</span>\n    <div\n      class=\"svg-wrapper mb-2 hintIcon\"\n      [attr.data-title]=\"hint\"\n      *ngIf=\"hint\"\n    >\n      <svg\n        class=\"hintSvg\"\n        viewBox=\"0 0 30 30\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n      >\n        <path\n          fill-rule=\"evenodd\"\n          clip-rule=\"evenodd\"\n          d=\"M15 26.25V26.25C8.78625 26.25 3.75 21.2138 3.75 15V15C3.75 8.78625 8.78625 3.75 15 3.75V3.75C21.2138 3.75 26.25 8.78625 26.25 15V15C26.25 21.2138 21.2138 26.25 15 26.25Z\"\n          stroke=\"#323232\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          d=\"M15 16.5623V16.2498C15 15.2285 15.6312 14.6748 16.2637 14.2498C16.8812 13.8335 17.5 13.291 17.5 12.291C17.5 10.9098 16.3813 9.79102 15 9.79102C13.6187 9.79102 12.5 10.9098 12.5 12.291\"\n          stroke=\"#323232\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          d=\"M14.9988 20C14.8263 20 14.6863 20.14 14.6875 20.3125C14.6875 20.485 14.8275 20.625 15 20.625C15.1725 20.625 15.3125 20.485 15.3125 20.3125C15.3125 20.14 15.1725 20 14.9988 20\"\n          stroke=\"#323232\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n      </svg>\n    </div>\n  </div>\n  <div class=\"form-check\" *ngFor=\"let option of customOptions\">\n    <input\n      class=\"form-check-input\"\n      type=\"checkbox\"\n      [id]=\"option.value + 'Checkbox'\"\n      [name]=\"option.value + 'Checkbox'\"\n      [value]=\"option.value\"\n      (change)=\"onCheckboxChange(option, $event)\"\n      [disabled]=\"isOptionDisabled(option)\"\n      [checked]=\"selectedOptions.includes(option.value)\"\n    />\n    <label\n      class=\"formCheckLabel ms-2 mb-2\"\n      [for]=\"option.value + 'Checkbox'\"\n      *ngIf=\"optionType == 'OPTION'\"\n      >{{ option.value }}</label\n    >\n    <label\n      class=\"formCheckLabel ms-2 mb-2\"\n      [for]=\"option.value + 'Checkbox'\"\n      *ngIf=\"optionType == 'LOOKUP' || 'DATABASE' || 'API'\"\n      >{{ option.label }}</label\n    >\n  </div>\n  <div *ngIf=\"validationFailed\" 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"]}
|
|
203
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"check-box-fields.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/form-fields/check-box-fields/check-box-fields.component.ts","../../../../../projects/form-submission/src/form-fields/check-box-fields/check-box-fields.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { FormService } from '../../services/form.service';\n\n@Component({\n  selector: 'lib-check-box-fields',\n  templateUrl: './check-box-fields.component.html',\n  styleUrls: ['./check-box-fields.component.scss'],\n})\nexport class CheckBoxFieldsComponent {\n  @Input() question: any = {};\n  count: number = 0;\n  required: boolean = false;\n  hint: string = '';\n  selectionType: string = '';\n  minimumSelection?: number;\n  maximumSelection?: number;\n  optionType: string = '';\n  lookupTable: any = {};\n  customOptions: any[] = [];\n  database: any = {};\n  api: any = {};\n  apiOptions: any[] = []; // Assuming you have a property to store API options\n  selectedOptions: any[] = [];\n  validationFailed: boolean = false;\n  validationMessage: string = '';\n\n  constructor(private formService: FormService) { }\n\n  ngOnInit() {\n    this.valueAssigned();\n  }\n\n  valueAssigned() {\n    this.count = this.question.count;\n    this.required = this.question.required;\n    this.hint = this.question.hint;\n    this.selectionType = this.question.formElement.appearance.selectionType;\n    this.minimumSelection =\n      this.question.formElement.validation.minimumSelection;\n    this.maximumSelection =\n      this.question.formElement.validation.maximumSelection;\n    this.optionType = this.question.formElement.option.optionType;\n    this.question.answer = [];\n    switch (this.optionType) {\n      case 'OPTION':\n        this.customOptions = this.question.formElement.option.customOptions;\n        break;\n      case 'LOOKUP':\n        this.lookupTable = this.question.formElement.option.lookupTable;\n        this.fetchDataFromLookup();\n        break;\n      case 'DATABASE':\n        this.database = this.question.formElement.option.database;\n        this.fetchDataFromDatabase();\n        break;\n      case 'API':\n        this.api = this.question.formElement.option.api;\n        this.fetchDataFromAPI();\n        break;\n      default:\n        console.warn('Unknown option type:', this.optionType);\n    }\n\n    // If selectionType is 'SINGLE', set minimumSelection and maximumSelection to 1\n    if (this.selectionType === 'SINGLE') {\n      this.minimumSelection = 1;\n      this.maximumSelection = 1;\n    }\n\n    // If selectionType is 'MULTIPLE' and minSelection and maxSelection are not specified, set them to undefined\n    if (\n      this.selectionType === 'MULTIPLE' &&\n      !this.minimumSelection &&\n      !this.maximumSelection\n    ) {\n      this.minimumSelection = undefined;\n      this.maximumSelection = undefined;\n    }\n  }\n\n  onCheckboxChange(option: any, event: any) {\n    if (this.selectionType === 'SINGLE') {\n      // Clear previously selected options for single selection type\n      this.selectedOptions = [];\n      this.question.answer.push(option.value);\n    }\n\n    if (event.target.checked) {\n      this.question.answer = [];\n      if (!this.selectedOptions.includes(option)) {\n        this.selectedOptions.push(option);\n        this.selectedOptions.map(option =>{\n          this.question.answer.push(option.value)\n        })        \n        this.isMinimumSelectionValid();\n      }\n    } else {\n      // Remove the selected option\n      this.selectedOptions = this.selectedOptions.filter(\n        (item) => item !== option\n      );\n      this.selectedOptions.map(option =>{\n        this.question.answer.push(option.value)\n      })\n      this.isMinimumSelectionValid();\n    }\n\n    // Check if the number of selected options exceeds the maximum allowed\n    if (\n      this.maximumSelection !== undefined &&\n      this.selectedOptions.length > this.maximumSelection\n    ) {\n      // If exceeded, uncheck the last selected option\n      event.target.checked = false;\n      // Remove the unchecked option from the selectedOptions array\n      this.selectedOptions = this.selectedOptions.filter(\n        (item) => item !== option\n      );\n      // You can add a message to inform the user about the maximum selection limit if needed\n    }\n  }\n\n  fetchDataFromLookup() {\n    this.formService.fetchDataFromLookup(this.lookupTable).subscribe(\n      (response) => {\n        this.customOptions = response.result.values.map(\n          (item: { value: string; label: string }) => ({\n            value: item.value,\n            label: item.label,\n          })\n        );\n      },\n      (error) => {\n        console.error('HTTP Error:', error);\n      }\n    );\n  }\n\n  fetchDataFromDatabase() {\n    const transformedDatabase = this.transformDatabaseObject(this.database);\n    this.formService.fetchDataFromDatabase(transformedDatabase).subscribe(\n      (response) => {\n        if (response.success) {\n          this.customOptions = response.result.map(\n            (item: { value: string; label: string }) => ({\n              value: item.value,\n              label: item.label,\n            })\n          );\n        } else {\n          console.error('Error fetching data from database:', response.message);\n        }\n      },\n      (error) => {\n        console.error('HTTP Error:', error);\n      }\n    );\n  }\n\n  transformDatabaseObject(database: any) {\n    return {\n      tableName: database.tableName,\n      valueField: database.valueField,\n      labelField: database.labelField,\n      criteria: database.criteria.map((criteria: any) => ({\n        field: criteria.field,\n        condition: criteria.condition,\n        value: criteria.inputValue,\n        logicalOperator: criteria.logicalOperator,\n      })),\n    };\n  }\n\n  fetchDataFromAPI() {\n    const apiConfig = this.api;\n    this.formService.fetchDataFromExternalAPI(apiConfig.url).subscribe(\n      (response) => {\n        const data = this.extractDataByPath(response, apiConfig.pathToValue);\n        this.customOptions = data.map((item: any) => ({\n          value: item[apiConfig.valueField],\n          label: item[apiConfig.labelField],\n        }));\n      },\n      (error) => {\n        console.error('HTTP Error:', error);\n      }\n    );\n  }\n\n  extractDataByPath(data: any, path: string) {\n    return path.split('.').reduce((acc, part) => acc && acc[part], data);\n  }\n\n  isMinimumSelectionValid() {\n    this.validationFailed = false;\n    if (this.selectedOptions.length == 0 && this.required) {\n      this.validationFailed = true;\n      this.validationMessage = 'This is a required question';\n      this.question.validation = false;\n    } else if (this.minimumSelection !== undefined) {\n      if (this.selectedOptions.length < this.minimumSelection) {\n        this.validationFailed = true;\n        this.validationMessage = `Minimum ${this.minimumSelection}  selection(s) required.`;\n        this.question.validation = false;\n      }\n    } else {\n      this.question.validation = true;\n    }\n  }\n\n  getOptions() {\n    if (this.optionType === 'OPTION') {\n      return this.customOptions;\n    } else if (this.optionType === 'LOOKUP') {\n      return Object.values(this.lookupTable);\n    } else if (this.optionType === 'API') {\n      return this.apiOptions.map((option) => option.valueField);\n    } else {\n      return [];\n    }\n  }\n\n  isOptionDisabled(option: any): boolean {\n    return (\n      this.maximumSelection !== undefined &&\n      this.selectedOptions.length >= this.maximumSelection &&\n      !this.selectedOptions.includes(option)\n    );\n  }\n}\n","<div [ngClass]=\"'col-' + count\" class=\"mb-5 px-3\">\n  <div class=\"input-wrapper mb-2\">\n    <label for=\"\">{{question.questionNumber}}.</label> &nbsp;&nbsp;\n    <label>{{ question.question }}</label\n    >&nbsp;\n    <span class=\"text-danger\" *ngIf=\"required\">*</span>\n    <div\n      class=\"svg-wrapper mb-2 hintIcon\"\n      [attr.data-title]=\"hint\"\n      *ngIf=\"hint\"\n    >\n      <svg\n        class=\"hintSvg\"\n        viewBox=\"0 0 30 30\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n      >\n        <path\n          fill-rule=\"evenodd\"\n          clip-rule=\"evenodd\"\n          d=\"M15 26.25V26.25C8.78625 26.25 3.75 21.2138 3.75 15V15C3.75 8.78625 8.78625 3.75 15 3.75V3.75C21.2138 3.75 26.25 8.78625 26.25 15V15C26.25 21.2138 21.2138 26.25 15 26.25Z\"\n          stroke=\"#323232\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          d=\"M15 16.5623V16.2498C15 15.2285 15.6312 14.6748 16.2637 14.2498C16.8812 13.8335 17.5 13.291 17.5 12.291C17.5 10.9098 16.3813 9.79102 15 9.79102C13.6187 9.79102 12.5 10.9098 12.5 12.291\"\n          stroke=\"#323232\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          d=\"M14.9988 20C14.8263 20 14.6863 20.14 14.6875 20.3125C14.6875 20.485 14.8275 20.625 15 20.625C15.1725 20.625 15.3125 20.485 15.3125 20.3125C15.3125 20.14 15.1725 20 14.9988 20\"\n          stroke=\"#323232\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n      </svg>\n    </div>\n  </div>\n  <div class=\"form-check\" *ngFor=\"let option of customOptions\">\n    <input\n      class=\"form-check-input\"\n      type=\"checkbox\"\n      [id]=\"option.value + 'Checkbox'\"\n      [name]=\"option.value + 'Checkbox'\"\n      [value]=\"option.value\"\n      (change)=\"onCheckboxChange(option, $event)\"\n      [disabled]=\"isOptionDisabled(option)\"\n      [checked]=\"selectedOptions.includes(option.value)\"\n    />\n    <label\n      class=\"formCheckLabel ms-2 mb-2\"\n      [for]=\"option.value + 'Checkbox'\"\n      *ngIf=\"optionType == 'OPTION'\"\n      >{{ option.value }}</label\n    >\n    <label\n      class=\"formCheckLabel ms-2 mb-2\"\n      [for]=\"option.value + 'Checkbox'\"\n      *ngIf=\"optionType == 'LOOKUP' || 'DATABASE' || 'API'\"\n      >{{ option.label }}</label\n    >\n  </div>\n  <div *ngIf=\"validationFailed\" 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"]}
|
|
@@ -46,18 +46,47 @@ export class MobileFieldsComponent {
|
|
|
46
46
|
this.countryWiseValidation =
|
|
47
47
|
this.question.formElement.validation.countryWiseValidation;
|
|
48
48
|
this.restrictCountry = this.question.formElement.validation.restrictCountry;
|
|
49
|
-
this.allowedCountry = this.question.formElement.validation.
|
|
50
|
-
this.blockedCountry = this.question.formElement.validation.
|
|
49
|
+
this.allowedCountry = this.question.formElement.validation.allowedCountries;
|
|
50
|
+
this.blockedCountry = this.question.formElement.validation.blockedCountries;
|
|
51
51
|
this.countryService.loadCountryDetails().subscribe((data) => {
|
|
52
52
|
this.filteredCountry = data.result;
|
|
53
|
-
if (this.restrictCountry &&
|
|
53
|
+
if (this.restrictCountry && this.allowedCountry.length > 0) {
|
|
54
54
|
this.filteredCountry = this.filteredCountry.filter(country => {
|
|
55
|
-
return (this.allowedCountry.includes(country.name)
|
|
55
|
+
return (this.allowedCountry.includes(country.name));
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
if (this.restrictCountry && this.blockedCountry.length > 0) {
|
|
59
|
+
this.filteredCountry = this.filteredCountry.filter(country => {
|
|
60
|
+
return (!this.blockedCountry.includes(country.name));
|
|
56
61
|
});
|
|
57
62
|
}
|
|
58
63
|
this.countryDetails = this.countryService.processCountryDetails(this.filteredCountry, this.displayFlag, this.displayCode, this.showCountryName);
|
|
59
64
|
});
|
|
60
65
|
}
|
|
66
|
+
onCountryChange() {
|
|
67
|
+
this.validationFailed = false;
|
|
68
|
+
this.validationMessage = '';
|
|
69
|
+
if (this.required && (!this.mobileNumber || this.selectedCountry.length === 0)) {
|
|
70
|
+
this.validationFailed = true;
|
|
71
|
+
this.validationMessage = 'This is a required question';
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
this.updateAnswer();
|
|
75
|
+
}
|
|
76
|
+
this.updateAnswer();
|
|
77
|
+
}
|
|
78
|
+
onMobileNumberChange() {
|
|
79
|
+
this.updateAnswer();
|
|
80
|
+
}
|
|
81
|
+
updateAnswer() {
|
|
82
|
+
if (this.selectedCountry.length > 0 && this.mobileNumber) {
|
|
83
|
+
const countryCode = this.selectedCountry[0].value;
|
|
84
|
+
this.question.answer = `${countryCode} ${this.mobileNumber}`;
|
|
85
|
+
}
|
|
86
|
+
else {
|
|
87
|
+
this.question.answer = '';
|
|
88
|
+
}
|
|
89
|
+
}
|
|
61
90
|
validateMobile() {
|
|
62
91
|
this.validationFailed = false;
|
|
63
92
|
this.validationMessage = '';
|
|
@@ -66,16 +95,20 @@ export class MobileFieldsComponent {
|
|
|
66
95
|
this.validationMessage = 'This is a required question';
|
|
67
96
|
this.validate.emit(this.validationFailed);
|
|
68
97
|
}
|
|
98
|
+
else {
|
|
99
|
+
this.updateAnswer();
|
|
100
|
+
this.validate.emit(this.validationFailed);
|
|
101
|
+
}
|
|
69
102
|
}
|
|
70
103
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MobileFieldsComponent, deps: [{ token: i1.CountryService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
71
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: MobileFieldsComponent, selector: "lib-mobile-fields", inputs: { question: "question" }, outputs: { validate: "validate" }, ngImport: i0, template: "<div [ngClass]=\"'col-' + count\" class=\"mb-5 px-3\">\n <div class=\"input-wrapper mb-2\">\n <label for=\"\">{{question.questionNumber}}.</label> \n <label>{{ question.question }}</label> \n <span class=\"text-danger\" *ngIf=\"required\">*</span>\n <div class=\"svg-wrapper mb-2 hintIcon\" [attr.data-title]=\"hint\" *ngIf=\"hint\">\n <svg class=\"hintSvg\" viewBox=\"0 0 30 30\" xmlns=\"http://www.w3.org/2000/svg\">\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" 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\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <path 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\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <path 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\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n </svg>\n </div>\n</div>\n <div class=\"input-group mb-2\">\n <div class=\"col-xs-5 col-5 col-md-3 px-0 pe-2\">\n <lib-dropdown\n [items]=\"countryDetails\"\n [multiple] = \"false\"\n [(selectedItems)]=\"selectedCountry\"></lib-dropdown>\n </div>\n <input\n type=\"number\"\n class=\"form-control col-xs-7 col-7 col-md-9 height mobileField\" \n [placeholder]=\"placeholder\"\n aria-label=\"Mobile Number\"\n [class.invalid]=\"validationFailed\"\n (blur)=\"validateMobile()\"\n [(ngModel)]=\"mobileNumber\"\n />\n </div>\n <div *ngIf=\"validationFailed\" class=\"text-danger\">\n <svg class=\"validationSvg\" viewBox=\"0 0 24 24\" xmlns=\"http://www.w3.org/2000/svg\">\n <path 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\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" 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\" fill=\"#FF0000\" stroke=\"#FF0000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <path d=\"M12 12.75L12 7.75\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\"/>\n </svg>\n {{validationMessage}}</div>\n</div>\n", styles: [".input-wrapper{display:flex;align-items:flex-start}.svg-wrapper{margin-left:auto;z-index:999}.hintIcon{position:relative;cursor:pointer}.hintIcon:hover:before{content:attr(data-title);position:absolute;top:calc(100% + 2px);left:50%;transform:translate(-50%);padding:4px 8px;border-radius:4px;background-color:#1d252d;color:#8e9aa0;font-size:14px;white-space:nowrap}.hintIcon:hover:after{content:\"\";position:absolute;top:calc(100% - 26px);left:50%;border:solid transparent;border-width:18px;border-bottom-color:#1d252d;transform:translate(-50%)}.height{height:42px}.invalid{border-color:red}.hintSvg{width:30px;height:30px;fill:none}.validationSvg{width:24px;height:24px;fill:none}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.mobileField{border-radius:6px!important}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.DropdownComponent, selector: "lib-dropdown", inputs: ["multiple", "scrollable", "selectedItems", "placeholder", "items", "showCreateNew", "selectedValues", "customButtons", "showBorder"], outputs: ["buttonClick", "selectedItemsChange", "onScroll", "onCreateNew", "onSearch"] }] }); }
|
|
104
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: MobileFieldsComponent, selector: "lib-mobile-fields", inputs: { question: "question" }, outputs: { validate: "validate" }, ngImport: i0, template: "<div [ngClass]=\"'col-' + count\" class=\"mb-5 px-3\">\n <div class=\"input-wrapper mb-2\">\n <label for=\"\">{{question.questionNumber}}.</label> \n <label>{{ question.question }}</label> \n <span class=\"text-danger\" *ngIf=\"required\">*</span>\n <div class=\"svg-wrapper mb-2 hintIcon\" [attr.data-title]=\"hint\" *ngIf=\"hint\">\n <svg class=\"hintSvg\" viewBox=\"0 0 30 30\" xmlns=\"http://www.w3.org/2000/svg\">\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" 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\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <path 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\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <path 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\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n </svg>\n </div>\n</div>\n <div class=\"input-group mb-2\">\n <div class=\"col-xs-5 col-5 col-md-3 px-0 pe-2\">\n <lib-dropdown\n [items]=\"countryDetails\"\n [multiple] = \"false\"\n [(selectedItems)]=\"selectedCountry\"\n (selectedItemsChange)=\"onCountryChange()\"></lib-dropdown>\n </div>\n <input\n type=\"number\"\n class=\"form-control col-xs-7 col-7 col-md-9 height mobileField\" \n [placeholder]=\"placeholder\"\n aria-label=\"Mobile Number\"\n [class.invalid]=\"validationFailed\"\n (blur)=\"validateMobile()\"\n [(ngModel)]=\"mobileNumber\"\n (ngModelChange)=\"onMobileNumberChange()\"\n />\n </div>\n <div *ngIf=\"validationFailed\" class=\"text-danger\">\n <svg class=\"validationSvg\" viewBox=\"0 0 24 24\" xmlns=\"http://www.w3.org/2000/svg\">\n <path 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\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" 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\" fill=\"#FF0000\" stroke=\"#FF0000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <path d=\"M12 12.75L12 7.75\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\"/>\n </svg>\n {{validationMessage}}</div>\n</div>\n", styles: [".input-wrapper{display:flex;align-items:flex-start}.svg-wrapper{margin-left:auto;z-index:999}.hintIcon{position:relative;cursor:pointer}.hintIcon:hover:before{content:attr(data-title);position:absolute;top:calc(100% + 2px);left:50%;transform:translate(-50%);padding:4px 8px;border-radius:4px;background-color:#1d252d;color:#8e9aa0;font-size:14px;white-space:nowrap}.hintIcon:hover:after{content:\"\";position:absolute;top:calc(100% - 26px);left:50%;border:solid transparent;border-width:18px;border-bottom-color:#1d252d;transform:translate(-50%)}.height{height:42px}.invalid{border-color:red}.hintSvg{width:30px;height:30px;fill:none}.validationSvg{width:24px;height:24px;fill:none}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.mobileField{border-radius:6px!important}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.DropdownComponent, selector: "lib-dropdown", inputs: ["multiple", "scrollable", "selectedItems", "placeholder", "items", "showCreateNew", "selectedValues", "customButtons", "showBorder"], outputs: ["buttonClick", "selectedItemsChange", "onScroll", "onCreateNew", "onSearch"] }] }); }
|
|
72
105
|
}
|
|
73
106
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MobileFieldsComponent, decorators: [{
|
|
74
107
|
type: Component,
|
|
75
|
-
args: [{ selector: 'lib-mobile-fields', template: "<div [ngClass]=\"'col-' + count\" class=\"mb-5 px-3\">\n <div class=\"input-wrapper mb-2\">\n <label for=\"\">{{question.questionNumber}}.</label> \n <label>{{ question.question }}</label> \n <span class=\"text-danger\" *ngIf=\"required\">*</span>\n <div class=\"svg-wrapper mb-2 hintIcon\" [attr.data-title]=\"hint\" *ngIf=\"hint\">\n <svg class=\"hintSvg\" viewBox=\"0 0 30 30\" xmlns=\"http://www.w3.org/2000/svg\">\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" 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\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <path 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\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <path 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\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n </svg>\n </div>\n</div>\n <div class=\"input-group mb-2\">\n <div class=\"col-xs-5 col-5 col-md-3 px-0 pe-2\">\n <lib-dropdown\n [items]=\"countryDetails\"\n [multiple] = \"false\"\n [(selectedItems)]=\"selectedCountry\"></lib-dropdown>\n </div>\n <input\n type=\"number\"\n class=\"form-control col-xs-7 col-7 col-md-9 height mobileField\" \n [placeholder]=\"placeholder\"\n aria-label=\"Mobile Number\"\n [class.invalid]=\"validationFailed\"\n (blur)=\"validateMobile()\"\n [(ngModel)]=\"mobileNumber\"\n />\n </div>\n <div *ngIf=\"validationFailed\" class=\"text-danger\">\n <svg class=\"validationSvg\" viewBox=\"0 0 24 24\" xmlns=\"http://www.w3.org/2000/svg\">\n <path 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\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" 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\" fill=\"#FF0000\" stroke=\"#FF0000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <path d=\"M12 12.75L12 7.75\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\"/>\n </svg>\n {{validationMessage}}</div>\n</div>\n", styles: [".input-wrapper{display:flex;align-items:flex-start}.svg-wrapper{margin-left:auto;z-index:999}.hintIcon{position:relative;cursor:pointer}.hintIcon:hover:before{content:attr(data-title);position:absolute;top:calc(100% + 2px);left:50%;transform:translate(-50%);padding:4px 8px;border-radius:4px;background-color:#1d252d;color:#8e9aa0;font-size:14px;white-space:nowrap}.hintIcon:hover:after{content:\"\";position:absolute;top:calc(100% - 26px);left:50%;border:solid transparent;border-width:18px;border-bottom-color:#1d252d;transform:translate(-50%)}.height{height:42px}.invalid{border-color:red}.hintSvg{width:30px;height:30px;fill:none}.validationSvg{width:24px;height:24px;fill:none}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.mobileField{border-radius:6px!important}\n"] }]
|
|
108
|
+
args: [{ selector: 'lib-mobile-fields', template: "<div [ngClass]=\"'col-' + count\" class=\"mb-5 px-3\">\n <div class=\"input-wrapper mb-2\">\n <label for=\"\">{{question.questionNumber}}.</label> \n <label>{{ question.question }}</label> \n <span class=\"text-danger\" *ngIf=\"required\">*</span>\n <div class=\"svg-wrapper mb-2 hintIcon\" [attr.data-title]=\"hint\" *ngIf=\"hint\">\n <svg class=\"hintSvg\" viewBox=\"0 0 30 30\" xmlns=\"http://www.w3.org/2000/svg\">\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" 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\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <path 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\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <path 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\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n </svg>\n </div>\n</div>\n <div class=\"input-group mb-2\">\n <div class=\"col-xs-5 col-5 col-md-3 px-0 pe-2\">\n <lib-dropdown\n [items]=\"countryDetails\"\n [multiple] = \"false\"\n [(selectedItems)]=\"selectedCountry\"\n (selectedItemsChange)=\"onCountryChange()\"></lib-dropdown>\n </div>\n <input\n type=\"number\"\n class=\"form-control col-xs-7 col-7 col-md-9 height mobileField\" \n [placeholder]=\"placeholder\"\n aria-label=\"Mobile Number\"\n [class.invalid]=\"validationFailed\"\n (blur)=\"validateMobile()\"\n [(ngModel)]=\"mobileNumber\"\n (ngModelChange)=\"onMobileNumberChange()\"\n />\n </div>\n <div *ngIf=\"validationFailed\" class=\"text-danger\">\n <svg class=\"validationSvg\" viewBox=\"0 0 24 24\" xmlns=\"http://www.w3.org/2000/svg\">\n <path 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\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" 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\" fill=\"#FF0000\" stroke=\"#FF0000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <path d=\"M12 12.75L12 7.75\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\"/>\n </svg>\n {{validationMessage}}</div>\n</div>\n", styles: [".input-wrapper{display:flex;align-items:flex-start}.svg-wrapper{margin-left:auto;z-index:999}.hintIcon{position:relative;cursor:pointer}.hintIcon:hover:before{content:attr(data-title);position:absolute;top:calc(100% + 2px);left:50%;transform:translate(-50%);padding:4px 8px;border-radius:4px;background-color:#1d252d;color:#8e9aa0;font-size:14px;white-space:nowrap}.hintIcon:hover:after{content:\"\";position:absolute;top:calc(100% - 26px);left:50%;border:solid transparent;border-width:18px;border-bottom-color:#1d252d;transform:translate(-50%)}.height{height:42px}.invalid{border-color:red}.hintSvg{width:30px;height:30px;fill:none}.validationSvg{width:24px;height:24px;fill:none}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.mobileField{border-radius:6px!important}\n"] }]
|
|
76
109
|
}], ctorParameters: function () { return [{ type: i1.CountryService }]; }, propDecorators: { question: [{
|
|
77
110
|
type: Input
|
|
78
111
|
}], validate: [{
|
|
79
112
|
type: Output
|
|
80
113
|
}] } });
|
|
81
|
-
//# 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":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAS,MAAM,eAAe,CAAC;;;;;;AAqB9E,MAAM,OAAO,qBAAqB;IAwBhC,YAAoB,cAA8B;QAA9B,mBAAc,GAAd,cAAc,CAAgB;QAvBzC,aAAQ,GAAQ,EAAE,CAAC;QAC5B,UAAK,GAAW,CAAC,CAAC;QAClB,aAAQ,GAAY,KAAK,CAAC;QAC1B,SAAI,GAAW,EAAE,CAAC;QAClB,gBAAW,GAAW,EAAE,CAAC;QACzB,uBAAkB,GAAY,IAAI,CAAC;QACnC,gBAAW,GAAY,IAAI,CAAC;QAC5B,gBAAW,GAAY,IAAI,CAAC;QAC5B,oBAAe,GAAY,IAAI,CAAC;QAChC,oBAAe,GAAY,IAAI,CAAC;QAChC,0BAAqB,GAAY,IAAI,CAAC;QACtC,oBAAe,GAAY,IAAI,CAAC;QAChC,mBAAc,GAAa,EAAE,CAAC;QAC9B,mBAAc,GAAa,EAAE,CAAC;QAC9B,mBAAc,GAAkB,EAAE,CAAC;QACnC,oBAAe,GAAe,EAAE,CAAC;QACjC,qBAAgB,GAAS,KAAK,CAAC;QAC/B,sBAAiB,GAAQ,EAAE,CAAC;QAC5B,iBAAY,GAAQ,EAAE,CAAC;QACvB,oBAAe,GAAmB,EAAE,CAAC;QAE3B,aAAQ,GAA2B,IAAI,YAAY,EAAW,CAAC;IAEpB,CAAC;IAEtD,QAAQ;QACN,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IAED,aAAa;QAEX,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC;QACjC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC;QACvC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;QAC/B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,WAAW,CAAC;QACpE,IAAI,CAAC,kBAAkB;YACrB,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,kBAAkB,CAAC;QAC1D,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,WAAW,CAAC;QACpE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,WAAW,CAAC;QACpE,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,eAAe,CAAC;QAC5E,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,eAAe,CAAC;QAC5E,IAAI,CAAC,qBAAqB;YACxB,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,qBAAqB,CAAC;QAC7D,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,eAAe,CAAC;QAE5E,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,cAAc,CAAC;QAE1E,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,cAAc,CAAC;QAG1E,IAAI,CAAC,cAAc,CAAC,kBAAkB,EAAE,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;YAC1D,IAAI,CAAC,eAAe,GAAC,IAAI,CAAC,MAAM,CAAC;YACjC,IAAG,IAAI,CAAC,eAAe,IAAI,CAAE,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,cAAc,CAAE,EAAC;gBACxE,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE;oBAC5D,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAA;gBACnG,CAAC,CAAC,CAAC;aACJ;YACD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC,qBAAqB,CAC7D,IAAI,CAAC,eAAe,EACpB,IAAI,CAAC,WAAW,EAChB,IAAI,CAAC,WAAW,EAChB,IAAI,CAAC,eAAe,CACrB,CAAC;QACF,CAAC,CAAC,CAAC;IACP,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;QAC9B,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;QAC5B,IAAG,IAAI,CAAC,QAAQ,IAAI,CAAC,CAAC,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,KAAG,CAAC,CAAC,EAAC;YAC1E,IAAI,CAAC,gBAAgB,GAAC,IAAI,CAAC;YAC3B,IAAI,CAAC,iBAAiB,GAAC,6BAA6B,CAAC;YACrD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;SAC3C;IACH,CAAC;+GA3EU,qBAAqB;mGAArB,qBAAqB,8HCrBlC,w1FAuCA;;4FDlBa,qBAAqB;kBALjC,SAAS;+BACE,mBAAmB;qGAKpB,QAAQ;sBAAhB,KAAK;gBAqBI,QAAQ;sBAAjB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, Output, OnInit} from '@angular/core';\nimport { CountryService } from '../../services/countryService';\n\ninterface CountryData {\n  value: string;\n  label: string;\n  image: string;\n}\n\ninterface filteredCountry{\n  name:string;\n  flag: string;\n  isd:{};\n  languages:{};\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  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  restrictCountry: boolean = true;\n  allowedCountry: string[] = [];\n  blockedCountry: string[] = [];\n  countryDetails: CountryData[] = [];\n  selectedCountry:CountryData[]=[];\n  validationFailed:boolean=false;\n  validationMessage:string='';\n  mobileNumber:string='';\n  filteredCountry:filteredCountry[]=[];\n\n  @Output() validate : EventEmitter<boolean> = new EventEmitter<boolean>();\n\n  constructor(private countryService: CountryService) {}\n\n  ngOnInit() {\n    this.valueAssigned();\n  }\n\n  valueAssigned() {\n\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.restrictCountry = this.question.formElement.validation.restrictCountry;\n    \n    this.allowedCountry = this.question.formElement.validation.allowedCountry;\n    \n    this.blockedCountry = this.question.formElement.validation.blockedCountry;\n    \n\n    this.countryService.loadCountryDetails().subscribe((data) => {\n      this.filteredCountry=data.result;\n      if(this.restrictCountry && ( this.allowedCountry || this.blockedCountry )){\n        this.filteredCountry = this.filteredCountry.filter(country =>{          \n         return (this.allowedCountry.includes(country.name) || !this.blockedCountry.includes(country.name))\n        });\n      }\n      this.countryDetails = this.countryService.processCountryDetails(\n        this.filteredCountry,\n        this.displayFlag,\n        this.displayCode,\n        this.showCountryName\n      );\n      });\n  }\n\n  validateMobile(){\n    this.validationFailed = false; \n    this.validationMessage = '';\n    if(this.required && (!this.mobileNumber || this.selectedCountry.length===0)){\n      this.validationFailed=true;\n      this.validationMessage='This is a required question';\n      this.validate.emit(this.validationFailed);\n    }\n  }\n}\n","<div [ngClass]=\"'col-' + count\" class=\"mb-5 px-3\">\n  <div  class=\"input-wrapper mb-2\">\n    <label for=\"\">{{question.questionNumber}}.</label> &nbsp;&nbsp;\n  <label>{{ question.question }}</label>&nbsp;\n  <span class=\"text-danger\" *ngIf=\"required\">*</span>\n  <div class=\"svg-wrapper  mb-2 hintIcon\" [attr.data-title]=\"hint\" *ngIf=\"hint\">\n    <svg class=\"hintSvg\"  viewBox=\"0 0 30 30\"  xmlns=\"http://www.w3.org/2000/svg\">\n      <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" 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\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n      <path 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\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n      <path 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\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n    </svg>\n  </div>\n</div>\n  <div class=\"input-group mb-2\">\n    <div class=\"col-xs-5 col-5 col-md-3 px-0 pe-2\">\n      <lib-dropdown\n       [items]=\"countryDetails\"\n      [multiple] = \"false\"\n      [(selectedItems)]=\"selectedCountry\"></lib-dropdown>\n    </div>\n    <input\n      type=\"number\"\n      class=\"form-control col-xs-7 col-7 col-md-9  height mobileField\" \n      [placeholder]=\"placeholder\"\n      aria-label=\"Mobile Number\"\n      [class.invalid]=\"validationFailed\"\n      (blur)=\"validateMobile()\"\n      [(ngModel)]=\"mobileNumber\"\n    />\n  </div>\n  <div *ngIf=\"validationFailed\" class=\"text-danger\">\n    <svg class=\"validationSvg\"  viewBox=\"0 0 24 24\" xmlns=\"http://www.w3.org/2000/svg\">\n      <path 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\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n      <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" 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\" fill=\"#FF0000\" stroke=\"#FF0000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n      <path d=\"M12 12.75L12 7.75\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n      <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\"/>\n      </svg>\n      {{validationMessage}}</div>\n</div>\n"]}
|
|
114
|
+
//# 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":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAU,MAAM,eAAe,CAAC;;;;;;AAqB/E,MAAM,OAAO,qBAAqB;IAwBhC,YAAoB,cAA8B;QAA9B,mBAAc,GAAd,cAAc,CAAgB;QAvBzC,aAAQ,GAAQ,EAAE,CAAC;QAC5B,UAAK,GAAW,CAAC,CAAC;QAClB,aAAQ,GAAY,KAAK,CAAC;QAC1B,SAAI,GAAW,EAAE,CAAC;QAClB,gBAAW,GAAW,EAAE,CAAC;QACzB,uBAAkB,GAAY,IAAI,CAAC;QACnC,gBAAW,GAAY,IAAI,CAAC;QAC5B,gBAAW,GAAY,IAAI,CAAC;QAC5B,oBAAe,GAAY,IAAI,CAAC;QAChC,oBAAe,GAAY,IAAI,CAAC;QAChC,0BAAqB,GAAY,IAAI,CAAC;QACtC,oBAAe,GAAY,IAAI,CAAC;QAChC,mBAAc,GAAa,EAAE,CAAC;QAC9B,mBAAc,GAAa,EAAE,CAAC;QAC9B,mBAAc,GAAkB,EAAE,CAAC;QACnC,oBAAe,GAAkB,EAAE,CAAC;QACpC,qBAAgB,GAAY,KAAK,CAAC;QAClC,sBAAiB,GAAW,EAAE,CAAC;QAC/B,iBAAY,GAAW,EAAE,CAAC;QAC1B,oBAAe,GAAsB,EAAE,CAAC;QAE9B,aAAQ,GAA0B,IAAI,YAAY,EAAW,CAAC;IAElB,CAAC;IAEvD,QAAQ;QACN,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IAED,aAAa;QAEX,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC;QACjC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC;QACvC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;QAC/B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,WAAW,CAAC;QACpE,IAAI,CAAC,kBAAkB;YACrB,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,kBAAkB,CAAC;QAC1D,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,WAAW,CAAC;QACpE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,WAAW,CAAC;QACpE,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,eAAe,CAAC;QAC5E,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,eAAe,CAAC;QAC5E,IAAI,CAAC,qBAAqB;YACxB,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,qBAAqB,CAAC;QAC7D,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,eAAe,CAAC;QAE5E,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,gBAAgB,CAAC;QAE5E,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,gBAAgB,CAAC;QAG5E,IAAI,CAAC,cAAc,CAAC,kBAAkB,EAAE,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;YAC1D,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,MAAM,CAAC;YACnC,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE;gBAC1D,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE;oBAC3D,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAA;gBACrD,CAAC,CAAC,CAAC;aACJ;YACD,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE;gBAC1D,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE;oBAC3D,OAAO,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAA;gBACtD,CAAC,CAAC,CAAC;aACJ;YACD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC,qBAAqB,CAC7D,IAAI,CAAC,eAAe,EACpB,IAAI,CAAC,WAAW,EAChB,IAAI,CAAC,WAAW,EAChB,IAAI,CAAC,eAAe,CACrB,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAED,eAAe;QACb,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;QAC9B,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;QAE5B,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,CAAC,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,KAAK,CAAC,CAAC,EAAE;YAC9E,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;YAC7B,IAAI,CAAC,iBAAiB,GAAG,6BAA6B,CAAC;SACxD;aAAM;YACL,IAAI,CAAC,YAAY,EAAE,CAAC;SACrB;QAED,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAED,oBAAoB;QAClB,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAED,YAAY;QACV,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,YAAY,EAAE;YACxD,MAAM,WAAW,GAAG,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;YAClD,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,GAAG,WAAW,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;SAC9D;aAAM;YACL,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,EAAE,CAAC;SAC3B;IACH,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;QAC9B,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;QAE5B,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,CAAC,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,KAAK,CAAC,CAAC,EAAE;YAC9E,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;YAC7B,IAAI,CAAC,iBAAiB,GAAG,6BAA6B,CAAC;YACvD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;SAC3C;aAAM;YACL,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;SAC3C;IACH,CAAC;+GA/GU,qBAAqB;mGAArB,qBAAqB,8HCrBlC,67FAyCA;;4FDpBa,qBAAqB;kBALjC,SAAS;+BACE,mBAAmB;qGAKpB,QAAQ;sBAAhB,KAAK;gBAqBI,QAAQ;sBAAjB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, Output, OnInit } from '@angular/core';\nimport { CountryService } from '../../services/countryService';\n\ninterface CountryData {\n  value: string;\n  label: string;\n  image: string;\n}\n\ninterface filteredCountry {\n  name: string;\n  flag: string;\n  isd: {};\n  languages: {};\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  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  restrictCountry: boolean = true;\n  allowedCountry: string[] = [];\n  blockedCountry: string[] = [];\n  countryDetails: CountryData[] = [];\n  selectedCountry: CountryData[] = [];\n  validationFailed: boolean = false;\n  validationMessage: string = '';\n  mobileNumber: string = '';\n  filteredCountry: filteredCountry[] = [];\n\n  @Output() validate: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n  constructor(private countryService: CountryService) { }\n\n  ngOnInit() {\n    this.valueAssigned();\n  }\n\n  valueAssigned() {\n\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.restrictCountry = this.question.formElement.validation.restrictCountry;\n\n    this.allowedCountry = this.question.formElement.validation.allowedCountries;\n\n    this.blockedCountry = this.question.formElement.validation.blockedCountries;\n\n\n    this.countryService.loadCountryDetails().subscribe((data) => {\n      this.filteredCountry = data.result;\n      if (this.restrictCountry && this.allowedCountry.length > 0) {\n        this.filteredCountry = this.filteredCountry.filter(country => {\n          return (this.allowedCountry.includes(country.name))\n        });\n      }\n      if (this.restrictCountry && this.blockedCountry.length > 0) {\n        this.filteredCountry = this.filteredCountry.filter(country => {\n          return (!this.blockedCountry.includes(country.name))\n        });\n      }\n      this.countryDetails = this.countryService.processCountryDetails(\n        this.filteredCountry,\n        this.displayFlag,\n        this.displayCode,\n        this.showCountryName\n      );\n    });\n  }\n\n  onCountryChange() {\n    this.validationFailed = false;\n    this.validationMessage = '';\n\n    if (this.required && (!this.mobileNumber || this.selectedCountry.length === 0)) {\n      this.validationFailed = true;\n      this.validationMessage = 'This is a required question';\n    } else {\n      this.updateAnswer();\n    }\n\n    this.updateAnswer();\n  }\n\n  onMobileNumberChange() {\n    this.updateAnswer();\n  }\n\n  updateAnswer() {\n    if (this.selectedCountry.length > 0 && this.mobileNumber) {\n      const countryCode = this.selectedCountry[0].value;\n      this.question.answer = `${countryCode} ${this.mobileNumber}`;\n    } else {\n      this.question.answer = '';\n    }\n  }\n\n  validateMobile() {\n    this.validationFailed = false;\n    this.validationMessage = '';\n\n    if (this.required && (!this.mobileNumber || this.selectedCountry.length === 0)) {\n      this.validationFailed = true;\n      this.validationMessage = 'This is a required question';\n      this.validate.emit(this.validationFailed);\n    } else {\n      this.updateAnswer();\n      this.validate.emit(this.validationFailed);\n    }\n  }\n}\n","<div [ngClass]=\"'col-' + count\" class=\"mb-5 px-3\">\n  <div  class=\"input-wrapper mb-2\">\n    <label for=\"\">{{question.questionNumber}}.</label> &nbsp;&nbsp;\n  <label>{{ question.question }}</label>&nbsp;\n  <span class=\"text-danger\" *ngIf=\"required\">*</span>\n  <div class=\"svg-wrapper  mb-2 hintIcon\" [attr.data-title]=\"hint\" *ngIf=\"hint\">\n    <svg class=\"hintSvg\"  viewBox=\"0 0 30 30\"  xmlns=\"http://www.w3.org/2000/svg\">\n      <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" 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\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n      <path 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\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n      <path 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\" stroke=\"#323232\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n    </svg>\n  </div>\n</div>\n  <div class=\"input-group mb-2\">\n    <div class=\"col-xs-5 col-5 col-md-3 px-0 pe-2\">\n      <lib-dropdown\n       [items]=\"countryDetails\"\n      [multiple] = \"false\"\n      [(selectedItems)]=\"selectedCountry\"\n      (selectedItemsChange)=\"onCountryChange()\"></lib-dropdown>\n    </div>\n    <input\n      type=\"number\"\n      class=\"form-control col-xs-7 col-7 col-md-9  height mobileField\" \n      [placeholder]=\"placeholder\"\n      aria-label=\"Mobile Number\"\n      [class.invalid]=\"validationFailed\"\n      (blur)=\"validateMobile()\"\n      [(ngModel)]=\"mobileNumber\"\n      (ngModelChange)=\"onMobileNumberChange()\"\n    />\n  </div>\n  <div *ngIf=\"validationFailed\" class=\"text-danger\">\n    <svg class=\"validationSvg\"  viewBox=\"0 0 24 24\" xmlns=\"http://www.w3.org/2000/svg\">\n      <path 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\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n      <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" 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\" fill=\"#FF0000\" stroke=\"#FF0000\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n      <path d=\"M12 12.75L12 7.75\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n      <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\"/>\n      </svg>\n      {{validationMessage}}</div>\n</div>\n"]}
|