master-control 0.4.65 → 0.4.67

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.
@@ -57,12 +57,12 @@ export class DobComponent {
57
57
  let value = evt.value;
58
58
  // Handle case where we have existing dashes but need to reformat
59
59
  // Split by dash to understand current structure
60
- const parts = value.split('-');
60
+ const parts = value.split('/');
61
61
  // If we have exactly 3 parts (date-month-year), don't add more dashes
62
62
  if (parts.length < 3) {
63
63
  // For first dash after date (2 digits)
64
- if (value.length > 2 && !value.includes('-')) {
65
- evt.value = [value.slice(0, 2), '-', value.slice(2)].join('');
64
+ if (value.length > 2 && !value.includes('/')) {
65
+ evt.value = [value.slice(0, 2), '/', value.slice(2)].join('');
66
66
  }
67
67
  // For second dash after month
68
68
  else if (parts.length === 2) {
@@ -71,7 +71,7 @@ export class DobComponent {
71
71
  // Add dash after numeric month (exactly 2 digits) or alphabetic month (exactly 3 letters)
72
72
  if ((monthPart.length === 2 && /^\d{2}$/.test(monthPart)) ||
73
73
  (monthPart.length === 3 && /^[a-zA-Z]{3}$/.test(monthPart))) {
74
- evt.value = datePart + '-' + monthPart + '-';
74
+ evt.value = datePart + '/' + monthPart + '/';
75
75
  }
76
76
  }
77
77
  }
@@ -93,22 +93,22 @@ export class DobComponent {
93
93
  if (isEditingDate && datePart.length >= 2) {
94
94
  // Trim date part to 2 characters max
95
95
  const validDatePart = datePart.substring(0, 2);
96
- previousValidValue = validDatePart + (parts[1] ? '-' + parts[1] : '') + (parts[2] ? '-' + parts[2] : '');
96
+ previousValidValue = validDatePart + (parts[1] ? '/' + parts[1] : '') + (parts[2] ? '/' + parts[2] : '');
97
97
  }
98
98
  else if (isEditingMonth && monthPart.length >= 2 && /^\d+$/.test(monthPart)) {
99
99
  // Trim numeric month to 2 characters max
100
100
  const validMonthPart = monthPart.substring(0, 2);
101
- previousValidValue = parts[0] + '-' + validMonthPart + (parts[2] ? '-' + parts[2] : '');
101
+ previousValidValue = parts[0] + '/' + validMonthPart + (parts[2] ? '/' + parts[2] : '');
102
102
  }
103
103
  else if (isEditingMonth && monthPart.length >= 3) {
104
104
  // Trim alphabetic month to 3 characters max
105
105
  const validMonthPart = monthPart.substring(0, 3);
106
- previousValidValue = parts[0] + '-' + validMonthPart + (parts[2] ? '-' + parts[2] : '');
106
+ previousValidValue = parts[0] + '/' + validMonthPart + (parts[2] ? '/' + parts[2] : '');
107
107
  }
108
108
  else if (isEditingYear && yearPart.length >= 4) {
109
109
  // Trim year part to 4 characters max
110
110
  const validYearPart = yearPart.substring(0, 4);
111
- previousValidValue = parts[0] + '-' + parts[1] + '-' + validYearPart;
111
+ previousValidValue = parts[0] + '/' + parts[1] + '/' + validYearPart;
112
112
  }
113
113
  // Prevent input if trying to exceed limits by restoring previous value
114
114
  if ((isEditingDate && datePart.length >= 2) ||
@@ -208,4 +208,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
208
208
  }], invalidDate: [{
209
209
  type: Output
210
210
  }] } });
211
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dob.component.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/dob/dob.component.ts","../../../../../projects/master-control/src/lib/dob/dob.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, EventEmitter, input, Output } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\nimport { MomentDateAdapter, MomentDateModule } from '@angular/material-moment-adapter';\nimport { DateAdapter, MAT_DATE_FORMATS } from '@angular/material/core';\nimport { MatDatepickerModule } from '@angular/material/datepicker';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { MasterControlService } from '../master-control.service';\n\n\nexport const MY_DATE_FORMAT = {\n  parse: {\n    dateInput: [\n      'DD-MM-YYYY',\n      'MM/DD/YYYY',\n      'YYYY/MM/DD',\n      'DD/MM/YYYY',\n      'DD MMM YYYY',\n      'DD MMMM YYYY',\n      'DD-MMM-YYYY'\n    ]\n  },\n display: {\n    dateInput: 'DD/MMM/YYYY',\n    monthYearLabel: 'MMM YYYY',\n    dateA11yLabel: 'DD/MMM/YYYY',\n    monthYearA11yLabel: 'MMMM YYYY',\n  },\n};\n\n@Component({\n  selector: 'lib-dob',\n  standalone: true,\n  imports: [MatInputModule, MatFormFieldModule, CommonModule, MatDatepickerModule, MomentDateModule, ReactiveFormsModule],\n    providers: [\n      {\n        provide: NG_VALUE_ACCESSOR,\n        useExisting: DobComponent,\n        multi: true\n      },\n    {\n      provide: DateAdapter,\n      useClass: MomentDateAdapter,\n      deps: []\n    },\n    { provide: MAT_DATE_FORMATS, useValue: MY_DATE_FORMAT }\n  ],\n  templateUrl: './dob.component.html',\n  styleUrl: './dob.component.css',\n})\nexport class DobComponent implements ControlValueAccessor {\n  field: any = input.required<any>();\n  inputValue: any = null;\n  reactiveFormControlobject : any = input<any>();\n  @Output() blur = new EventEmitter<any>();\n  @Output() valueChange = new EventEmitter<any>();\n  @Output() dateSelected = new EventEmitter<any>();\n  @Output() invalidDate = new EventEmitter<any>();\n\n  constructor(public service : MasterControlService) {}\n\n   dateDivisionFormat(event: any) {\n    let evt = event.target;\n\n    // Check if user is deleting (backspace/delete)\n    const isDeleting = event.inputType === 'deleteContentBackward' ||\n                       event.inputType === 'deleteContentForward' ||\n                       !event.data;\n\n    // If deleting, allow normal deletion without auto-adding dashes\n    if (isDeleting) {\n      return;\n    }\n\n    let value = evt.value;\n\n    // Handle case where we have existing dashes but need to reformat\n    // Split by dash to understand current structure\n    const parts = value.split('-');\n\n    // If we have exactly 3 parts (date-month-year), don't add more dashes\n    if (parts.length < 3) {\n       // For first dash after date (2 digits)\n    if (value.length > 2 && !value.includes('-')) {\n      evt.value = [value.slice(0, 2), '-', value.slice(2)].join('');\n    }\n    // For second dash after month\n    else if (parts.length === 2) {\n      const datePart = parts[0];\n      const monthPart = parts[1];\n\n      // Add dash after numeric month (exactly 2 digits) or alphabetic month (exactly 3 letters)\n      if ((monthPart.length === 2 && /^\\d{2}$/.test(monthPart)) ||\n          (monthPart.length === 3 && /^[a-zA-Z]{3}$/.test(monthPart))) {\n        evt.value = datePart + '-' + monthPart + '-';\n      }\n    }\n\n    }\n     const datePart = parts[0] || '';\n      const monthPart = parts[1] || '';\n      const yearPart = parts[2] || '';\n\n     // Prevent further input if limits are reached and restore previous value\n      if ((datePart.length >= 2) ||\n          (monthPart.length >= 2 && /^\\d+$/.test(monthPart)) ||\n          (monthPart.length >= 3 && /^[a-zA-Z]+$/.test(monthPart)) ||\n          (yearPart.length >= 4)) {\n\n        // Get cursor position to determine which part is being edited\n        const cursorPos = evt.selectionStart;\n        const isEditingDate = cursorPos <= 3;\n        const isEditingMonth = cursorPos > 3 && cursorPos <= (3 + monthPart.length);\n        const isEditingYear = cursorPos > (3 + monthPart.length + 1);\n\n        // Reconstruct the previous valid value by trimming excess characters\n        let previousValidValue='';\n        if (isEditingDate && datePart.length >= 2) {\n          // Trim date part to 2 characters max\n          const validDatePart = datePart.substring(0, 2);\n          previousValidValue = validDatePart + (parts[1] ? '-' + parts[1] : '') + (parts[2] ? '-' + parts[2] : '');\n        } else if (isEditingMonth && monthPart.length >= 2 && /^\\d+$/.test(monthPart)) {\n          // Trim numeric month to 2 characters max\n          const validMonthPart = monthPart.substring(0, 2);\n          previousValidValue = parts[0] + '-' + validMonthPart + (parts[2] ? '-' + parts[2] : '');\n        } else if (isEditingMonth && monthPart.length >= 3 ) {\n          // Trim alphabetic month to 3 characters max\n          const validMonthPart = monthPart.substring(0, 3);\n          previousValidValue = parts[0] + '-' + validMonthPart + (parts[2] ? '-' + parts[2] : '');\n        } else if (isEditingYear && yearPart.length >= 4) {\n          // Trim year part to 4 characters max\n          const validYearPart = yearPart.substring(0, 4);\n          previousValidValue = parts[0] + '-' + parts[1] + '-' + validYearPart;\n        }\n\n        // Prevent input if trying to exceed limits by restoring previous value\n        if ((isEditingDate && datePart.length >= 2) ||\n            (isEditingMonth && monthPart.length >= 2 && /^\\d+$/.test(monthPart)) ||\n            (isEditingMonth && monthPart.length >= 3 ) ||\n            (isEditingYear && yearPart.length >= 4)) {\n\n          // Restore the previous valid value\n          setTimeout(() => {\n            evt.value = previousValidValue;\n          }, 0);\n          event.preventDefault();\n          return;\n        }\n      }\n\n  }\n\n\n\n\n\n\n  _onChange: any = (inputValue:any) => {};\n  _unTouched: any = () => {};\n\n  writeValue(obj: any): void{\n    this.inputValue=obj;\n  };\n  registerOnChange(fn: any): void{\n    this._onChange = fn;\n  };\n  registerOnTouched(fn: any): void{\n    this._unTouched = fn;\n  };\n  setDisabledState?(isDisabled: boolean): void{};\n\n  onInputChange(event: any): void {\n    this.inputValue = event.target.value;\n    this._onChange(this.inputValue);\n  }\n\n  onInputBlur(event? : any): void {\n    if (!this.service.checkIfValueIsEmpty(event.target.value)) {\n      if (isNaN(Date.parse(event.target.value))) {\n        event.target.value = '';\n      }\n    }\n    this._unTouched();\n    this.blur.emit(event);\n  }\n\n\n  // Handle datepicker selection\n  onDateChange(event: any): void {\n    if (event.value) {\n      const selectedDate = event.value;\n      this.inputValue = selectedDate;\n      this._onChange(this.inputValue);\n\n      // Emit date selection event\n      this.dateSelected.emit({\n        formattedValue: this.inputValue,\n        dateObject: selectedDate,\n        isValid: true,\n        source: 'datepicker'\n      });\n\n      this.valueChange.emit(this.inputValue);\n    }\n  }\n\n}\n","<label *ngIf=\"field() && field()?.isVisible && field().isShowLabel\" class=\"field-lable\">{{ field()?.label\n  }}<span style=\"color: red\" *ngIf=\"field() && field()?.validators?.isRequired\">*</span></label>\n<mat-form-field [class]=\"'w-100 ' + field()?.fieldName\" appearance=\"outline\" *ngIf=\"field() && field()?.isVisible\" [ngStyle]=\"{\n    '--custom-border-color': field()?.controlStyle?.borderColor ,\n    '--custom-border-width': field()?.controlStyle?.borderWidth ,\n    '--custom-border-radius': field()?.controlStyle?.borderRadius ,\n    '--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\n    '--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\n    '--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\n    '--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\n    '--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\n    '--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\n    '--custom-font-size': field()?.controlStyle?.fontSize ,\n    '--custom-font-weight': field()?.controlStyle?.fontWeight ,\n    '--custom-font-family': field()?.controlStyle?.fontFamily ,\n    '--custom-font-color': field()?.controlStyle?.color ,\n    '--custom-caret-color': field()?.controlStyle?.caretColor ,\n    '--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\n    '--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\n    '--custom-bg-color': field()?.controlStyle?.background ,\n     '--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\n    }\">\n  @if(reactiveFormControlobject()) {\n  <input matInput autocomplete=\"off\" type=\"text\" [name]=\"field()?.fieldName\" [id]=\"field()?.fieldName\"\n    [placeholder]=\"field()?.placeHolder || 'DD-MM-YYYY'\" [required]=\"field()?.validators?.isRequired\"\n    [pattern]=\"field()?.validators?.pattern\" [matDatepicker]=\"picker\" (input)=\"dateDivisionFormat($event)\"\n    [min]=\"field()?.configData?.min\" [max]=\"field()?.configData?.max\" [disabled]=\"field()?.isDisable\"\n    (dateChange)=\"onDateChange($event)\" (blur)=\"onInputBlur($event)\" [value]=\"inputValue\"\n    [formControl]=\"reactiveFormControlobject()\" />\n  }@else {\n  <input matInput autocomplete=\"off\" type=\"text\" [name]=\"field()?.fieldName\" [id]=\"field()?.fieldName\"\n    [placeholder]=\"field()?.placeHolder\" [required]=\"field()?.validators?.isRequired\"\n    [pattern]=\"field()?.validators?.pattern\" [matDatepicker]=\"picker\" (input)=\"dateDivisionFormat($event)\"\n    [min]=\"field()?.configData?.min\" [max]=\"field()?.configData?.max\" [disabled]=\"field()?.isDisable\"\n    (dateChange)=\"onDateChange($event)\" (blur)=\"onInputBlur($event)\" [value]=\"inputValue\" />\n  }\n\n  <mat-datepicker-toggle matSuffix [for]=\"picker\">\n    <img src=\"https://cdn.godigit.com/digitPlusAssets/retail-life-icon/svgicon/date_picker_icon.svg\" style=\"width: 16px\"\n      matDatepickerToggleIcon />\n  </mat-datepicker-toggle>\n  <mat-datepicker #picker></mat-datepicker>\n  <mat-error *ngIf=\"false\">\n    {{ field()?.validators?.isRequiredMessage }}\n  </mat-error>\n</mat-form-field>\n<div class=\"error-message\" *ngIf=\"false\">\n  {{ field()?.validators?.isRequiredMessage }}.\n</div>\n<div class=\"error-message\" *ngIf=\"field()?.configData?.isInvalid\">\n  {{ field()?.validators?.patternMessage }}.\n</div>\n"]}
211
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dob.component.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/dob/dob.component.ts","../../../../../projects/master-control/src/lib/dob/dob.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, EventEmitter, input, Output } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\nimport { MomentDateAdapter, MomentDateModule } from '@angular/material-moment-adapter';\nimport { DateAdapter, MAT_DATE_FORMATS } from '@angular/material/core';\nimport { MatDatepickerModule } from '@angular/material/datepicker';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { MasterControlService } from '../master-control.service';\n\n\nexport const MY_DATE_FORMAT = {\n  parse: {\n    dateInput: [\n      'DD-MM-YYYY',\n      'MM/DD/YYYY',\n      'YYYY/MM/DD',\n      'DD/MM/YYYY',\n      'DD MMM YYYY',\n      'DD MMMM YYYY',\n      'DD-MMM-YYYY'\n    ]\n  },\n display: {\n    dateInput: 'DD/MMM/YYYY',\n    monthYearLabel: 'MMM YYYY',\n    dateA11yLabel: 'DD/MMM/YYYY',\n    monthYearA11yLabel: 'MMMM YYYY',\n  },\n};\n\n@Component({\n  selector: 'lib-dob',\n  standalone: true,\n  imports: [MatInputModule, MatFormFieldModule, CommonModule, MatDatepickerModule, MomentDateModule, ReactiveFormsModule],\n    providers: [\n      {\n        provide: NG_VALUE_ACCESSOR,\n        useExisting: DobComponent,\n        multi: true\n      },\n    {\n      provide: DateAdapter,\n      useClass: MomentDateAdapter,\n      deps: []\n    },\n    { provide: MAT_DATE_FORMATS, useValue: MY_DATE_FORMAT }\n  ],\n  templateUrl: './dob.component.html',\n  styleUrl: './dob.component.css',\n})\nexport class DobComponent implements ControlValueAccessor {\n  field: any = input.required<any>();\n  inputValue: any = null;\n  reactiveFormControlobject : any = input<any>();\n  @Output() blur = new EventEmitter<any>();\n  @Output() valueChange = new EventEmitter<any>();\n  @Output() dateSelected = new EventEmitter<any>();\n  @Output() invalidDate = new EventEmitter<any>();\n\n  constructor(public service : MasterControlService) {}\n\n   dateDivisionFormat(event: any) {\n    let evt = event.target;\n\n    // Check if user is deleting (backspace/delete)\n    const isDeleting = event.inputType === 'deleteContentBackward' ||\n                       event.inputType === 'deleteContentForward' ||\n                       !event.data;\n\n    // If deleting, allow normal deletion without auto-adding dashes\n    if (isDeleting) {\n      return;\n    }\n\n    let value = evt.value;\n\n    // Handle case where we have existing dashes but need to reformat\n    // Split by dash to understand current structure\n    const parts = value.split('/');\n\n    // If we have exactly 3 parts (date-month-year), don't add more dashes\n    if (parts.length < 3) {\n       // For first dash after date (2 digits)\n    if (value.length > 2 && !value.includes('/')) {\n      evt.value = [value.slice(0, 2), '/', value.slice(2)].join('');\n    }\n    // For second dash after month\n    else if (parts.length === 2) {\n      const datePart = parts[0];\n      const monthPart = parts[1];\n\n      // Add dash after numeric month (exactly 2 digits) or alphabetic month (exactly 3 letters)\n      if ((monthPart.length === 2 && /^\\d{2}$/.test(monthPart)) ||\n          (monthPart.length === 3 && /^[a-zA-Z]{3}$/.test(monthPart))) {\n        evt.value = datePart + '/' + monthPart + '/';\n      }\n    }\n\n    }\n     const datePart = parts[0] || '';\n      const monthPart = parts[1] || '';\n      const yearPart = parts[2] || '';\n\n     // Prevent further input if limits are reached and restore previous value\n      if ((datePart.length >= 2) ||\n          (monthPart.length >= 2 && /^\\d+$/.test(monthPart)) ||\n          (monthPart.length >= 3 && /^[a-zA-Z]+$/.test(monthPart)) ||\n          (yearPart.length >= 4)) {\n\n        // Get cursor position to determine which part is being edited\n        const cursorPos = evt.selectionStart;\n        const isEditingDate = cursorPos <= 3;\n        const isEditingMonth = cursorPos > 3 && cursorPos <= (3 + monthPart.length);\n        const isEditingYear = cursorPos > (3 + monthPart.length + 1);\n\n        // Reconstruct the previous valid value by trimming excess characters\n        let previousValidValue='';\n        if (isEditingDate && datePart.length >= 2) {\n          // Trim date part to 2 characters max\n          const validDatePart = datePart.substring(0, 2);\n          previousValidValue = validDatePart + (parts[1] ? '/' + parts[1] : '') + (parts[2] ? '/' + parts[2] : '');\n        } else if (isEditingMonth && monthPart.length >= 2 && /^\\d+$/.test(monthPart)) {\n          // Trim numeric month to 2 characters max\n          const validMonthPart = monthPart.substring(0, 2);\n          previousValidValue = parts[0] + '/' + validMonthPart + (parts[2] ? '/' + parts[2] : '');\n        } else if (isEditingMonth && monthPart.length >= 3 ) {\n          // Trim alphabetic month to 3 characters max\n          const validMonthPart = monthPart.substring(0, 3);\n          previousValidValue = parts[0] + '/' + validMonthPart + (parts[2] ? '/' + parts[2] : '');\n        } else if (isEditingYear && yearPart.length >= 4) {\n          // Trim year part to 4 characters max\n          const validYearPart = yearPart.substring(0, 4);\n          previousValidValue = parts[0] + '/' + parts[1] + '/' + validYearPart;\n        }\n\n        // Prevent input if trying to exceed limits by restoring previous value\n        if ((isEditingDate && datePart.length >= 2) ||\n            (isEditingMonth && monthPart.length >= 2 && /^\\d+$/.test(monthPart)) ||\n            (isEditingMonth && monthPart.length >= 3 ) ||\n            (isEditingYear && yearPart.length >= 4)) {\n\n          // Restore the previous valid value\n          setTimeout(() => {\n            evt.value = previousValidValue;\n          }, 0);\n          event.preventDefault();\n          return;\n        }\n      }\n\n  }\n\n\n\n\n\n\n  _onChange: any = (inputValue:any) => {};\n  _unTouched: any = () => {};\n\n  writeValue(obj: any): void{\n    this.inputValue=obj;\n  };\n  registerOnChange(fn: any): void{\n    this._onChange = fn;\n  };\n  registerOnTouched(fn: any): void{\n    this._unTouched = fn;\n  };\n  setDisabledState?(isDisabled: boolean): void{};\n\n  onInputChange(event: any): void {\n    this.inputValue = event.target.value;\n    this._onChange(this.inputValue);\n  }\n\n  onInputBlur(event? : any): void {\n    if (!this.service.checkIfValueIsEmpty(event.target.value)) {\n      if (isNaN(Date.parse(event.target.value))) {\n        event.target.value = '';\n      }\n    }\n    this._unTouched();\n    this.blur.emit(event);\n  }\n\n\n  // Handle datepicker selection\n  onDateChange(event: any): void {\n    if (event.value) {\n      const selectedDate = event.value;\n      this.inputValue = selectedDate;\n      this._onChange(this.inputValue);\n\n      // Emit date selection event\n      this.dateSelected.emit({\n        formattedValue: this.inputValue,\n        dateObject: selectedDate,\n        isValid: true,\n        source: 'datepicker'\n      });\n\n      this.valueChange.emit(this.inputValue);\n    }\n  }\n\n}\n","<label *ngIf=\"field() && field()?.isVisible && field().isShowLabel\" class=\"field-lable\">{{ field()?.label\n  }}<span style=\"color: red\" *ngIf=\"field() && field()?.validators?.isRequired\">*</span></label>\n<mat-form-field [class]=\"'w-100 ' + field()?.fieldName\" appearance=\"outline\" *ngIf=\"field() && field()?.isVisible\" [ngStyle]=\"{\n    '--custom-border-color': field()?.controlStyle?.borderColor ,\n    '--custom-border-width': field()?.controlStyle?.borderWidth ,\n    '--custom-border-radius': field()?.controlStyle?.borderRadius ,\n    '--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\n    '--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\n    '--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\n    '--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\n    '--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\n    '--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\n    '--custom-font-size': field()?.controlStyle?.fontSize ,\n    '--custom-font-weight': field()?.controlStyle?.fontWeight ,\n    '--custom-font-family': field()?.controlStyle?.fontFamily ,\n    '--custom-font-color': field()?.controlStyle?.color ,\n    '--custom-caret-color': field()?.controlStyle?.caretColor ,\n    '--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\n    '--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\n    '--custom-bg-color': field()?.controlStyle?.background ,\n     '--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\n    }\">\n  @if(reactiveFormControlobject()) {\n  <input matInput autocomplete=\"off\" type=\"text\" [name]=\"field()?.fieldName\" [id]=\"field()?.fieldName\"\n    [placeholder]=\"field()?.placeHolder || 'DD-MM-YYYY'\" [required]=\"field()?.validators?.isRequired\"\n    [pattern]=\"field()?.validators?.pattern\" [matDatepicker]=\"picker\" (input)=\"dateDivisionFormat($event)\"\n    [min]=\"field()?.configData?.min\" [max]=\"field()?.configData?.max\" [disabled]=\"field()?.isDisable\"\n    (dateChange)=\"onDateChange($event)\" (blur)=\"onInputBlur($event)\" [value]=\"inputValue\"\n    [formControl]=\"reactiveFormControlobject()\" />\n  }@else {\n  <input matInput autocomplete=\"off\" type=\"text\" [name]=\"field()?.fieldName\" [id]=\"field()?.fieldName\"\n    [placeholder]=\"field()?.placeHolder\" [required]=\"field()?.validators?.isRequired\"\n    [pattern]=\"field()?.validators?.pattern\" [matDatepicker]=\"picker\" (input)=\"dateDivisionFormat($event)\"\n    [min]=\"field()?.configData?.min\" [max]=\"field()?.configData?.max\" [disabled]=\"field()?.isDisable\"\n    (dateChange)=\"onDateChange($event)\" (blur)=\"onInputBlur($event)\" [value]=\"inputValue\" />\n  }\n\n  <mat-datepicker-toggle matSuffix [for]=\"picker\">\n    <img src=\"https://cdn.godigit.com/digitPlusAssets/retail-life-icon/svgicon/date_picker_icon.svg\" style=\"width: 16px\"\n      matDatepickerToggleIcon />\n  </mat-datepicker-toggle>\n  <mat-datepicker #picker></mat-datepicker>\n  <mat-error *ngIf=\"false\">\n    {{ field()?.validators?.isRequiredMessage }}\n  </mat-error>\n</mat-form-field>\n<div class=\"error-message\" *ngIf=\"false\">\n  {{ field()?.validators?.isRequiredMessage }}.\n</div>\n<div class=\"error-message\" *ngIf=\"field()?.configData?.isInvalid\">\n  {{ field()?.validators?.patternMessage }}.\n</div>\n"]}
@@ -1,5 +1,6 @@
1
1
  import { CommonModule } from '@angular/common';
2
2
  import { Component, Input, input } from '@angular/core';
3
+ import { CustomizedTooltipDirective } from '../directives/customized.tooltip.directive';
3
4
  import * as i0 from "@angular/core";
4
5
  import * as i1 from "../master-control.service";
5
6
  import * as i2 from "@angular/common";
@@ -12,14 +13,14 @@ export class InBuiltBenefitComponent {
12
13
  this.service = service;
13
14
  }
14
15
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: InBuiltBenefitComponent, deps: [{ token: i1.MasterControlService }], target: i0.ɵɵFactoryTarget.Component });
15
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: InBuiltBenefitComponent, isStandalone: true, selector: "lib-in-built-benefit", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null }, premiumAmount: { classPropertyName: "premiumAmount", publicName: "premiumAmount", isSignal: false, isRequired: false, transformFunction: null }, premiumAmountShort: { classPropertyName: "premiumAmountShort", publicName: "premiumAmountShort", isSignal: false, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<div class=\"d-flex in-built-card\"\n [ngStyle]=\"{\n'--inbuilt-card-border-color': field()?.controlStyle?.borderColor ,\n'--inbuilt-card-border-width': field()?.controlStyle?.borderWidth ,\n'--inbuilt-card-border-radius': field()?.controlStyle?.borderRadius ,\n'--inbuilt-card-bg-color': field()?.controlStyle?.background ,\n'--inbuilt-card-width': field()?.controlStyle?.width ,\n }\"\n *ngIf=\"field() && field()?.isVisible\"\n>\n <p class=\"w-100 top-box\">\n <span class=\"top-benefit-card\">In-built Benefit</span>\n </p>\n <div>\n <span class=\"premium-header\" *ngIf=\"field()?.configData?.label\">{{ field()?.configData?.label }}</span> <br />\n <span class=\"benefit-text normal-text\" *ngIf=\"field()?.configData?.subText\">\n {{ field()?.configData?.subText }}\n </span>\n <br />\n <span class=\"premium\" *ngIf=\"!this.service.checkIfValueIsEmpty(premiumAmount)\"\n ><b>{{ premiumAmount }}</b> ({{ premiumAmountShort }})</span\n >\n </div>\n <div class=\"m-auto\">\n <img *ngIf=\"field()?.imageUrl\" [src]=\"field().imageUrl\" alt=\"\" />\n </div>\n</div>\n", styles: [".in-built-card{max-width:var(--inbuilt-card-width, 100%)!important;min-height:114px;border-radius:var(--inbuilt-card-border-radius, 12px)!important;border:1px solid #0bb68b;border-color:var(--inbuilt-card-border-color, #0bb68b)!important;border-width:var(--inbuilt-card-border-width, 1px)!important;background:var(--inbuilt-card-bg-color, #e6f7f3)!important;padding:12px 16px;position:relative}.premium-header{font-size:14px;font-weight:700;letter-spacing:0px;line-height:18px;color:#444}.benefit-text{font-size:12px;color:#696969;font-weight:700;letter-spacing:0%;line-height:16px}.premium{font-size:12px;padding:4px 16px;border-radius:4px;height:24px;width:113px;background:#fff;color:#444}.normal-text{font-weight:400}.bold-text{font-weight:700}.top-benefit-card{border-radius:25px;background:#fff;border:1px solid #ececec;height:26px;width:114px;padding:0 6px 5px 12px;font-size:12px;font-weight:400;color:#444;letter-spacing:0%;position:absolute;transform:translate(-6em,-2.2em)}.top-box{position:absolute;text-align:center}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
16
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: InBuiltBenefitComponent, isStandalone: true, selector: "lib-in-built-benefit", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null }, premiumAmount: { classPropertyName: "premiumAmount", publicName: "premiumAmount", isSignal: false, isRequired: false, transformFunction: null }, premiumAmountShort: { classPropertyName: "premiumAmountShort", publicName: "premiumAmountShort", isSignal: false, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<div class=\"d-flex in-built-card\"\n [ngStyle]=\"{\n'--inbuilt-card-border-color': field()?.controlStyle?.borderColor ,\n'--inbuilt-card-border-width': field()?.controlStyle?.borderWidth ,\n'--inbuilt-card-border-radius': field()?.controlStyle?.borderRadius ,\n'--inbuilt-card-bg-color': field()?.controlStyle?.background ,\n'--inbuilt-card-width': field()?.controlStyle?.width ,\n }\"\n *ngIf=\"field() && field()?.isVisible\"\n>\n <p class=\"w-100 top-box\">\n <span class=\"top-benefit-card\">Benefits in Brief</span>\n </p>\n <div class=\"d-flex align-items-start gap-3\">\n <img *ngIf=\"field()?.configData?.imageUrl\" [src]=\"field()?.configData?.imageUrl\" alt=\"Benefit Image\" class=\"benefit-img\" />\n <div>\n <span class=\"premium-header\" *ngIf=\"field()?.configData?.label\">{{ field()?.configData?.label }}</span> <br />\n <span class=\"benefit-text normal-text\" *ngIf=\"field()?.configData?.subText\">\n {{ field()?.configData?.subText }}\n </span>\n <div class=\"buit-in-benefit-text\">\n <span class=\"benefit-text normal-text\" *ngIf=\"field()?.configData?.benefitprefixtext\"> {{ field()?.configData?.benefitprefixtext }} </span>\n <span class=\"highlight\" *ngIf=\"field()?.configData?.benefitHighlighttext\">{{field()?.configData?.benefitHighlighttext}}\n <span [appTooltipTemplate]=\"currentTooltip\" arrowPosition=\"left\" tooltipPosition=\"bottom\"\n *ngIf=\"field().configData?.infoimageUrl && field().configData?.tooltipText\">\n <img [src]=\"field().configData?.infoimageUrl\" class=\"toggle-img mx-1\" />\n </span>\n <ng-template #currentTooltip>\n <span [innerHTML]=\"field().configData?.tooltipText\"></span>\n </ng-template>\n </span>\n </div>\n <br />\n <span class=\"premium\" *ngIf=\"!this.service.checkIfValueIsEmpty(premiumAmount)\">\n <b>{{ premiumAmount }}</b> ({{ premiumAmountShort }})\n </span>\n </div>\n </div>\n <div class=\"m-auto\">\n <img *ngIf=\"field()?.imageUrl\" [src]=\"field().imageUrl\" alt=\"\" />\n </div>\n</div>\n", styles: [".in-built-card{max-width:var(--inbuilt-card-width, 100%)!important;min-height:114px;border-radius:var(--inbuilt-card-border-radius, 12px)!important;border:1px solid #0bb68b;border-color:var(--inbuilt-card-border-color, #0bb68b)!important;border-width:var(--inbuilt-card-border-width, 1px)!important;background:var(--inbuilt-card-bg-color, #e6f7f3)!important;padding:12px 16px;position:relative}.premium-header{font-size:14px;font-weight:700;letter-spacing:0px;line-height:18px;color:#444}.benefit-text{font-size:12px;color:#696969;font-weight:700;letter-spacing:0%;line-height:16px}.premium{font-size:12px;padding:4px 16px;border-radius:4px;height:24px;width:113px;background:#fff;color:#444}.normal-text{font-weight:400}.bold-text{font-weight:700}.top-benefit-card{border-radius:25px;background:#fff;border:1px solid #ececec;height:26px;width:114px;padding:0 6px 5px 12px;font-size:12px;font-weight:400;color:#444;letter-spacing:0%;position:absolute;transform:translate(-6em,-2.2em)}.top-box{position:absolute;text-align:center}.buit-in-benefit-text{display:flex;align-items:center;gap:4px;white-space:nowrap}.highlight{color:#444;font-weight:700;font-size:12px;letter-spacing:0px;line-height:18px}.toggle-img{width:12px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: CustomizedTooltipDirective, selector: "[appTooltipTemplate]", inputs: ["appTooltipTemplate"] }] });
16
17
  }
17
18
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: InBuiltBenefitComponent, decorators: [{
18
19
  type: Component,
19
- args: [{ selector: 'lib-in-built-benefit', standalone: true, imports: [CommonModule], template: "<div class=\"d-flex in-built-card\"\n [ngStyle]=\"{\n'--inbuilt-card-border-color': field()?.controlStyle?.borderColor ,\n'--inbuilt-card-border-width': field()?.controlStyle?.borderWidth ,\n'--inbuilt-card-border-radius': field()?.controlStyle?.borderRadius ,\n'--inbuilt-card-bg-color': field()?.controlStyle?.background ,\n'--inbuilt-card-width': field()?.controlStyle?.width ,\n }\"\n *ngIf=\"field() && field()?.isVisible\"\n>\n <p class=\"w-100 top-box\">\n <span class=\"top-benefit-card\">In-built Benefit</span>\n </p>\n <div>\n <span class=\"premium-header\" *ngIf=\"field()?.configData?.label\">{{ field()?.configData?.label }}</span> <br />\n <span class=\"benefit-text normal-text\" *ngIf=\"field()?.configData?.subText\">\n {{ field()?.configData?.subText }}\n </span>\n <br />\n <span class=\"premium\" *ngIf=\"!this.service.checkIfValueIsEmpty(premiumAmount)\"\n ><b>{{ premiumAmount }}</b> ({{ premiumAmountShort }})</span\n >\n </div>\n <div class=\"m-auto\">\n <img *ngIf=\"field()?.imageUrl\" [src]=\"field().imageUrl\" alt=\"\" />\n </div>\n</div>\n", styles: [".in-built-card{max-width:var(--inbuilt-card-width, 100%)!important;min-height:114px;border-radius:var(--inbuilt-card-border-radius, 12px)!important;border:1px solid #0bb68b;border-color:var(--inbuilt-card-border-color, #0bb68b)!important;border-width:var(--inbuilt-card-border-width, 1px)!important;background:var(--inbuilt-card-bg-color, #e6f7f3)!important;padding:12px 16px;position:relative}.premium-header{font-size:14px;font-weight:700;letter-spacing:0px;line-height:18px;color:#444}.benefit-text{font-size:12px;color:#696969;font-weight:700;letter-spacing:0%;line-height:16px}.premium{font-size:12px;padding:4px 16px;border-radius:4px;height:24px;width:113px;background:#fff;color:#444}.normal-text{font-weight:400}.bold-text{font-weight:700}.top-benefit-card{border-radius:25px;background:#fff;border:1px solid #ececec;height:26px;width:114px;padding:0 6px 5px 12px;font-size:12px;font-weight:400;color:#444;letter-spacing:0%;position:absolute;transform:translate(-6em,-2.2em)}.top-box{position:absolute;text-align:center}\n"] }]
20
+ args: [{ selector: 'lib-in-built-benefit', standalone: true, imports: [CommonModule, CustomizedTooltipDirective], template: "<div class=\"d-flex in-built-card\"\n [ngStyle]=\"{\n'--inbuilt-card-border-color': field()?.controlStyle?.borderColor ,\n'--inbuilt-card-border-width': field()?.controlStyle?.borderWidth ,\n'--inbuilt-card-border-radius': field()?.controlStyle?.borderRadius ,\n'--inbuilt-card-bg-color': field()?.controlStyle?.background ,\n'--inbuilt-card-width': field()?.controlStyle?.width ,\n }\"\n *ngIf=\"field() && field()?.isVisible\"\n>\n <p class=\"w-100 top-box\">\n <span class=\"top-benefit-card\">Benefits in Brief</span>\n </p>\n <div class=\"d-flex align-items-start gap-3\">\n <img *ngIf=\"field()?.configData?.imageUrl\" [src]=\"field()?.configData?.imageUrl\" alt=\"Benefit Image\" class=\"benefit-img\" />\n <div>\n <span class=\"premium-header\" *ngIf=\"field()?.configData?.label\">{{ field()?.configData?.label }}</span> <br />\n <span class=\"benefit-text normal-text\" *ngIf=\"field()?.configData?.subText\">\n {{ field()?.configData?.subText }}\n </span>\n <div class=\"buit-in-benefit-text\">\n <span class=\"benefit-text normal-text\" *ngIf=\"field()?.configData?.benefitprefixtext\"> {{ field()?.configData?.benefitprefixtext }} </span>\n <span class=\"highlight\" *ngIf=\"field()?.configData?.benefitHighlighttext\">{{field()?.configData?.benefitHighlighttext}}\n <span [appTooltipTemplate]=\"currentTooltip\" arrowPosition=\"left\" tooltipPosition=\"bottom\"\n *ngIf=\"field().configData?.infoimageUrl && field().configData?.tooltipText\">\n <img [src]=\"field().configData?.infoimageUrl\" class=\"toggle-img mx-1\" />\n </span>\n <ng-template #currentTooltip>\n <span [innerHTML]=\"field().configData?.tooltipText\"></span>\n </ng-template>\n </span>\n </div>\n <br />\n <span class=\"premium\" *ngIf=\"!this.service.checkIfValueIsEmpty(premiumAmount)\">\n <b>{{ premiumAmount }}</b> ({{ premiumAmountShort }})\n </span>\n </div>\n </div>\n <div class=\"m-auto\">\n <img *ngIf=\"field()?.imageUrl\" [src]=\"field().imageUrl\" alt=\"\" />\n </div>\n</div>\n", styles: [".in-built-card{max-width:var(--inbuilt-card-width, 100%)!important;min-height:114px;border-radius:var(--inbuilt-card-border-radius, 12px)!important;border:1px solid #0bb68b;border-color:var(--inbuilt-card-border-color, #0bb68b)!important;border-width:var(--inbuilt-card-border-width, 1px)!important;background:var(--inbuilt-card-bg-color, #e6f7f3)!important;padding:12px 16px;position:relative}.premium-header{font-size:14px;font-weight:700;letter-spacing:0px;line-height:18px;color:#444}.benefit-text{font-size:12px;color:#696969;font-weight:700;letter-spacing:0%;line-height:16px}.premium{font-size:12px;padding:4px 16px;border-radius:4px;height:24px;width:113px;background:#fff;color:#444}.normal-text{font-weight:400}.bold-text{font-weight:700}.top-benefit-card{border-radius:25px;background:#fff;border:1px solid #ececec;height:26px;width:114px;padding:0 6px 5px 12px;font-size:12px;font-weight:400;color:#444;letter-spacing:0%;position:absolute;transform:translate(-6em,-2.2em)}.top-box{position:absolute;text-align:center}.buit-in-benefit-text{display:flex;align-items:center;gap:4px;white-space:nowrap}.highlight{color:#444;font-weight:700;font-size:12px;letter-spacing:0px;line-height:18px}.toggle-img{width:12px}\n"] }]
20
21
  }], ctorParameters: () => [{ type: i1.MasterControlService }], propDecorators: { premiumAmount: [{
21
22
  type: Input
22
23
  }], premiumAmountShort: [{
23
24
  type: Input
24
25
  }] } });
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW4tYnVpbHQtYmVuZWZpdC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXN0ZXItY29udHJvbC9zcmMvbGliL2luLWJ1aWx0LWJlbmVmaXQvaW4tYnVpbHQtYmVuZWZpdC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXN0ZXItY29udHJvbC9zcmMvbGliL2luLWJ1aWx0LWJlbmVmaXQvaW4tYnVpbHQtYmVuZWZpdC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7O0FBVXhELE1BQU0sT0FBTyx1QkFBdUI7SUFLYjtJQUpyQixLQUFLLEdBQVEsS0FBSyxDQUFDLFFBQVEsRUFBTyxDQUFDO0lBRTFCLGFBQWEsR0FBUSxXQUFXLENBQUM7SUFDakMsa0JBQWtCLEdBQVEsSUFBSSxDQUFDO0lBQ3RDLFlBQW1CLE9BQThCO1FBQTlCLFlBQU8sR0FBUCxPQUFPLENBQXVCO0lBQUcsQ0FBQzt3R0FMNUMsdUJBQXVCOzRGQUF2Qix1QkFBdUIsb2dCQ1hwQywwbENBMkJBLGdrQ0RwQlksWUFBWTs7NEZBSVgsdUJBQXVCO2tCQVBuQyxTQUFTOytCQUNFLHNCQUFzQixjQUNwQixJQUFJLFdBQ1AsQ0FBQyxZQUFZLENBQUM7eUZBT2QsYUFBYTtzQkFBckIsS0FBSztnQkFDRyxrQkFBa0I7c0JBQTFCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1hc3RlckNvbnRyb2xTZXJ2aWNlIH0gZnJvbSAnLi4vbWFzdGVyLWNvbnRyb2wuc2VydmljZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2xpYi1pbi1idWlsdC1iZW5lZml0JyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIHRlbXBsYXRlVXJsOiAnLi9pbi1idWlsdC1iZW5lZml0LmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmw6ICcuL2luLWJ1aWx0LWJlbmVmaXQuY29tcG9uZW50LmNzcycsXG59KVxuZXhwb3J0IGNsYXNzIEluQnVpbHRCZW5lZml0Q29tcG9uZW50IHtcbiAgZmllbGQ6IGFueSA9IGlucHV0LnJlcXVpcmVkPGFueT4oKTtcblxuICBASW5wdXQoKSBwcmVtaXVtQW1vdW50OiBhbnkgPSAn4oK5MSwwMCwwMDAnO1xuICBASW5wdXQoKSBwcmVtaXVtQW1vdW50U2hvcnQ6IGFueSA9ICcxTCc7XG4gICAgY29uc3RydWN0b3IocHVibGljIHNlcnZpY2UgOiBNYXN0ZXJDb250cm9sU2VydmljZSkge31cblxufVxuIiwiPGRpdiBjbGFzcz1cImQtZmxleCBpbi1idWlsdC1jYXJkXCJcbiBbbmdTdHlsZV09XCJ7XG4nLS1pbmJ1aWx0LWNhcmQtYm9yZGVyLWNvbG9yJzogZmllbGQoKT8uY29udHJvbFN0eWxlPy5ib3JkZXJDb2xvciAsXG4nLS1pbmJ1aWx0LWNhcmQtYm9yZGVyLXdpZHRoJzogZmllbGQoKT8uY29udHJvbFN0eWxlPy5ib3JkZXJXaWR0aCAsXG4nLS1pbmJ1aWx0LWNhcmQtYm9yZGVyLXJhZGl1cyc6IGZpZWxkKCk/LmNvbnRyb2xTdHlsZT8uYm9yZGVyUmFkaXVzICxcbictLWluYnVpbHQtY2FyZC1iZy1jb2xvcic6IGZpZWxkKCk/LmNvbnRyb2xTdHlsZT8uYmFja2dyb3VuZCAsXG4nLS1pbmJ1aWx0LWNhcmQtd2lkdGgnOiBmaWVsZCgpPy5jb250cm9sU3R5bGU/LndpZHRoICxcbiB9XCJcbiAqbmdJZj1cImZpZWxkKCkgJiYgZmllbGQoKT8uaXNWaXNpYmxlXCJcbj5cbiAgPHAgY2xhc3M9XCJ3LTEwMCB0b3AtYm94XCI+XG4gICAgPHNwYW4gY2xhc3M9XCJ0b3AtYmVuZWZpdC1jYXJkXCI+SW4tYnVpbHQgQmVuZWZpdDwvc3Bhbj5cbiAgPC9wPlxuICA8ZGl2PlxuICAgIDxzcGFuIGNsYXNzPVwicHJlbWl1bS1oZWFkZXJcIiAqbmdJZj1cImZpZWxkKCk/LmNvbmZpZ0RhdGE/LmxhYmVsXCI+e3sgZmllbGQoKT8uY29uZmlnRGF0YT8ubGFiZWwgfX08L3NwYW4+IDxiciAvPlxuICAgIDxzcGFuIGNsYXNzPVwiYmVuZWZpdC10ZXh0IG5vcm1hbC10ZXh0XCIgKm5nSWY9XCJmaWVsZCgpPy5jb25maWdEYXRhPy5zdWJUZXh0XCI+XG4gICAgICB7eyBmaWVsZCgpPy5jb25maWdEYXRhPy5zdWJUZXh0IH19XG4gICAgICA8L3NwYW4+XG4gICAgPGJyIC8+XG4gICAgPHNwYW4gY2xhc3M9XCJwcmVtaXVtXCIgKm5nSWY9XCIhdGhpcy5zZXJ2aWNlLmNoZWNrSWZWYWx1ZUlzRW1wdHkocHJlbWl1bUFtb3VudClcIlxuICAgICAgPjxiPnt7IHByZW1pdW1BbW91bnQgfX08L2I+ICh7eyBwcmVtaXVtQW1vdW50U2hvcnQgfX0pPC9zcGFuXG4gICAgPlxuICA8L2Rpdj5cbiAgPGRpdiBjbGFzcz1cIm0tYXV0b1wiPlxuICAgIDxpbWcgKm5nSWY9XCJmaWVsZCgpPy5pbWFnZVVybFwiIFtzcmNdPVwiZmllbGQoKS5pbWFnZVVybFwiIGFsdD1cIlwiIC8+XG4gIDwvZGl2PlxuPC9kaXY+XG4iXX0=
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW4tYnVpbHQtYmVuZWZpdC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXN0ZXItY29udHJvbC9zcmMvbGliL2luLWJ1aWx0LWJlbmVmaXQvaW4tYnVpbHQtYmVuZWZpdC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXN0ZXItY29udHJvbC9zcmMvbGliL2luLWJ1aWx0LWJlbmVmaXQvaW4tYnVpbHQtYmVuZWZpdC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXhELE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLDRDQUE0QyxDQUFDOzs7O0FBU3hGLE1BQU0sT0FBTyx1QkFBdUI7SUFLYjtJQUpyQixLQUFLLEdBQVEsS0FBSyxDQUFDLFFBQVEsRUFBTyxDQUFDO0lBRTFCLGFBQWEsR0FBUSxXQUFXLENBQUM7SUFDakMsa0JBQWtCLEdBQVEsSUFBSSxDQUFDO0lBQ3RDLFlBQW1CLE9BQThCO1FBQTlCLFlBQU8sR0FBUCxPQUFPLENBQXVCO0lBQUcsQ0FBQzt3R0FMNUMsdUJBQXVCOzRGQUF2Qix1QkFBdUIsb2dCQ1pwQyxxa0VBMENBLGl3Q0RsQ1ksWUFBWSx3TkFBRywwQkFBMEI7OzRGQUl4Qyx1QkFBdUI7a0JBUG5DLFNBQVM7K0JBQ0Usc0JBQXNCLGNBQ3BCLElBQUksV0FDUCxDQUFDLFlBQVksRUFBRywwQkFBMEIsQ0FBQzt5RkFPM0MsYUFBYTtzQkFBckIsS0FBSztnQkFDRyxrQkFBa0I7c0JBQTFCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1hc3RlckNvbnRyb2xTZXJ2aWNlIH0gZnJvbSAnLi4vbWFzdGVyLWNvbnRyb2wuc2VydmljZSc7XG5pbXBvcnQgeyBDdXN0b21pemVkVG9vbHRpcERpcmVjdGl2ZSB9IGZyb20gJy4uL2RpcmVjdGl2ZXMvY3VzdG9taXplZC50b29sdGlwLmRpcmVjdGl2ZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2xpYi1pbi1idWlsdC1iZW5lZml0JyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSAsIEN1c3RvbWl6ZWRUb29sdGlwRGlyZWN0aXZlXSxcbiAgdGVtcGxhdGVVcmw6ICcuL2luLWJ1aWx0LWJlbmVmaXQuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybDogJy4vaW4tYnVpbHQtYmVuZWZpdC5jb21wb25lbnQuY3NzJyxcbn0pXG5leHBvcnQgY2xhc3MgSW5CdWlsdEJlbmVmaXRDb21wb25lbnQge1xuICBmaWVsZDogYW55ID0gaW5wdXQucmVxdWlyZWQ8YW55PigpO1xuXG4gIEBJbnB1dCgpIHByZW1pdW1BbW91bnQ6IGFueSA9ICfigrkxLDAwLDAwMCc7XG4gIEBJbnB1dCgpIHByZW1pdW1BbW91bnRTaG9ydDogYW55ID0gJzFMJztcbiAgICBjb25zdHJ1Y3RvcihwdWJsaWMgc2VydmljZSA6IE1hc3RlckNvbnRyb2xTZXJ2aWNlKSB7fVxuXG59XG4iLCI8ZGl2IGNsYXNzPVwiZC1mbGV4IGluLWJ1aWx0LWNhcmRcIlxuIFtuZ1N0eWxlXT1cIntcbictLWluYnVpbHQtY2FyZC1ib3JkZXItY29sb3InOiBmaWVsZCgpPy5jb250cm9sU3R5bGU/LmJvcmRlckNvbG9yICxcbictLWluYnVpbHQtY2FyZC1ib3JkZXItd2lkdGgnOiBmaWVsZCgpPy5jb250cm9sU3R5bGU/LmJvcmRlcldpZHRoICxcbictLWluYnVpbHQtY2FyZC1ib3JkZXItcmFkaXVzJzogZmllbGQoKT8uY29udHJvbFN0eWxlPy5ib3JkZXJSYWRpdXMgLFxuJy0taW5idWlsdC1jYXJkLWJnLWNvbG9yJzogZmllbGQoKT8uY29udHJvbFN0eWxlPy5iYWNrZ3JvdW5kICxcbictLWluYnVpbHQtY2FyZC13aWR0aCc6IGZpZWxkKCk/LmNvbnRyb2xTdHlsZT8ud2lkdGggLFxuIH1cIlxuICpuZ0lmPVwiZmllbGQoKSAmJiBmaWVsZCgpPy5pc1Zpc2libGVcIlxuPlxuICA8cCBjbGFzcz1cInctMTAwIHRvcC1ib3hcIj5cbiAgICA8c3BhbiBjbGFzcz1cInRvcC1iZW5lZml0LWNhcmRcIj5CZW5lZml0cyBpbiBCcmllZjwvc3Bhbj5cbiAgPC9wPlxuICA8ZGl2IGNsYXNzPVwiZC1mbGV4IGFsaWduLWl0ZW1zLXN0YXJ0IGdhcC0zXCI+XG4gICAgPGltZyAqbmdJZj1cImZpZWxkKCk/LmNvbmZpZ0RhdGE/LmltYWdlVXJsXCIgW3NyY109XCJmaWVsZCgpPy5jb25maWdEYXRhPy5pbWFnZVVybFwiIGFsdD1cIkJlbmVmaXQgSW1hZ2VcIiBjbGFzcz1cImJlbmVmaXQtaW1nXCIgLz5cbiAgICA8ZGl2PlxuICAgICAgPHNwYW4gY2xhc3M9XCJwcmVtaXVtLWhlYWRlclwiICpuZ0lmPVwiZmllbGQoKT8uY29uZmlnRGF0YT8ubGFiZWxcIj57eyBmaWVsZCgpPy5jb25maWdEYXRhPy5sYWJlbCB9fTwvc3Bhbj4gPGJyIC8+XG4gICAgICA8c3BhbiBjbGFzcz1cImJlbmVmaXQtdGV4dCBub3JtYWwtdGV4dFwiICpuZ0lmPVwiZmllbGQoKT8uY29uZmlnRGF0YT8uc3ViVGV4dFwiPlxuICAgICAgICB7eyBmaWVsZCgpPy5jb25maWdEYXRhPy5zdWJUZXh0IH19XG4gICAgICA8L3NwYW4+XG4gICAgICA8ZGl2IGNsYXNzPVwiYnVpdC1pbi1iZW5lZml0LXRleHRcIj5cbiAgICAgICAgPHNwYW4gY2xhc3M9XCJiZW5lZml0LXRleHQgbm9ybWFsLXRleHRcIiAqbmdJZj1cImZpZWxkKCk/LmNvbmZpZ0RhdGE/LmJlbmVmaXRwcmVmaXh0ZXh0XCI+IHt7IGZpZWxkKCk/LmNvbmZpZ0RhdGE/LmJlbmVmaXRwcmVmaXh0ZXh0IH19IDwvc3Bhbj5cbiAgICAgICAgPHNwYW4gY2xhc3M9XCJoaWdobGlnaHRcIiAqbmdJZj1cImZpZWxkKCk/LmNvbmZpZ0RhdGE/LmJlbmVmaXRIaWdobGlnaHR0ZXh0XCI+e3tmaWVsZCgpPy5jb25maWdEYXRhPy5iZW5lZml0SGlnaGxpZ2h0dGV4dH19XG4gICAgICAgICAgPHNwYW4gW2FwcFRvb2x0aXBUZW1wbGF0ZV09XCJjdXJyZW50VG9vbHRpcFwiIGFycm93UG9zaXRpb249XCJsZWZ0XCIgdG9vbHRpcFBvc2l0aW9uPVwiYm90dG9tXCJcbiAgICAgICAgKm5nSWY9XCJmaWVsZCgpLmNvbmZpZ0RhdGE/LmluZm9pbWFnZVVybCAmJiBmaWVsZCgpLmNvbmZpZ0RhdGE/LnRvb2x0aXBUZXh0XCI+XG4gICAgICAgIDxpbWcgW3NyY109XCJmaWVsZCgpLmNvbmZpZ0RhdGE/LmluZm9pbWFnZVVybFwiIGNsYXNzPVwidG9nZ2xlLWltZyBteC0xXCIgLz5cbiAgICAgIDwvc3Bhbj5cbiAgICAgIDxuZy10ZW1wbGF0ZSAjY3VycmVudFRvb2x0aXA+XG4gICAgICAgIDxzcGFuIFtpbm5lckhUTUxdPVwiZmllbGQoKS5jb25maWdEYXRhPy50b29sdGlwVGV4dFwiPjwvc3Bhbj5cbiAgICAgIDwvbmctdGVtcGxhdGU+XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgIDwvZGl2PlxuICAgICAgPGJyIC8+XG4gICAgICA8c3BhbiBjbGFzcz1cInByZW1pdW1cIiAqbmdJZj1cIiF0aGlzLnNlcnZpY2UuY2hlY2tJZlZhbHVlSXNFbXB0eShwcmVtaXVtQW1vdW50KVwiPlxuICAgICAgICA8Yj57eyBwcmVtaXVtQW1vdW50IH19PC9iPiAoe3sgcHJlbWl1bUFtb3VudFNob3J0IH19KVxuICAgICAgPC9zcGFuPlxuICAgIDwvZGl2PlxuICA8L2Rpdj5cbiAgPGRpdiBjbGFzcz1cIm0tYXV0b1wiPlxuICAgIDxpbWcgKm5nSWY9XCJmaWVsZCgpPy5pbWFnZVVybFwiIFtzcmNdPVwiZmllbGQoKS5pbWFnZVVybFwiIGFsdD1cIlwiIC8+XG4gIDwvZGl2PlxuPC9kaXY+XG4iXX0=
@@ -1253,12 +1253,12 @@ class DobComponent {
1253
1253
  let value = evt.value;
1254
1254
  // Handle case where we have existing dashes but need to reformat
1255
1255
  // Split by dash to understand current structure
1256
- const parts = value.split('-');
1256
+ const parts = value.split('/');
1257
1257
  // If we have exactly 3 parts (date-month-year), don't add more dashes
1258
1258
  if (parts.length < 3) {
1259
1259
  // For first dash after date (2 digits)
1260
- if (value.length > 2 && !value.includes('-')) {
1261
- evt.value = [value.slice(0, 2), '-', value.slice(2)].join('');
1260
+ if (value.length > 2 && !value.includes('/')) {
1261
+ evt.value = [value.slice(0, 2), '/', value.slice(2)].join('');
1262
1262
  }
1263
1263
  // For second dash after month
1264
1264
  else if (parts.length === 2) {
@@ -1267,7 +1267,7 @@ class DobComponent {
1267
1267
  // Add dash after numeric month (exactly 2 digits) or alphabetic month (exactly 3 letters)
1268
1268
  if ((monthPart.length === 2 && /^\d{2}$/.test(monthPart)) ||
1269
1269
  (monthPart.length === 3 && /^[a-zA-Z]{3}$/.test(monthPart))) {
1270
- evt.value = datePart + '-' + monthPart + '-';
1270
+ evt.value = datePart + '/' + monthPart + '/';
1271
1271
  }
1272
1272
  }
1273
1273
  }
@@ -1289,22 +1289,22 @@ class DobComponent {
1289
1289
  if (isEditingDate && datePart.length >= 2) {
1290
1290
  // Trim date part to 2 characters max
1291
1291
  const validDatePart = datePart.substring(0, 2);
1292
- previousValidValue = validDatePart + (parts[1] ? '-' + parts[1] : '') + (parts[2] ? '-' + parts[2] : '');
1292
+ previousValidValue = validDatePart + (parts[1] ? '/' + parts[1] : '') + (parts[2] ? '/' + parts[2] : '');
1293
1293
  }
1294
1294
  else if (isEditingMonth && monthPart.length >= 2 && /^\d+$/.test(monthPart)) {
1295
1295
  // Trim numeric month to 2 characters max
1296
1296
  const validMonthPart = monthPart.substring(0, 2);
1297
- previousValidValue = parts[0] + '-' + validMonthPart + (parts[2] ? '-' + parts[2] : '');
1297
+ previousValidValue = parts[0] + '/' + validMonthPart + (parts[2] ? '/' + parts[2] : '');
1298
1298
  }
1299
1299
  else if (isEditingMonth && monthPart.length >= 3) {
1300
1300
  // Trim alphabetic month to 3 characters max
1301
1301
  const validMonthPart = monthPart.substring(0, 3);
1302
- previousValidValue = parts[0] + '-' + validMonthPart + (parts[2] ? '-' + parts[2] : '');
1302
+ previousValidValue = parts[0] + '/' + validMonthPart + (parts[2] ? '/' + parts[2] : '');
1303
1303
  }
1304
1304
  else if (isEditingYear && yearPart.length >= 4) {
1305
1305
  // Trim year part to 4 characters max
1306
1306
  const validYearPart = yearPart.substring(0, 4);
1307
- previousValidValue = parts[0] + '-' + parts[1] + '-' + validYearPart;
1307
+ previousValidValue = parts[0] + '/' + parts[1] + '/' + validYearPart;
1308
1308
  }
1309
1309
  // Prevent input if trying to exceed limits by restoring previous value
1310
1310
  if ((isEditingDate && datePart.length >= 2) ||
@@ -3749,11 +3749,11 @@ class InBuiltBenefitComponent {
3749
3749
  this.service = service;
3750
3750
  }
3751
3751
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: InBuiltBenefitComponent, deps: [{ token: MasterControlService }], target: i0.ɵɵFactoryTarget.Component });
3752
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: InBuiltBenefitComponent, isStandalone: true, selector: "lib-in-built-benefit", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null }, premiumAmount: { classPropertyName: "premiumAmount", publicName: "premiumAmount", isSignal: false, isRequired: false, transformFunction: null }, premiumAmountShort: { classPropertyName: "premiumAmountShort", publicName: "premiumAmountShort", isSignal: false, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<div class=\"d-flex in-built-card\"\n [ngStyle]=\"{\n'--inbuilt-card-border-color': field()?.controlStyle?.borderColor ,\n'--inbuilt-card-border-width': field()?.controlStyle?.borderWidth ,\n'--inbuilt-card-border-radius': field()?.controlStyle?.borderRadius ,\n'--inbuilt-card-bg-color': field()?.controlStyle?.background ,\n'--inbuilt-card-width': field()?.controlStyle?.width ,\n }\"\n *ngIf=\"field() && field()?.isVisible\"\n>\n <p class=\"w-100 top-box\">\n <span class=\"top-benefit-card\">In-built Benefit</span>\n </p>\n <div>\n <span class=\"premium-header\" *ngIf=\"field()?.configData?.label\">{{ field()?.configData?.label }}</span> <br />\n <span class=\"benefit-text normal-text\" *ngIf=\"field()?.configData?.subText\">\n {{ field()?.configData?.subText }}\n </span>\n <br />\n <span class=\"premium\" *ngIf=\"!this.service.checkIfValueIsEmpty(premiumAmount)\"\n ><b>{{ premiumAmount }}</b> ({{ premiumAmountShort }})</span\n >\n </div>\n <div class=\"m-auto\">\n <img *ngIf=\"field()?.imageUrl\" [src]=\"field().imageUrl\" alt=\"\" />\n </div>\n</div>\n", styles: [".in-built-card{max-width:var(--inbuilt-card-width, 100%)!important;min-height:114px;border-radius:var(--inbuilt-card-border-radius, 12px)!important;border:1px solid #0bb68b;border-color:var(--inbuilt-card-border-color, #0bb68b)!important;border-width:var(--inbuilt-card-border-width, 1px)!important;background:var(--inbuilt-card-bg-color, #e6f7f3)!important;padding:12px 16px;position:relative}.premium-header{font-size:14px;font-weight:700;letter-spacing:0px;line-height:18px;color:#444}.benefit-text{font-size:12px;color:#696969;font-weight:700;letter-spacing:0%;line-height:16px}.premium{font-size:12px;padding:4px 16px;border-radius:4px;height:24px;width:113px;background:#fff;color:#444}.normal-text{font-weight:400}.bold-text{font-weight:700}.top-benefit-card{border-radius:25px;background:#fff;border:1px solid #ececec;height:26px;width:114px;padding:0 6px 5px 12px;font-size:12px;font-weight:400;color:#444;letter-spacing:0%;position:absolute;transform:translate(-6em,-2.2em)}.top-box{position:absolute;text-align:center}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
3752
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: InBuiltBenefitComponent, isStandalone: true, selector: "lib-in-built-benefit", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null }, premiumAmount: { classPropertyName: "premiumAmount", publicName: "premiumAmount", isSignal: false, isRequired: false, transformFunction: null }, premiumAmountShort: { classPropertyName: "premiumAmountShort", publicName: "premiumAmountShort", isSignal: false, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<div class=\"d-flex in-built-card\"\n [ngStyle]=\"{\n'--inbuilt-card-border-color': field()?.controlStyle?.borderColor ,\n'--inbuilt-card-border-width': field()?.controlStyle?.borderWidth ,\n'--inbuilt-card-border-radius': field()?.controlStyle?.borderRadius ,\n'--inbuilt-card-bg-color': field()?.controlStyle?.background ,\n'--inbuilt-card-width': field()?.controlStyle?.width ,\n }\"\n *ngIf=\"field() && field()?.isVisible\"\n>\n <p class=\"w-100 top-box\">\n <span class=\"top-benefit-card\">Benefits in Brief</span>\n </p>\n <div class=\"d-flex align-items-start gap-3\">\n <img *ngIf=\"field()?.configData?.imageUrl\" [src]=\"field()?.configData?.imageUrl\" alt=\"Benefit Image\" class=\"benefit-img\" />\n <div>\n <span class=\"premium-header\" *ngIf=\"field()?.configData?.label\">{{ field()?.configData?.label }}</span> <br />\n <span class=\"benefit-text normal-text\" *ngIf=\"field()?.configData?.subText\">\n {{ field()?.configData?.subText }}\n </span>\n <div class=\"buit-in-benefit-text\">\n <span class=\"benefit-text normal-text\" *ngIf=\"field()?.configData?.benefitprefixtext\"> {{ field()?.configData?.benefitprefixtext }} </span>\n <span class=\"highlight\" *ngIf=\"field()?.configData?.benefitHighlighttext\">{{field()?.configData?.benefitHighlighttext}}\n <span [appTooltipTemplate]=\"currentTooltip\" arrowPosition=\"left\" tooltipPosition=\"bottom\"\n *ngIf=\"field().configData?.infoimageUrl && field().configData?.tooltipText\">\n <img [src]=\"field().configData?.infoimageUrl\" class=\"toggle-img mx-1\" />\n </span>\n <ng-template #currentTooltip>\n <span [innerHTML]=\"field().configData?.tooltipText\"></span>\n </ng-template>\n </span>\n </div>\n <br />\n <span class=\"premium\" *ngIf=\"!this.service.checkIfValueIsEmpty(premiumAmount)\">\n <b>{{ premiumAmount }}</b> ({{ premiumAmountShort }})\n </span>\n </div>\n </div>\n <div class=\"m-auto\">\n <img *ngIf=\"field()?.imageUrl\" [src]=\"field().imageUrl\" alt=\"\" />\n </div>\n</div>\n", styles: [".in-built-card{max-width:var(--inbuilt-card-width, 100%)!important;min-height:114px;border-radius:var(--inbuilt-card-border-radius, 12px)!important;border:1px solid #0bb68b;border-color:var(--inbuilt-card-border-color, #0bb68b)!important;border-width:var(--inbuilt-card-border-width, 1px)!important;background:var(--inbuilt-card-bg-color, #e6f7f3)!important;padding:12px 16px;position:relative}.premium-header{font-size:14px;font-weight:700;letter-spacing:0px;line-height:18px;color:#444}.benefit-text{font-size:12px;color:#696969;font-weight:700;letter-spacing:0%;line-height:16px}.premium{font-size:12px;padding:4px 16px;border-radius:4px;height:24px;width:113px;background:#fff;color:#444}.normal-text{font-weight:400}.bold-text{font-weight:700}.top-benefit-card{border-radius:25px;background:#fff;border:1px solid #ececec;height:26px;width:114px;padding:0 6px 5px 12px;font-size:12px;font-weight:400;color:#444;letter-spacing:0%;position:absolute;transform:translate(-6em,-2.2em)}.top-box{position:absolute;text-align:center}.buit-in-benefit-text{display:flex;align-items:center;gap:4px;white-space:nowrap}.highlight{color:#444;font-weight:700;font-size:12px;letter-spacing:0px;line-height:18px}.toggle-img{width:12px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: CustomizedTooltipDirective, selector: "[appTooltipTemplate]", inputs: ["appTooltipTemplate"] }] });
3753
3753
  }
3754
3754
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: InBuiltBenefitComponent, decorators: [{
3755
3755
  type: Component,
3756
- args: [{ selector: 'lib-in-built-benefit', standalone: true, imports: [CommonModule], template: "<div class=\"d-flex in-built-card\"\n [ngStyle]=\"{\n'--inbuilt-card-border-color': field()?.controlStyle?.borderColor ,\n'--inbuilt-card-border-width': field()?.controlStyle?.borderWidth ,\n'--inbuilt-card-border-radius': field()?.controlStyle?.borderRadius ,\n'--inbuilt-card-bg-color': field()?.controlStyle?.background ,\n'--inbuilt-card-width': field()?.controlStyle?.width ,\n }\"\n *ngIf=\"field() && field()?.isVisible\"\n>\n <p class=\"w-100 top-box\">\n <span class=\"top-benefit-card\">In-built Benefit</span>\n </p>\n <div>\n <span class=\"premium-header\" *ngIf=\"field()?.configData?.label\">{{ field()?.configData?.label }}</span> <br />\n <span class=\"benefit-text normal-text\" *ngIf=\"field()?.configData?.subText\">\n {{ field()?.configData?.subText }}\n </span>\n <br />\n <span class=\"premium\" *ngIf=\"!this.service.checkIfValueIsEmpty(premiumAmount)\"\n ><b>{{ premiumAmount }}</b> ({{ premiumAmountShort }})</span\n >\n </div>\n <div class=\"m-auto\">\n <img *ngIf=\"field()?.imageUrl\" [src]=\"field().imageUrl\" alt=\"\" />\n </div>\n</div>\n", styles: [".in-built-card{max-width:var(--inbuilt-card-width, 100%)!important;min-height:114px;border-radius:var(--inbuilt-card-border-radius, 12px)!important;border:1px solid #0bb68b;border-color:var(--inbuilt-card-border-color, #0bb68b)!important;border-width:var(--inbuilt-card-border-width, 1px)!important;background:var(--inbuilt-card-bg-color, #e6f7f3)!important;padding:12px 16px;position:relative}.premium-header{font-size:14px;font-weight:700;letter-spacing:0px;line-height:18px;color:#444}.benefit-text{font-size:12px;color:#696969;font-weight:700;letter-spacing:0%;line-height:16px}.premium{font-size:12px;padding:4px 16px;border-radius:4px;height:24px;width:113px;background:#fff;color:#444}.normal-text{font-weight:400}.bold-text{font-weight:700}.top-benefit-card{border-radius:25px;background:#fff;border:1px solid #ececec;height:26px;width:114px;padding:0 6px 5px 12px;font-size:12px;font-weight:400;color:#444;letter-spacing:0%;position:absolute;transform:translate(-6em,-2.2em)}.top-box{position:absolute;text-align:center}\n"] }]
3756
+ args: [{ selector: 'lib-in-built-benefit', standalone: true, imports: [CommonModule, CustomizedTooltipDirective], template: "<div class=\"d-flex in-built-card\"\n [ngStyle]=\"{\n'--inbuilt-card-border-color': field()?.controlStyle?.borderColor ,\n'--inbuilt-card-border-width': field()?.controlStyle?.borderWidth ,\n'--inbuilt-card-border-radius': field()?.controlStyle?.borderRadius ,\n'--inbuilt-card-bg-color': field()?.controlStyle?.background ,\n'--inbuilt-card-width': field()?.controlStyle?.width ,\n }\"\n *ngIf=\"field() && field()?.isVisible\"\n>\n <p class=\"w-100 top-box\">\n <span class=\"top-benefit-card\">Benefits in Brief</span>\n </p>\n <div class=\"d-flex align-items-start gap-3\">\n <img *ngIf=\"field()?.configData?.imageUrl\" [src]=\"field()?.configData?.imageUrl\" alt=\"Benefit Image\" class=\"benefit-img\" />\n <div>\n <span class=\"premium-header\" *ngIf=\"field()?.configData?.label\">{{ field()?.configData?.label }}</span> <br />\n <span class=\"benefit-text normal-text\" *ngIf=\"field()?.configData?.subText\">\n {{ field()?.configData?.subText }}\n </span>\n <div class=\"buit-in-benefit-text\">\n <span class=\"benefit-text normal-text\" *ngIf=\"field()?.configData?.benefitprefixtext\"> {{ field()?.configData?.benefitprefixtext }} </span>\n <span class=\"highlight\" *ngIf=\"field()?.configData?.benefitHighlighttext\">{{field()?.configData?.benefitHighlighttext}}\n <span [appTooltipTemplate]=\"currentTooltip\" arrowPosition=\"left\" tooltipPosition=\"bottom\"\n *ngIf=\"field().configData?.infoimageUrl && field().configData?.tooltipText\">\n <img [src]=\"field().configData?.infoimageUrl\" class=\"toggle-img mx-1\" />\n </span>\n <ng-template #currentTooltip>\n <span [innerHTML]=\"field().configData?.tooltipText\"></span>\n </ng-template>\n </span>\n </div>\n <br />\n <span class=\"premium\" *ngIf=\"!this.service.checkIfValueIsEmpty(premiumAmount)\">\n <b>{{ premiumAmount }}</b> ({{ premiumAmountShort }})\n </span>\n </div>\n </div>\n <div class=\"m-auto\">\n <img *ngIf=\"field()?.imageUrl\" [src]=\"field().imageUrl\" alt=\"\" />\n </div>\n</div>\n", styles: [".in-built-card{max-width:var(--inbuilt-card-width, 100%)!important;min-height:114px;border-radius:var(--inbuilt-card-border-radius, 12px)!important;border:1px solid #0bb68b;border-color:var(--inbuilt-card-border-color, #0bb68b)!important;border-width:var(--inbuilt-card-border-width, 1px)!important;background:var(--inbuilt-card-bg-color, #e6f7f3)!important;padding:12px 16px;position:relative}.premium-header{font-size:14px;font-weight:700;letter-spacing:0px;line-height:18px;color:#444}.benefit-text{font-size:12px;color:#696969;font-weight:700;letter-spacing:0%;line-height:16px}.premium{font-size:12px;padding:4px 16px;border-radius:4px;height:24px;width:113px;background:#fff;color:#444}.normal-text{font-weight:400}.bold-text{font-weight:700}.top-benefit-card{border-radius:25px;background:#fff;border:1px solid #ececec;height:26px;width:114px;padding:0 6px 5px 12px;font-size:12px;font-weight:400;color:#444;letter-spacing:0%;position:absolute;transform:translate(-6em,-2.2em)}.top-box{position:absolute;text-align:center}.buit-in-benefit-text{display:flex;align-items:center;gap:4px;white-space:nowrap}.highlight{color:#444;font-weight:700;font-size:12px;letter-spacing:0px;line-height:18px}.toggle-img{width:12px}\n"] }]
3757
3757
  }], ctorParameters: () => [{ type: MasterControlService }], propDecorators: { premiumAmount: [{
3758
3758
  type: Input
3759
3759
  }], premiumAmountShort: [{