mis-crystal-design-system 18.1.7-signal-16-test → 18.1.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (38) hide show
  1. package/async-search-dropdown/async-dropdown.component.d.ts +44 -3
  2. package/daterangepicker_v2/tz-drp-container/tz-drp-container.component.d.ts +9 -2
  3. package/esm2022/async-search-dropdown/async-dropdown.component.mjs +147 -37
  4. package/esm2022/datepicker_v2/tz-dp-container/tz-dp-container.component.mjs +35 -22
  5. package/esm2022/daterangepicker_v2/tz-daterangepicker.directive.mjs +6 -3
  6. package/esm2022/daterangepicker_v2/tz-drp-container/tz-drp-container.component.mjs +270 -187
  7. package/esm2022/dynamic-form/dynamic-form.component.mjs +30 -21
  8. package/esm2022/loader/loader.component.mjs +12 -6
  9. package/esm2022/slider/slider.component.mjs +2 -2
  10. package/esm2022/table/sort-icons.directive.mjs +24 -5
  11. package/esm2022/table/table.component.mjs +200 -93
  12. package/esm2022/table/table.module.mjs +7 -5
  13. package/esm2022/timepicker/timepicker.component.mjs +41 -14
  14. package/esm2022/timerangepicker/timerangepicker.component.mjs +73 -23
  15. package/fesm2022/mis-crystal-design-system-async-search-dropdown.mjs +146 -36
  16. package/fesm2022/mis-crystal-design-system-async-search-dropdown.mjs.map +1 -1
  17. package/fesm2022/mis-crystal-design-system-datepicker_v2.mjs +34 -21
  18. package/fesm2022/mis-crystal-design-system-datepicker_v2.mjs.map +1 -1
  19. package/fesm2022/mis-crystal-design-system-daterangepicker_v2.mjs +274 -188
  20. package/fesm2022/mis-crystal-design-system-daterangepicker_v2.mjs.map +1 -1
  21. package/fesm2022/mis-crystal-design-system-dynamic-form.mjs +29 -20
  22. package/fesm2022/mis-crystal-design-system-dynamic-form.mjs.map +1 -1
  23. package/fesm2022/mis-crystal-design-system-loader.mjs +11 -5
  24. package/fesm2022/mis-crystal-design-system-loader.mjs.map +1 -1
  25. package/fesm2022/mis-crystal-design-system-slider.mjs +2 -2
  26. package/fesm2022/mis-crystal-design-system-slider.mjs.map +1 -1
  27. package/fesm2022/mis-crystal-design-system-table.mjs +227 -99
  28. package/fesm2022/mis-crystal-design-system-table.mjs.map +1 -1
  29. package/fesm2022/mis-crystal-design-system-timepicker.mjs +40 -13
  30. package/fesm2022/mis-crystal-design-system-timepicker.mjs.map +1 -1
  31. package/fesm2022/mis-crystal-design-system-timerangepicker.mjs +72 -22
  32. package/fesm2022/mis-crystal-design-system-timerangepicker.mjs.map +1 -1
  33. package/loader/loader.component.d.ts +7 -1
  34. package/package.json +18 -18
  35. package/table/table.component.d.ts +16 -4
  36. package/table/table.module.d.ts +2 -1
  37. package/timepicker/timepicker.component.d.ts +3 -1
  38. package/timerangepicker/timerangepicker.component.d.ts +5 -1
@@ -714,6 +714,7 @@ export class DynamicFormComponent {
714
714
  get formFieldsArray() {
715
715
  return this.formFields();
716
716
  }
717
+ // dynamic-form.component.ts (in constructor)
717
718
  constructor() {
718
719
  /**
719
720
  * formFields: Dynamic fields recieved from the API metadata to build a dynamic form
@@ -751,14 +752,15 @@ export class DynamicFormComponent {
751
752
  this.dynamicForm = computed(() => this.dynamicFormSignal());
752
753
  this.dynamicFormAPI = computed(() => this.dynamicFormAPISignal());
753
754
  this.valueChangesSubscription$ = computed(() => this.valueChangesSubscriptionSignal());
754
- // Watch for changes in input signals and update the form accordingly
755
+ // Watch for changes in **form structure/metadata (formFields)** and update the form accordingly
755
756
  effect(() => {
756
757
  const formFields = this.formFields();
757
- const formValues = this.formValues();
758
- // Only update if we have form fields (formValues can be empty)
759
- if (formFields) {
760
- // Use untracked to prevent infinite loops when setting signals
761
- untracked(() => {
758
+ // Use untracked to access formValues so that this effect only runs when formFields changes,
759
+ // not when the formValues output (which feeds back as an input) changes.
760
+ untracked(() => {
761
+ const formValues = this.formValues();
762
+ // Only update if we have form fields
763
+ if (formFields) {
762
764
  const form = this.generateDynamicForm(formFields, formValues);
763
765
  this.dynamicFormSignal.set(form);
764
766
  // Re-subscribe to form changes
@@ -774,8 +776,10 @@ export class DynamicFormComponent {
774
776
  return this.generateDynamicFieldsValueObject(form.value.dynamicFields);
775
777
  }
776
778
  });
777
- });
778
- }
779
+ // Also, emit the initial or updated values right after generating the form
780
+ this.onFormValueChanges();
781
+ }
782
+ });
779
783
  });
780
784
  }
781
785
  ngOnInit() {
@@ -868,7 +872,7 @@ export class DynamicFormComponent {
868
872
  }
869
873
  updateSubDynamicFields(field, formGroup, value) {
870
874
  if (field.subFields?.length > 0) {
871
- let subFieldsControls = this.generateSubDynamicFields(this.formValues, field, value);
875
+ let subFieldsControls = this.generateSubDynamicFields(this.formValues(), field, value);
872
876
  formGroup.removeControl('subFields');
873
877
  formGroup.addControl('subFields', subFieldsControls);
874
878
  }
@@ -938,21 +942,26 @@ export class DynamicFormComponent {
938
942
  mapFormValueToFormField(formField, formValue) {
939
943
  let validators = formField.validators ? [dynamicFieldValidator(formField.validators)] : [];
940
944
  let control = new UntypedFormControl(null, validators);
945
+ /**
946
+ * Extract actual value if formValue has nested structure (for fields with subFields)
947
+ * Format: { value: "actualValue", subFields: {...} }
948
+ */
949
+ const actualValue = formValue?.value !== undefined ? formValue.value : formValue;
941
950
  if (formField.fieldType === "input") {
942
951
  if (formField.fieldInputType === "text" || formField.fieldInputType === "textarea")
943
- control.setValue(formValue ? formValue : "");
952
+ control.setValue(actualValue ? actualValue : "");
944
953
  else if (formField.fieldInputType === "number")
945
- control.setValue(formValue ? formValue : 0);
954
+ control.setValue(actualValue ? actualValue : 0);
946
955
  else if (formField.fieldInputType === "date") {
947
- if (formValue && typeof formValue === "number") {
956
+ if (actualValue && typeof actualValue === "number") {
948
957
  const timezone = (formField.fieldConfig && formField.fieldConfig.timezone) || 'Asia/Kolkata';
949
958
  const format = (formField.fieldConfig && formField.fieldConfig.format) || 'DD/MM/YYYY';
950
- control.setValue(dayjs(formValue).tz(timezone).format(format));
959
+ control.setValue(dayjs(actualValue).tz(timezone).format(format));
951
960
  }
952
- else if (formValue && typeof formValue === "string") {
961
+ else if (actualValue && typeof actualValue === "string") {
953
962
  const timezone = (formField.fieldConfig && formField.fieldConfig.timezone) || 'Asia/Kolkata';
954
963
  const format = (formField.fieldConfig && formField.fieldConfig.format) || 'DD/MM/YYYY';
955
- control.setValue(dayjs.tz(formValue, format, timezone).format(format));
964
+ control.setValue(dayjs.tz(actualValue, format, timezone).format(format));
956
965
  }
957
966
  else {
958
967
  const timezone = (formField.fieldConfig && formField.fieldConfig.timezone) || 'Asia/Kolkata';
@@ -963,11 +972,11 @@ export class DynamicFormComponent {
963
972
  }
964
973
  else if (formField.fieldType === "singleSelect") {
965
974
  const findSelectedValue = () => {
966
- let index = formField.itemsList.findIndex(item => item.value === formValue);
975
+ let index = formField.itemsList.findIndex(item => item.value === actualValue);
967
976
  return index >= 0 ? formField.itemsList[index] : "";
968
977
  };
969
978
  if (formField.fieldInputType === "dropdown") {
970
- if (!formValue)
979
+ if (!actualValue)
971
980
  control.setValue(formField.itemsList[0]);
972
981
  else
973
982
  control.setValue(findSelectedValue());
@@ -977,9 +986,9 @@ export class DynamicFormComponent {
977
986
  }
978
987
  }
979
988
  else if (formField.fieldType === "multiSelect") {
980
- if (formValue && Array.isArray(formValue)) {
989
+ if (actualValue && Array.isArray(actualValue)) {
981
990
  let selectedValues = [];
982
- for (let value of formValue) {
991
+ for (let value of actualValue) {
983
992
  let index = formField.itemsList.findIndex(item => item.value === value);
984
993
  if (index > -1)
985
994
  selectedValues.push({ ...formField.itemsList[index] });
@@ -991,7 +1000,7 @@ export class DynamicFormComponent {
991
1000
  }
992
1001
  }
993
1002
  else if (formField.fieldType === "boolean") {
994
- control.setValue(!!formValue);
1003
+ control.setValue(!!actualValue);
995
1004
  }
996
1005
  else
997
1006
  control.setValue(null);
@@ -1136,4 +1145,4 @@ export const dynamicFieldValidator = (validators) => {
1136
1145
  return errors;
1137
1146
  };
1138
1147
  };
1139
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form.component.js","sourceRoot":"","sources":["../../../../projects/mis-components/dynamic-form/dynamic-form.component.ts","../../../../projects/mis-components/dynamic-form/dynamic-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ContentChild, HostListener, OnDestroy, OnInit, TemplateRef, input, output, signal, computed, effect, untracked } from \"@angular/core\";\nimport { NsDynamicForm } from \"./dynamic-form.namespace\";\nimport { AbstractControl, UntypedFormArray, UntypedFormControl, UntypedFormGroup, ValidationErrors, ValidatorFn, Validators } from \"@angular/forms\";\n\nimport dayjs from 'dayjs';\nimport timezone from 'dayjs/plugin/timezone';\nimport customParseFormat from 'dayjs/plugin/customParseFormat'\n\ndayjs.extend(timezone);\ndayjs.extend(customParseFormat);\nimport { Subscription } from \"rxjs\";\n\n@Component({\n  selector: \"mis-dynamic-form\",\n  templateUrl: \"./dynamic-form.component.html\",\n  styleUrls: [\"./dynamic-form.component.scss\"]\n})\nexport class DynamicFormComponent implements OnInit, OnDestroy {\n  /**\n   * formFields:  Dynamic fields recieved from the API metadata to build a dynamic form\n   * formValues:  Holds the value of the dynamic form with \"key\" being dynamic field \"title\"\n   *              and value being the user input.\n   */\n  formFields = input<Array<NsDynamicForm.IDynamicField>>([]);\n  formValues = input<{ [key: string]: any }>({});\n  // Need to deprecate these inputs and use constants.\n  activeBtnIconUrl = input<string>(\"\");\n  calendarIconUrl = input<string>(\"\");\n  removeIconUrl = input<string>(\"\");\n  removeSepratorForSubFields = input<boolean>(false);\n  /**\n   * dynamicForm: Constructed using formFields and formValues(in case of edit)\n   */\n\n  /**\n   * formUpdated: Emits formValues Object whenever there is a change in the dynamic form.\n   */\n  formUpdated = output<{ [key: string]: any }>();\n  /**\n   * formValid: Emits boolean depending on validity of the form\n   */\n  formValid = output<boolean>();\n  /**\n   * formInitialized: Emits dynamic form API on form initilization\n   */\n  formInitialized = output<any>();\n  fieldRemoved = output<NsDynamicForm.IDynamicField>();\n\n  @ContentChild(\"customInputTextNumber\", { static: false })\n  customInputTextNumber: TemplateRef<Element>;\n  \n  @ContentChild(\"customInputTextarea\", { static: false })\n  customInputTextarea: TemplateRef<Element>;\n\n  @ContentChild(\"customInputDate\", { static: false })\n  customInputDate: TemplateRef<Element>;\n\n  @ContentChild(\"customBooleanToggle\", { static: false })\n  customBooleanToggle: TemplateRef<Element>;\n\n  @ContentChild(\"customSingleSelectDropdown\", { static: false })\n  customSingleSelectDropdown: TemplateRef<Element>;\n\n  @ContentChild(\"customSingleSelectRadio\", { static: false })\n  customSingleSelectRadio: TemplateRef<Element>;\n\n  @ContentChild(\"customMultiSelectCheckbox\", { static: false })\n  customMultiSelectCheckbox: TemplateRef<Element>;\n\n  @ContentChild(\"customMultiSelectDropdown\", { static: false })\n  customMultiSelectDropdown: TemplateRef<Element>;\n\n  // Signal-based state management\n  private readonly dynamicFormSignal = signal<UntypedFormGroup | null>(null);\n  private readonly dynamicFormAPISignal = signal<NsDynamicForm.IDynamicFormAPI | null>(null);\n  private readonly valueChangesSubscriptionSignal = signal<Subscription | null>(null);\n  \n  // Computed properties for template access\n  dynamicForm = computed(() => this.dynamicFormSignal());\n  dynamicFormAPI = computed(() => this.dynamicFormAPISignal());\n  valueChangesSubscription$ = computed(() => this.valueChangesSubscriptionSignal());\n  \n  // Backward compatibility: handle both signal and property access\n  get formFieldsArray() {\n    return this.formFields();\n  }\n  \n\n  constructor() {\n    // Watch for changes in input signals and update the form accordingly\n    effect(() => {\n      const formFields = this.formFields();\n      const formValues = this.formValues();\n      \n      // Only update if we have form fields (formValues can be empty)\n      if (formFields) {\n        // Use untracked to prevent infinite loops when setting signals\n        untracked(() => {\n          const form = this.generateDynamicForm(formFields, formValues);\n          this.dynamicFormSignal.set(form);\n          \n          // Re-subscribe to form changes\n          this.valueChangesSubscriptionSignal()?.unsubscribe();\n          this.valueChangesSubscriptionSignal.set(form.valueChanges.subscribe(formValue => {\n            this.onFormValueChanges();\n          }));\n          \n          // Emit form validity status\n          this.formValid.emit(form.valid);\n          \n          // Update the API with the new form\n          this.dynamicFormAPISignal.set({\n            defaultFormValues: () => {\n              return this.generateDynamicFieldsValueObject(form.value.dynamicFields);\n            }\n          });\n        });\n      }\n    });\n  }\n\n  ngOnInit(): void {\n    // Building the form with proper null checks\n    const formFields = this.formFields() || [];\n    const formValues = this.formValues() || {};\n    \n    // Only create form if we have form fields\n    if (formFields.length > 0) {\n      const form = this.generateDynamicForm(formFields, formValues);\n      this.dynamicFormSignal.set(form);\n    } else {\n      // Create an empty form as fallback\n      const emptyForm = new UntypedFormGroup({\n        dynamicFields: new UntypedFormArray([])\n      });\n      this.dynamicFormSignal.set(emptyForm);\n    }\n\n    // Subscribing to form changes and emiting values.\n    const currentForm = this.dynamicFormSignal();\n    if (currentForm) {\n      this.valueChangesSubscriptionSignal.set(currentForm.valueChanges.subscribe(formValue => {\n        this.onFormValueChanges();\n      }));\n    }\n\n    //api to expose functions\n    this.dynamicFormAPISignal.set({\n      defaultFormValues: () => {\n        return this.generateDynamicFieldsValueObject(this.dynamicForm().value.dynamicFields);\n      }\n    });\n    this.formInitialized.emit(this.dynamicFormAPI());\n    this.formValid.emit(this.dynamicForm().valid);\n  }\n  ngOnDestroy(): void {\n    this.valueChangesSubscription$()?.unsubscribe();\n  }\n  onFormValueChanges(): void {\n    let formValues = this.generateDynamicFieldsValueObject(this.dynamicForm().value.dynamicFields);\n    this.formValid.emit(this.dynamicForm().valid);\n    this.formUpdated.emit(formValues);\n    console.log(formValues)\n  }\n  generateDynamicFieldsValueObject(formValues: Array<any>): { [key: string]: any } {\n    let dynamicFieldsValue = {};\n    formValues.forEach((fieldValue, index) => {\n      if(typeof fieldValue?.value === 'string') fieldValue.value = fieldValue?.value?.trim()\n      let formattedValue = this.mapFormFieldToFormValue(this.formFields()[index], fieldValue.value);\n      if (fieldValue.subFields?.length > 0) {\n        let formattedSubFieldsValues = {}\n        let subField = this.formFields()[index].subFields\n        if(this.formFields()[index].fieldType === 'singleSelect' || this.formFields()[index].fieldType === 'multiSelect') {\n          subField = subField.filter((subField) => subField.parentConfigValue === fieldValue.value.value);\n        }\n        fieldValue.subFields.forEach((subFieldValue, subIndex) => {\n          let subFormField = subField[subIndex]\n          if(typeof subFieldValue?.value === 'string') subFieldValue.value = subFieldValue?.value?.trim()\n          formattedSubFieldsValues[subFormField.configName] = this.mapFormFieldToFormValue(subFormField, subFieldValue)\n        })\n        dynamicFieldsValue[this.formFields()[index].configName] = {\n          value: formattedValue,\n          subFields: formattedSubFieldsValues\n        }\n      }\n      else {\n        dynamicFieldsValue[this.formFields()[index].configName] = formattedValue;\n      }\n    });\n    return dynamicFieldsValue;\n  }\n  generateDynamicForm(\n    formFields: Array<NsDynamicForm.IDynamicField>,\n    formValues: { [key: string]: any }\n  ): UntypedFormGroup {\n    let formArray = new UntypedFormArray([])\n\n    for (let field of formFields) {\n      let fieldValue = formValues[field.configName];\n      let fieldControl = this.mapFormValueToFormField(field, fieldValue);\n      let subFieldsControls = this.generateSubDynamicFields(formValues, field, fieldControl.value);\n      formArray.push(new UntypedFormGroup({\n        value: fieldControl,\n        subFields: subFieldsControls\n      }))\n    }  \n    return new UntypedFormGroup({\n      dynamicFields: formArray\n    })\n  }\n  \n  getDynamicFieldsControls(): UntypedFormArray {\n    return this.dynamicForm().get(\"dynamicFields\") as UntypedFormArray;\n  }\n  updateSubDynamicFields(\n    field: NsDynamicForm.IDynamicField,\n    formGroup: UntypedFormGroup,\n    value: any\n  ): void {\n    if (field.subFields?.length > 0) {\n      let subFieldsControls = this.generateSubDynamicFields(this.formValues, field, value);\n      formGroup.removeControl('subFields')\n      formGroup.addControl('subFields', subFieldsControls)\n    }\n  }\n  updateSelectedValueForSingleSelect(\n    field: NsDynamicForm.IDynamicField,\n    control: UntypedFormControl,\n    formGroup: UntypedFormGroup,\n    value: any\n  ): void {\n    if (control.value?.value !== value.value) {\n      control.setValue(value);\n    }\n    else control.setValue('');\n    this.updateSubDynamicFields(field, formGroup, value);\n    control.markAsTouched();\n  }\n  updateSelectedValueForMultiSelect(\n    field: NsDynamicForm.IDynamicField,\n    control: UntypedFormControl,\n    formGroup: UntypedFormGroup,\n    values: Array<any>\n  ): void {\n    let selectedValues: Array<{ label: string; value: any }> = control.value;\n    for (let value of values) {\n      let itemIndex = selectedValues.findIndex(item => item.label === value.label);\n      if (itemIndex > -1) {\n        selectedValues.splice(itemIndex, 1);\n      } else {\n        selectedValues.push({ ...value });\n      }\n    }\n    control.setValue(selectedValues);\n    this.updateSubDynamicFields(field, formGroup, values);\n    control.markAsTouched();\n  }\n  isCheckBoxSelected(value: string, selectedValues: Array<{ label: string; value: string }>): boolean {\n    return selectedValues.findIndex(item => item.label === value) > -1;\n  }\n\n  findSelectedSubFieldConfig(subfields, value, subFieldIndex) {\n    try{\n      const selectedSubFieldConfig = subfields.filter(item => item.parentConfigValue === value)[subFieldIndex];\n      return selectedSubFieldConfig;\n    }\n    catch(e){\n      throw new Error('Subfield index not found');\n    }\n  }\n\n  matchParentConfig(subfields, value) {\n    if (!subfields || subfields.length === 0) {\n      return false;\n    }\n    return subfields.some(item => item.parentConfigValue === value);\n  }\n\n  generateSubDynamicFields(\n    formValues: any,\n    parentField: NsDynamicForm.IDynamicField,\n    parentValue: Array<{ label: string, value: string | number }> | {label: string, value: string } | string | number | boolean\n  ): UntypedFormArray {\n    let controls = new UntypedFormArray([])\n    let subFields = parentField.subFields\n    let subFieldsValues = formValues[parentField.configName]?.subFields ? formValues[parentField.configName].subFields : {}\n    if(!subFields) return controls;\n    if (parentField.fieldType === 'singleSelect') {\n      subFields = subFields.filter((subField) => subField.parentConfigValue === (<{label: string, value: string }>parentValue)?.value);\n    }\n    else if (parentField.fieldType === 'multiSelect') {\n      let parentValues = new Set((<Array<{ label: string, value: string | number }>>parentValue).map((value) => value.value));\n      subFields = subFields.filter((subField) => parentValues.has(subField.parentConfigValue));\n    }\n\n    if (subFields?.length > 0) {\n        for (let subField of subFields) {\n          controls.push(this.mapFormValueToFormField(subField, subFieldsValues[subField.configName]))\n        }\n      }\n    return controls;\n  }\n  mapFormValueToFormField(formField: NsDynamicForm.IDynamicField, formValue: any): any {\n    let validators = formField.validators ? [dynamicFieldValidator(formField.validators)]: []\n    let control = new UntypedFormControl(null, validators);\n\n    if (formField.fieldType === \"input\") {\n      if (formField.fieldInputType === \"text\" || formField.fieldInputType === \"textarea\") control.setValue(formValue ? formValue : \"\");\n      else if (formField.fieldInputType === \"number\") control.setValue(formValue ? formValue : 0);\n      else if (formField.fieldInputType === \"date\") {\n        if (formValue && typeof formValue === \"number\") {\n          const timezone = (formField.fieldConfig && formField.fieldConfig.timezone) || 'Asia/Kolkata';\n          const format = (formField.fieldConfig && formField.fieldConfig.format) || 'DD/MM/YYYY';\n          control.setValue(dayjs(formValue).tz(timezone).format(format));\n        } else if (formValue && typeof formValue === \"string\") {\n          const timezone = (formField.fieldConfig && formField.fieldConfig.timezone) || 'Asia/Kolkata';\n          const format = (formField.fieldConfig && formField.fieldConfig.format) || 'DD/MM/YYYY';\n          control.setValue(dayjs.tz(formValue, format, timezone).format(format));\n        } else {\n          const timezone = (formField.fieldConfig && formField.fieldConfig.timezone) || 'Asia/Kolkata';\n          const format = (formField.fieldConfig && formField.fieldConfig.format) || 'DD/MM/YYYY';\n          control.setValue(dayjs().tz(timezone).format(format));\n        }\n      }\n    } else if (formField.fieldType === \"singleSelect\") {\n      const findSelectedValue = () => {\n        let index = formField.itemsList.findIndex(item => item.value === formValue)\n        return index >= 0 ? formField.itemsList[index]: \"\";\n      }\n      if (formField.fieldInputType === \"dropdown\") {\n        if (!formValue) control.setValue(formField.itemsList[0]);\n        else control.setValue(findSelectedValue())\n      }\n      else if (formField.fieldInputType === \"radio\") {\n        control.setValue(findSelectedValue())\n      }\n    } else if (formField.fieldType === \"multiSelect\") {\n      if (formValue && Array.isArray(formValue)) {\n        let selectedValues = [];\n        for (let value of formValue) {\n          let index = formField.itemsList.findIndex(item => item.value === value);\n          if (index > -1) selectedValues.push({ ...formField.itemsList[index] });\n        }\n        control.setValue(selectedValues);\n      } else {\n        control.setValue([]);\n      }\n    } else if (formField.fieldType === \"boolean\") {\n      control.setValue(!!formValue);\n    } else control.setValue(null);\n    return control;\n  }\n  mapFormFieldToFormValue(formField: NsDynamicForm.IDynamicField, formValue: any): any {\n    if (formField.fieldType === \"input\") {\n      if (formField.fieldInputType === \"text\" || formField.fieldInputType === \"textarea\") return formValue;\n      else if (formField.fieldInputType === \"number\") return +formValue;\n      else if (formField.fieldInputType === \"date\") {\n        const format = (formField.fieldConfig && formField.fieldConfig.format) || 'DD/MM/YYYY';\n        const timezone = (formField.fieldConfig && formField.fieldConfig.timezone) || 'Asia/Kolkata';\n        return dayjs.tz(formValue, format, timezone).valueOf();\n      }\n    } else if (formField.fieldType === \"singleSelect\") {\n      return formValue?.value ?? '';\n    } else if (formField.fieldType === \"multiSelect\") {\n      return formValue?.map(item => item.value);\n    } else if (formField.fieldType === \"boolean\") {\n      return formValue;\n    } else return formValue;\n  }\n}\n\nexport const dynamicFieldValidator = (validators: Array<NsDynamicForm.IDynamicFieldValidator>): ValidatorFn => {\n  return (control: AbstractControl): ValidationErrors | null => {\n    let value = control.value\n    if (Array.isArray(value)) {\n      return null;\n    }\n    else if (typeof value === 'object') {\n      value = value?.value ? value.value : ''\n    }\n    let errors = null\n\n    validators.forEach((validator) => {\n      let error = null\n      let message = validator.message\n      switch (validator.type) {\n        case \"Required\":\n          error = Validators.required(control);\n          if (!error && typeof value === 'string' && value.trim() === '') {\n            error = { Required: message };\n          }\n          if(error) error = {Required: message}\n          break;\n        case \"MinLength\":\n          error = Validators.minLength(+validator.value)(control)\n          message = message.replace('${0}', error?.minlength.requiredLength)\n          if(error) error = { MinLength: message }\n          break;\n        case \"MaxLength\":\n          error = Validators.maxLength(+validator.value)(control)\n          message = message.replace('${0}', error?.actualLength)\n          if(error) error = { MaxLength: message }\n          break;\n        case \"Email\":\n          error = Validators.email(control)\n          if(error) error = {Email: message}\n          break;\n        case \"Custom\":\n          error = Validators.pattern(`${validator.value}`)(control)\n          if(error) error = {Custom: message}\n          break;\n        default:\n          break;\n      }\n      if (error) errors = { ...errors, ...error }\n    })\n    return errors\n  }\n}","<form [formGroup]=\"dynamicForm()\">\n  <ng-container formArrayName=\"dynamicFields\">\n    <ng-container [formGroupName]=\"i\" *ngFor=\"let fieldControl of getDynamicFieldsControls().controls; let i = index\">\n        <ng-container\n        [ngTemplateOutlet]=\"dynamicField\"\n        [ngTemplateOutletContext]=\"{\n          $implicit: formFieldsArray?.[i],\n          formGroup: fieldControl,\n          control: fieldControl.controls.value\n        }\"\n      >\n      </ng-container>\n      <div class=\"sub-dynamic-form\" *ngIf=\"fieldControl?.value && (!!formFieldsArray?.[i]?.subFields && formFieldsArray?.[i]?.subFields?.length > 0 && matchParentConfig(formFieldsArray?.[i]?.subFields, fieldControl?.controls?.value?.value?.value))\">\n        <ng-container *ngFor=\"let subFieldControl of fieldControl.controls.subFields.controls; let j = index\">\n          <ng-container\n            [ngTemplateOutlet]=\"dynamicField\"\n            [ngTemplateOutletContext]=\"{\n              $implicit: findSelectedSubFieldConfig(formFieldsArray?.[i]?.subFields, fieldControl.controls.value.value.value,j),\n              control: subFieldControl\n            }\">\n          </ng-container>\n        </ng-container>\n      </div>\n    </ng-container>\n  </ng-container>\n</form>\n\n\n<ng-template #dynamicField let-field let-control=\"control\" let-formgroup=\"formGroup\">\n\n  <!-- fieldType: 'input' fieldInputType: 'text' | 'number' -->\n  <ng-container *ngIf=\"field.fieldType === 'input' && (field.fieldInputType === 'text' || field.fieldInputType === 'number')\">\n    <ng-container *ngIf=\"customInputTextNumber; else defaultInputTextNumber\">\n      <ng-template\n        [ngTemplateOutlet]=\"customInputTextNumber\"\n        [ngTemplateOutletContext]=\"{ field: field, control: control, formgroup: formgroup }\"\n      ></ng-template>\n    </ng-container>\n    <ng-template #defaultInputTextNumber>\n      <div class=\"dynamic-field multi-line-field-container\"\n        [ngStyle]=\"{'border-bottom': (formgroup?.controls?.subFields?.controls?.length && removeSepratorForSubFields) ?  'none':''}\">\n        <p class=\"h7 field-title-sm\">\n          {{ field?.title }} <span *ngIf=\"field.validators && field.validators.length > 0\"> *</span>\n        </p>\n        <div style=\"flex-basis: 100%\"></div>\n        <input class=\"input-field ip-text\" [type]=\"field.fieldInputType\" [formControl]=\"control\"\n          (ngModelChange)=\"updateSubDynamicFields(field, formgroup, $event)\" \n          [ngStyle]=\"{'border': control.touched && control.errors ? '1px solid #B00020': ''}\"\n          [placeholder]=\"field.placeholderText ? field.placeholderText : 'Input Text'\" \n          [min]=\"field.fieldInputType === 'number' ? 0 : '' \"/>\n        <ng-container *ngIf=\"control.touched && control.errors\"\n          [ngTemplateOutlet]=\"dynamicFieldErrors\" \n          [ngTemplateOutletContext]=\"{ $implicit: control.errors }\"\n        >\n        </ng-container>\n      </div>\n    </ng-template>\n  </ng-container>\n  \n  <!-- fieldType: 'input' fieldInputType: 'textarea' -->\n  <ng-container *ngIf=\"field.fieldType === 'input' && field.fieldInputType === 'textarea'\">\n    <ng-container *ngIf=\"customInputTextarea; else defaultInputTextarea\">\n      <ng-template\n      [ngTemplateOutlet]=\"customInputTextarea\"\n      [ngTemplateOutletContext]=\"{ field: field, control: control, formgroup: formgroup }\"\n    ></ng-template>\n    </ng-container>\n    <ng-template #defaultInputTextarea>\n      <div class=\"dynamic-field multi-line-field-container\"\n      [ngStyle]=\"{'border-bottom': (formgroup?.controls?.subFields?.controls?.length && removeSepratorForSubFields) ?  'none':''}\">\n        <p class=\"h7 field-title-sm\">\n          {{ field.title }}<span *ngIf=\"field.validators && field.validators.length > 0\"> *</span>\n        </p>\n        <div style=\"flex-basis: 100%\"></div>\n        <textarea class=\"input-field ip-textarea\" type=\"text\"\n          [ngStyle]=\"{'border': control.touched && control.errors ? '1px solid #B00020': ''}\"\n          [placeholder]=\"field.placeholderText ? field.placeholderText : 'Input Text'\" [formControl]=\"control\" (ngModelChange)=\"updateSubDynamicFields(field, formgroup, $event)\"></textarea>\n          <ng-container *ngIf=\"control.touched && control.errors\" [ngTemplateOutlet]=\"dynamicFieldErrors\"\n            [ngTemplateOutletContext]=\"{ $implicit: control.errors }\">\n          </ng-container>\n      </div>\n    </ng-template>\n  </ng-container>\n  \n  <!-- fieldType: 'input' fieldInputType: 'date' -->\n  <ng-container *ngIf=\"field.fieldType === 'input' && field.fieldInputType === 'date'\">\n    <ng-container *ngIf=\"customInputDate; else defaultInputDate\">\n      <ng-template\n        [ngTemplateOutlet]=\"customInputDate\"\n        [ngTemplateOutletContext]=\"{ field: field, control: control, formgroup: formgroup }\"\n      ></ng-template>\n    </ng-container>\n    <ng-template #defaultInputDate>\n      <div class=\"dynamic-field single-line-field-container\"\n      [ngStyle]=\"{'border-bottom': (formgroup?.controls?.subFields?.controls?.length && removeSepratorForSubFields) ?  'none':''}\"\n        *ngIf=\"field.fieldType === 'input' && field.fieldInputType === 'date'\">\n        <p class=\"h6\">\n          {{ field.title }} <span *ngIf=\"field.validators && field.validators.length > 0\"> *</span>\n        </p>\n        <div class=\"date-picker-container\">\n          <input class=\"date-picker\" readonly misTzDp [dpConfig]=\"field.fieldConfig\"\n            (dateChange)=\"control.setValue($event)\" [selectedDate]=\"control.value\" [offsetY]=\"0\"\n            [value]=\"control.value\" #dp />\n          <img alt=\"data-picker\" *ngIf=\"calendarIconUrl()\" class=\"date-picker-icon\" [src]=\"calendarIconUrl()\"\n            (click)=\"dp.click()\" />\n        </div>\n        <ng-container *ngIf=\"control.touched && control.errors\" [ngTemplateOutlet]=\"dynamicFieldErrors\"\n          [ngTemplateOutletContext]=\"{ $implicit: control.errors }\">\n        </ng-container>\n      </div>\n    </ng-template>\n  </ng-container>\n\n  <!-- fieldType: 'boolean' fieldInputType: 'toggle' -->\n  <ng-container *ngIf=\"field.fieldType === 'boolean' && field.fieldInputType === 'toggle'\">\n    <ng-container *ngIf=\"customBooleanToggle; else defaultBooleanToggle\">\n      <ng-template\n        [ngTemplateOutlet]=\"customBooleanToggle\"\n        [ngTemplateOutletContext]=\"{ field: field, control: control, formgroup: formgroup }\"\n      ></ng-template>\n    </ng-container>\n    <ng-template #defaultBooleanToggle>\n      <div class=\"dynamic-field single-line-field-container\"\n      [ngStyle]=\"{'border-bottom': (formgroup?.controls?.subFields?.controls?.length && removeSepratorForSubFields) ?  'none':''}\">\n        <p class=\"h6\">\n          {{ field.title }}<span *ngIf=\"field.validators && field.validators.length > 0\"> *</span>\n        </p>\n        <mis-switch [control]=\"control\" (valueChanged)=\"updateSubDynamicFields(field, formgroup, $event)\"></mis-switch>\n        <ng-container *ngIf=\"control.touched && control.errors\" [ngTemplateOutlet]=\"dynamicFieldErrors\"\n          [ngTemplateOutletContext]=\"{ $implicit: control.errors }\">\n        </ng-container>\n      </div>    \n    </ng-template>\n  </ng-container>\n\n  <!-- fieldType: 'singleSelect' fieldInputType: 'dropdown' -->\n  <ng-container *ngIf=\"field.fieldType === 'singleSelect' && field.fieldInputType === 'dropdown'\">\n    <ng-container *ngIf=\"customSingleSelectDropdown; else defaultSingleSelectDropdown\">\n      <ng-template\n        [ngTemplateOutlet]=\"customSingleSelectDropdown\"\n        [ngTemplateOutletContext]=\"{ field: field, control: control, formgroup: formgroup }\"\n      ></ng-template>\n    </ng-container>\n    <ng-template #defaultSingleSelectDropdown>\n      <div class=\"dynamic-field single-line-field-container\"\n        [ngStyle]=\"{'border-bottom': (formgroup?.controls?.subFields?.controls?.length && removeSepratorForSubFields) ?  'none':''}\">\n        <p class=\"h6\">\n          {{ field.title }}<span *ngIf=\"field.validators && field.validators.length > 0\"> *</span>\n        </p>\n        <div [ngClass]=\"{'removeable-container' : field?.isRemoveable}\">\n          <mis-dropdown [searchEnabled]=\"false\" [width]=\"'140px'\" [data]=\"field.itemsList\" [selectedItem]=\"control.value\"\n          (onChange)=\"updateSelectedValueForSingleSelect(field, control, formgroup, $event);\">\n          </mis-dropdown>\n          <img *ngIf=\"field.isRemoveable && removeIconUrl()\" class=\"remove-icon\" [src]=\"removeIconUrl()\" (click)=\"fieldRemoved.emit(field)\">\n        </div>\n        <ng-container *ngIf=\"control.touched && control.errors\" [ngTemplateOutlet]=\"dynamicFieldErrors\"\n          [ngTemplateOutletContext]=\"{ $implicit: control.errors }\">\n        </ng-container>\n      </div>\n    </ng-template>\n  </ng-container >\n  \n\n  <!-- fieldType: 'singleSelect' fieldInputType: 'radio' -->\n  <ng-container *ngIf=\"field.fieldType === 'singleSelect' && field.fieldInputType === 'radio'\">\n    <ng-container *ngIf=\"customSingleSelectRadio; else defaultSingleSelectRadio\">\n      <ng-template\n        [ngTemplateOutlet]=\"customSingleSelectRadio\"\n        [ngTemplateOutletContext]=\"{ field: field, control: control, formgroup: formgroup }\"\n      ></ng-template>\n    </ng-container>\n    <ng-template #defaultSingleSelectRadio>\n      <div class=\"dynamic-field multi-line-field-container\"\n      [ngStyle]=\"{'border-bottom': (formgroup?.controls?.subFields?.controls?.length && removeSepratorForSubFields) ?  'none':''}\">\n        <p class=\"h7 field-title-sm\">\n          {{ field.title }}<span *ngIf=\"field.validators && field.validators.length > 0\"> *</span>\n        </p>\n        <div style=\"flex-basis: 100%\"></div>\n        <div id=\"checkboxes-container\">\n          <div class=\"radio-checkbox-common\" *ngFor=\"let item of field.itemsList\"\n            [ngClass]=\"{ 'checkbox-active': item.label === control.value?.label }\"\n            (click)=\"updateSelectedValueForSingleSelect(field, control, formgroup, item);\">\n            <img *ngIf=\"(item.label === control.value?.label) && activeBtnIconUrl()\" [src]=\"activeBtnIconUrl()\" alt=\"\" />\n            <p class=\"h6\">{{ item.label }}</p>\n          </div>\n        </div>\n        <ng-container *ngIf=\"control.touched && control.errors\" [ngTemplateOutlet]=\"dynamicFieldErrors\"\n          [ngTemplateOutletContext]=\"{ $implicit: control.errors }\">\n        </ng-container>\n      </div>\n    </ng-template>\n  </ng-container>\n  \n\n  <!-- fieldType: 'multiSelect' fieldInputType: 'checkbox' -->\n  <ng-container *ngIf=\"field.fieldType === 'multiSelect' && field.fieldInputType === 'checkbox'\">\n    <ng-container *ngIf=\"customMultiSelectCheckbox; else defaultMultiSelectCheckbox\">\n      <ng-template\n        [ngTemplateOutlet]=\"customMultiSelectCheckbox\"\n        [ngTemplateOutletContext]=\"{ field: field, control: control, formgroup: formgroup }\"\n      ></ng-template>\n    </ng-container>\n    <ng-template #defaultMultiSelectCheckbox>\n      <div class=\"dynamic-field multi-line-field-container\"\n      [ngStyle]=\"{'border-bottom': (formgroup?.controls?.subFields?.controls?.length && removeSepratorForSubFields) ?  'none':''}\">\n        <p class=\"h7 field-title-sm\">\n          {{ field.title }}<span *ngIf=\"field.validators && field.validators.length > 0\"> *</span>\n        </p>\n        <div style=\"flex-basis: 100%\"></div>\n        <div id=\"checkboxes-container\">\n          <div class=\"radio-checkbox-common\" *ngFor=\"let item of field.itemsList\"\n            [ngClass]=\"{ 'checkbox-active': isCheckBoxSelected(item.label, control.value) }\"\n            (click)=\"updateSelectedValueForMultiSelect(field, control, formgroup, [item])\">\n            <img *ngIf=\"isCheckBoxSelected(item.label, control.value) && activeBtnIconUrl()\" [src]=\"activeBtnIconUrl()\"\n              alt=\"\" />\n            <p class=\"h6\">{{ item.label }}</p>\n          </div>\n        </div>\n        <ng-container *ngIf=\"control.touched && control.errors\" [ngTemplateOutlet]=\"dynamicFieldErrors\"\n          [ngTemplateOutletContext]=\"{ $implicit: control.errors }\">\n        </ng-container>\n      </div>\n    </ng-template>\n  </ng-container>\n\n\n  <!-- fieldType: 'multiSelect' fieldInputType: 'dropdown' -->\n  <ng-container *ngIf=\"field.fieldType === 'multiSelect' && field.fieldInputType === 'dropdown'\">\n    <ng-container *ngIf=\"customMultiSelectDropdown; else defaultMultiSelectDropdown\">\n      <ng-template\n        [ngTemplateOutlet]=\"customMultiSelectDropdown\"\n        [ngTemplateOutletContext]=\"{ field: field, control: control, formgroup: formgroup }\"\n      ></ng-template>\n    </ng-container>\n    <ng-template #defaultMultiSelectDropdown>\n      <div class=\"dynamic-field single-line-field-container\"\n      [ngStyle]=\"{'border-bottom': (formgroup?.controls?.subFields?.controls?.length && removeSepratorForSubFields) ?  'none':''}\">\n        <p class=\"h6\">\n          {{ field.title }}<span *ngIf=\"field.validators && field.validators.length > 0\"> *</span>\n        </p>\n        <mis-multi-select-dropdown [width]=\"'140px'\" [showSelectedCount]=\"true\" [dropdownListWidth]=\"'256px'\"\n          [searchEnabled]=\"false\" [hideApplyButton]=\"true\" [data]=\"field.itemsList\"\n          [selectedItems]=\"control.value\" (onChange)=\"updateSelectedValueForMultiSelect(field, control, formgroup, $event);\"></mis-multi-select-dropdown>\n        <ng-container *ngIf=\"control.touched && control.errors\" [ngTemplateOutlet]=\"dynamicFieldErrors\"\n          [ngTemplateOutletContext]=\"{ $implicit: control.errors }\">\n        </ng-container>\n      </div>\n    </ng-template>\n  </ng-container>\n\n</ng-template>\n\n<ng-template #dynamicFieldErrors let-errors>\n  <div id=\"error-messages-container\">\n    <ng-container *ngFor=\"let error of errors | keyvalue\">\n      <p class=\"h8\">\n        {{\" • &nbsp;\" + error.value}}\n      </p>\n      <div [ngStyle]=\"{ 'flex-basis': '100%', 'height': '0' }\"></div>\n    </ng-container>\n  </div>\n</ng-template>"]}
1148
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form.component.js","sourceRoot":"","sources":["../../../../projects/mis-components/dynamic-form/dynamic-form.component.ts","../../../../projects/mis-components/dynamic-form/dynamic-form.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAgD,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAE1J,OAAO,EAAmB,gBAAgB,EAAE,kBAAkB,EAAE,gBAAgB,EAAiC,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAEpJ,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,QAAQ,MAAM,uBAAuB,CAAC;AAC7C,OAAO,iBAAiB,MAAM,gCAAgC,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;ICOtD,6BAAsG;IACpG,4BAMe;;;;;;;;;;IALb,cAAiC;IACjC,AADA,kDAAiC,8RAI/B;;;IAPR,+BAAmP;IACjP,6GAAsG;IASxG,iBAAM;;;IATsC,cAA6C;IAA7C,qEAA6C;;;IAX3F,iCAAkH;IAC9G,4BAQa;IACf,qFAAmP;;;;;;;IAVvO,oCAAmB;IAE7B,cAAiC;IACjC,AADA,kDAAiC,8KAK/B;IAG2B,cAAkN;IAAlN,ixBAAkN;;;;IAoBnP,6BAAyE;IACvE,kIAGC;;;;;;;;IAFC,cAA0C;IAC1C,AADA,+DAA0C,8FAC0C;;;IAO/D,4BAA8D;IAAC,kBAAC;IAAA,iBAAO;;;IAQ5F,4BAIe;;;;;IAFb,AADA,yDAAuC,4EACkB;;;;IAX3D,AAFF,+BAC+H,YAChG;IAC3B,YAAmB;IAAA,mHAA8D;IACnF,iBAAI;IACJ,0BAAoC;IACpC,iCAIuD;IAHrD,0VAAiB,8DAAgD,KAAC;IADpE,iBAIuD;IACvD,mIAGC;IAEH,iBAAM;;;;;;;IAfJ,gVAA4H;IAE1H,eAAmB;IAAnB,yEAAmB;IAAO,cAAqD;IAArD,4EAAqD;IAG9C,eAA6B;IAI9D,AADA,AADA,AAF+D,AAA9B,8CAA6B,4BAAwB,+GAEH,mFACP,sDACzB;IACtC,cAAuC;IAAvC,gEAAuC;;;IAnB5D,6BAA4H;IAO1H,AANA,qHAAyE,uIAMpC;;;;;IANtB,cAA6B;IAAA,AAA7B,mDAA6B,wCAA2B;;;;IA6BvE,6BAAqE;IACnE,kIAGD;;;;;;;;IAFC,cAAwC;IACxC,AADA,6DAAwC,8FAC4C;;;IAO/D,4BAA8D;IAAC,kBAAC;IAAA,iBAAO;;;IAMxF,4BAEe;;;;;IADb,AADsD,yDAAuC,4EACpC;;;;IAR7D,AAFF,+BAC6H,YAC9F;IAC3B,YAAiB;IAAA,mHAA8D;IACjF,iBAAI;IACJ,0BAAoC;IACpC,oCAE0K;IAAnE,6VAAiB,8DAAgD,KAAC;IAAC,iBAAW;IACnL,mIAC4D;IAEhE,iBAAM;;;;;;;IAXN,gVAA4H;IAExH,eAAiB;IAAjB,8CAAiB;IAAO,cAAqD;IAArD,4EAAqD;IAI7E,eAAmF;IACN,AAA7E,AADA,2HAAmF,mFACP,4BAAwB;IACrF,cAAuC;IAAvC,gEAAuC;;;IAjB9D,6BAAyF;IAOvF,AANA,qHAAqE,uIAMlC;;;;;IANpB,cAA2B;IAAA,AAA3B,iDAA2B,sCAAyB;;;;IAyBnE,6BAA6D;IAC3D,kIAGC;;;;;;;;IAFC,cAAoC;IACpC,AADA,yDAAoC,8FACgD;;;IAQhE,4BAA8D;IAAC,kBAAC;IAAA,iBAAO;;;;IAMzF,+BACyB;IAAvB,kPAAS,cAAU,KAAC;IADtB,iBACyB;;;IADiD,gEAAyB;;;IAGrG,4BAEe;;;;;IADb,AADsD,yDAAuC,4EACpC;;;;IAX3D,AAHF,+BAEyE,YACzD;IACZ,YAAkB;IAAA,yHAA8D;IAClF,iBAAI;IAEF,AADF,+BAAmC,mBAGD;IAD9B,yPAAc,4BAAwB,KAAC;IADzC,iBAEgC;IAChC,uHACyB;IAC3B,iBAAM;IACN,yIAC4D;IAE9D,iBAAM;;;;;;;IAfN,gVAA4H;IAGxH,eAAkB;IAAlB,+CAAkB;IAAO,cAAqD;IAArD,4EAAqD;IAGlC,eAA8B;IAExE,AADuE,AAA/B,AADE,+CAA8B,mCACF,cAAc,4BAC7D;IACD,eAAuB;IAAvB,+CAAuB;IAGlC,cAAuC;IAAvC,gEAAuC;;;IAbxD,kHAEyE;;;IAAtE,2FAAoE;;;IAV3E,6BAAqF;IAOnF,AANA,qHAA6D,sIAM9B;;;;;IANhB,cAAuB;IAAA,AAAvB,6CAAuB,kCAAqB;;;;IA6B3D,6BAAqE;IACnE,kIAGC;;;;;;;;IAFC,cAAwC;IACxC,AADA,6DAAwC,8FAC4C;;;IAOjE,4BAA8D;IAAC,kBAAC;IAAA,iBAAO;;;IAG1F,4BAEe;;;;;IADb,AADsD,yDAAuC,4EACpC;;;;IAL3D,AAFF,+BAC6H,YAC7G;IACZ,YAAiB;IAAA,mHAA8D;IACjF,iBAAI;IACJ,sCAAkG;IAAlE,6VAAgB,8DAAgD,KAAC;IAAC,iBAAa;IAC/G,mIAC4D;IAE9D,iBAAM;;;;;;;IARN,gVAA4H;IAExH,eAAiB;IAAjB,8CAAiB;IAAO,cAAqD;IAArD,4EAAqD;IAEnE,cAAmB;IAAnB,qCAAmB;IAChB,cAAuC;IAAvC,gEAAuC;;;IAd5D,6BAAyF;IAOvF,AANA,qHAAqE,sIAMlC;;;;;IANpB,cAA2B;IAAA,AAA3B,iDAA2B,sCAAyB;;;;IAsBnE,6BAAmF;IACjF,kIAGC;;;;;;;;IAFC,cAA+C;IAC/C,AADA,oEAA+C,8FACqC;;;IAOjE,4BAA8D;IAAC,kBAAC;IAAA,iBAAO;;;;IAMxF,+BAAkI;IAAnC,yQAAS,kCAAwB,KAAC;IAAjI,iBAAkI;;;IAA3D,8DAAuB;;;IAEhG,4BAEe;;;;;IADb,AADsD,yDAAuC,4EACpC;;;;IAV3D,AAFF,+BAC+H,YAC/G;IACZ,YAAiB;IAAA,mHAA8D;IACjF,iBAAI;IAEF,AADF,+BAAgE,uBAEsB;IAApF,2XAAY,uFAAqE,KAAE;IACnF,iBAAe;IACf,iHAAkI;IACpI,iBAAM;IACN,mIAC4D;IAE9D,iBAAM;;;;;;;IAbJ,iVAA4H;IAE1H,eAAiB;IAAjB,8CAAiB;IAAO,cAAqD;IAArD,4EAAqD;IAE1E,cAA0D;IAA1D,uGAA0D;IAC/C,cAAuB;IAA4C,AAAzB,AAAlB,AAAxB,qCAAuB,kBAAkB,4BAAyB,mCAA+B;IAGzG,cAA2C;IAA3C,sEAA2C;IAEpC,cAAuC;IAAvC,gEAAuC;;;IAnB5D,6BAAgG;IAO9F,AANA,qHAAmF,uIAMzC;;;;;IAN3B,cAAkC;IAAA,AAAlC,wDAAkC,6CAAgC;;;;IA4BjF,6BAA6E;IAC3E,kIAGC;;;;;;;;IAFC,cAA4C;IAC5C,AADA,iEAA4C,8FACwC;;;IAOjE,4BAA8D;IAAC,kBAAC;IAAA,iBAAO;;;IAOtF,0BAA6G;;;IAApC,iEAA0B;;;;IAHrG,+BAEiF;IAA/E,uYAAS,yFAAmE,KAAE;IAC9E,uHAA6G;IAC7G,6BAAc;IAAA,YAAgB;IAChC,AADgC,iBAAI,EAC9B;;;;;IAJJ,sIAAsE;IAEhE,cAAiE;IAAjE,mIAAiE;IACzD,eAAgB;IAAhB,oCAAgB;;;IAGlC,4BAEe;;;;;IADb,AADsD,yDAAuC,4EACpC;;;IAb3D,AAFF,+BAC6H,YAC9F;IAC3B,YAAiB;IAAA,mHAA8D;IACjF,iBAAI;IACJ,0BAAoC;IACpC,+BAA+B;IAC7B,iHAEiF;IAInF,iBAAM;IACN,mIAC4D;IAE9D,iBAAM;;;;;;;IAhBN,gVAA4H;IAExH,eAAiB;IAAjB,8CAAiB;IAAO,cAAqD;IAArD,4EAAqD;IAIzB,eAAkB;IAAlB,4CAAkB;IAOzD,cAAuC;IAAvC,gEAAuC;;;IAtB5D,6BAA6F;IAO3F,AANA,qHAA6E,sIAMtC;;;;;IANxB,cAA+B;IAAA,AAA/B,qDAA+B,0CAA6B;;;;IA+B3E,6BAAiF;IAC/E,kIAGC;;;;;;;;IAFC,cAA8C;IAC9C,AADA,mEAA8C,8FACsC;;;IAOjE,4BAA8D;IAAC,kBAAC;IAAA,iBAAO;;;IAOtF,0BACW;;;IADsE,iEAA0B;;;;IAH7G,+BAEiF;IAA/E,uYAAS,0FAAoE,KAAC;IAC9E,uHACW;IACX,6BAAc;IAAA,YAAgB;IAChC,AADgC,iBAAI,EAC9B;;;;;IALJ,mHAAgF;IAE1E,cAAyE;IAAzE,gHAAyE;IAEjE,eAAgB;IAAhB,oCAAgB;;;IAGlC,4BAEe;;;;;IADb,AADsD,yDAAuC,4EACpC;;;IAd3D,AAFF,+BAC6H,YAC9F;IAC3B,YAAiB;IAAA,mHAA8D;IACjF,iBAAI;IACJ,0BAAoC;IACpC,+BAA+B;IAC7B,iHAEiF;IAKnF,iBAAM;IACN,mIAC4D;IAE9D,iBAAM;;;;;;;IAjBN,gVAA4H;IAExH,eAAiB;IAAjB,8CAAiB;IAAO,cAAqD;IAArD,4EAAqD;IAIzB,eAAkB;IAAlB,4CAAkB;IAQzD,cAAuC;IAAvC,gEAAuC;;;IAvB5D,6BAA+F;IAO7F,AANA,qHAAiF,sIAMxC;;;;;IAN1B,cAAiC;IAAA,AAAjC,uDAAiC,4CAA+B;;;;IAgC/E,6BAAiF;IAC/E,kIAGC;;;;;;;;IAFC,cAA8C;IAC9C,AADA,mEAA8C,8FACsC;;;IAOjE,4BAA8D;IAAC,kBAAC;IAAA,iBAAO;;;IAK1F,4BAEe;;;;;IADb,AADsD,yDAAuC,4EACpC;;;;IAP3D,AAFF,+BAC6H,YAC7G;IACZ,YAAiB;IAAA,mHAA8D;IACjF,iBAAI;IACJ,qDAEqH;IAAnF,wYAAY,sFAAoE,KAAE;IAAC,iBAA4B;IACjJ,mIAC4D;IAE9D,iBAAM;;;;;;;IAVN,iVAA4H;IAExH,eAAiB;IAAjB,8CAAiB;IAAO,cAAqD;IAArD,4EAAqD;IAEpD,cAAiB;IAE1C,AADiD,AAAzB,AAAxB,AADsE,AAA3B,AAAlB,+BAAiB,2BAA2B,8BAA8B,wBAC5E,yBAAyB,4BAAyB,oCAC1C;IAClB,cAAuC;IAAvC,gEAAuC;;;IAhB5D,6BAA+F;IAO7F,AANA,qHAAiF,wIAMxC;;;;;IAN1B,cAAiC;IAAA,AAAjC,uDAAiC,4CAA+B;;;IADjF,AAhCA,AA/BA,AA5BA,AAtBA,AA7BA,AAzBA,AA7BA,sGAA4H,yFA6BnC,yFAyBJ,yFA6BI,yFAsBO,yFA4BH,yFA+BE,yFAgCA;;;IApMhF,qIAA2G;IA6B3G,cAAwE;IAAxE,+FAAwE;IAyBxE,cAAoE;IAApE,2FAAoE;IA6BpE,cAAwE;IAAxE,+FAAwE;IAsBxE,cAA+E;IAA/E,sGAA+E;IA4B/E,cAA4E;IAA5E,mGAA4E;IA+B5E,cAA8E;IAA9E,qGAA8E;IAgC9E,cAA8E;IAA9E,qGAA8E;;;IA2B3F,6BAAsD;IACpD,6BAAc;IACZ,YACF;IAAA,iBAAI;IACJ,0BAA+D;;;;IAF7D,eACF;IADE,mEACF;IACK,cAAmD;IAAnD,qDAAmD;;;IAL5D,+BAAmC;IACjC,sGAAsD;;IAMxD,iBAAM;;;IAN4B,cAAoB;IAApB,0DAAoB;;ADtPxD,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;AACvB,KAAK,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC;AAQhC,MAAM,OAAO,oBAAoB;IAiE/B,iEAAiE;IACjE,IAAI,eAAe;QACjB,OAAO,IAAI,CAAC,UAAU,EAAE,CAAC;IAC3B,CAAC;IAED,6CAA6C;IAC/C;QAtEE;;;;WAIG;QACH,eAAU,GAAG,KAAK,CAAqC,EAAE,CAAC,CAAC;QAC3D,eAAU,GAAG,KAAK,CAAyB,EAAE,CAAC,CAAC;QAC/C,oDAAoD;QACpD,qBAAgB,GAAG,KAAK,CAAS,EAAE,CAAC,CAAC;QACrC,oBAAe,GAAG,KAAK,CAAS,EAAE,CAAC,CAAC;QACpC,kBAAa,GAAG,KAAK,CAAS,EAAE,CAAC,CAAC;QAClC,+BAA0B,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QACnD;;WAEG;QAEH;;WAEG;QACH,gBAAW,GAAG,MAAM,EAA0B,CAAC;QAC/C;;WAEG;QACH,cAAS,GAAG,MAAM,EAAW,CAAC;QAC9B;;WAEG;QACH,oBAAe,GAAG,MAAM,EAAO,CAAC;QAChC,iBAAY,GAAG,MAAM,EAA+B,CAAC;QA0BrD,gCAAgC;QACf,sBAAiB,GAAG,MAAM,CAA0B,IAAI,CAAC,CAAC;QAC1D,yBAAoB,GAAG,MAAM,CAAuC,IAAI,CAAC,CAAC;QAC1E,mCAA8B,GAAG,MAAM,CAAsB,IAAI,CAAC,CAAC;QAEpF,0CAA0C;QAC1C,gBAAW,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,CAAC;QACvD,mBAAc,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,oBAAoB,EAAE,CAAC,CAAC;QAC7D,8BAAyB,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,8BAA8B,EAAE,CAAC,CAAC;QASlF,gGAAgG;QAChG,MAAM,CAAC,GAAG,EAAE;YACV,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;YAErC,4FAA4F;YAC5F,yEAAyE;YACzE,SAAS,CAAC,GAAG,EAAE;gBACb,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;gBAErC,qCAAqC;gBACrC,IAAI,UAAU,EAAE,CAAC;oBACf,MAAM,IAAI,GAAG,IAAI,CAAC,mBAAmB,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;oBAC9D,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;oBAEjC,+BAA+B;oBAC/B,IAAI,CAAC,8BAA8B,EAAE,EAAE,WAAW,EAAE,CAAC;oBACrD,IAAI,CAAC,8BAA8B,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE;wBAC9E,IAAI,CAAC,kBAAkB,EAAE,CAAC;oBAC5B,CAAC,CAAC,CAAC,CAAC;oBAEJ,4BAA4B;oBAC5B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;oBAEhC,mCAAmC;oBACnC,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC;wBAC5B,iBAAiB,EAAE,GAAG,EAAE;4BACtB,OAAO,IAAI,CAAC,gCAAgC,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;wBACzE,CAAC;qBACF,CAAC,CAAC;oBAEH,2EAA2E;oBAC3E,IAAI,CAAC,kBAAkB,EAAE,CAAC;gBAC5B,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAIC,QAAQ;QACN,4CAA4C;QAC5C,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,EAAE,IAAI,EAAE,CAAC;QAC3C,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,EAAE,IAAI,EAAE,CAAC;QAE3C,0CAA0C;QAC1C,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC1B,MAAM,IAAI,GAAG,IAAI,CAAC,mBAAmB,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;YAC9D,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACnC,CAAC;aAAM,CAAC;YACN,mCAAmC;YACnC,MAAM,SAAS,GAAG,IAAI,gBAAgB,CAAC;gBACrC,aAAa,EAAE,IAAI,gBAAgB,CAAC,EAAE,CAAC;aACxC,CAAC,CAAC;YACH,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACxC,CAAC;QAED,kDAAkD;QAClD,MAAM,WAAW,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC7C,IAAI,WAAW,EAAE,CAAC;YAChB,IAAI,CAAC,8BAA8B,CAAC,GAAG,CAAC,WAAW,CAAC,YAAY,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE;gBACrF,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC5B,CAAC,CAAC,CAAC,CAAC;QACN,CAAC;QAED,yBAAyB;QACzB,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC;YAC5B,iBAAiB,EAAE,GAAG,EAAE;gBACtB,OAAO,IAAI,CAAC,gCAAgC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;YACvF,CAAC;SACF,CAAC,CAAC;QACH,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;QACjD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,CAAC;IAChD,CAAC;IACD,WAAW;QACT,IAAI,CAAC,yBAAyB,EAAE,EAAE,WAAW,EAAE,CAAC;IAClD,CAAC;IACD,kBAAkB;QAChB,IAAI,UAAU,GAAG,IAAI,CAAC,gCAAgC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;QAC/F,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,CAAC;QAC9C,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAClC,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAA;IACzB,CAAC;IACD,gCAAgC,CAAC,UAAsB;QACrD,IAAI,kBAAkB,GAAG,EAAE,CAAC;QAC5B,UAAU,CAAC,OAAO,CAAC,CAAC,UAAU,EAAE,KAAK,EAAE,EAAE;YACvC,IAAG,OAAO,UAAU,EAAE,KAAK,KAAK,QAAQ;gBAAE,UAAU,CAAC,KAAK,GAAG,UAAU,EAAE,KAAK,EAAE,IAAI,EAAE,CAAA;YACtF,IAAI,cAAc,GAAG,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,KAAK,CAAC,EAAE,UAAU,CAAC,KAAK,CAAC,CAAC;YAC9F,IAAI,UAAU,CAAC,SAAS,EAAE,MAAM,GAAG,CAAC,EAAE,CAAC;gBACrC,IAAI,wBAAwB,GAAG,EAAE,CAAA;gBACjC,IAAI,QAAQ,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,KAAK,CAAC,CAAC,SAAS,CAAA;gBACjD,IAAG,IAAI,CAAC,UAAU,EAAE,CAAC,KAAK,CAAC,CAAC,SAAS,KAAK,cAAc,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC,KAAK,CAAC,CAAC,SAAS,KAAK,aAAa,EAAE,CAAC;oBACjH,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,iBAAiB,KAAK,UAAU,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;gBAClG,CAAC;gBACD,UAAU,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,aAAa,EAAE,QAAQ,EAAE,EAAE;oBACvD,IAAI,YAAY,GAAG,QAAQ,CAAC,QAAQ,CAAC,CAAA;oBACrC,IAAG,OAAO,aAAa,EAAE,KAAK,KAAK,QAAQ;wBAAE,aAAa,CAAC,KAAK,GAAG,aAAa,EAAE,KAAK,EAAE,IAAI,EAAE,CAAA;oBAC/F,wBAAwB,CAAC,YAAY,CAAC,UAAU,CAAC,GAAG,IAAI,CAAC,uBAAuB,CAAC,YAAY,EAAE,aAAa,CAAC,CAAA;gBAC/G,CAAC,CAAC,CAAA;gBACF,kBAAkB,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,KAAK,CAAC,CAAC,UAAU,CAAC,GAAG;oBACxD,KAAK,EAAE,cAAc;oBACrB,SAAS,EAAE,wBAAwB;iBACpC,CAAA;YACH,CAAC;iBACI,CAAC;gBACJ,kBAAkB,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,KAAK,CAAC,CAAC,UAAU,CAAC,GAAG,cAAc,CAAC;YAC3E,CAAC;QACH,CAAC,CAAC,CAAC;QACH,OAAO,kBAAkB,CAAC;IAC5B,CAAC;IACD,mBAAmB,CACjB,UAA8C,EAC9C,UAAkC;QAElC,IAAI,SAAS,GAAG,IAAI,gBAAgB,CAAC,EAAE,CAAC,CAAA;QAExC,KAAK,IAAI,KAAK,IAAI,UAAU,EAAE,CAAC;YAC7B,IAAI,UAAU,GAAG,UAAU,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;YAC9C,IAAI,YAAY,GAAG,IAAI,CAAC,uBAAuB,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC;YACnE,IAAI,iBAAiB,GAAG,IAAI,CAAC,wBAAwB,CAAC,UAAU,EAAE,KAAK,EAAE,YAAY,CAAC,KAAK,CAAC,CAAC;YAC7F,SAAS,CAAC,IAAI,CAAC,IAAI,gBAAgB,CAAC;gBAClC,KAAK,EAAE,YAAY;gBACnB,SAAS,EAAE,iBAAiB;aAC7B,CAAC,CAAC,CAAA;QACL,CAAC;QACD,OAAO,IAAI,gBAAgB,CAAC;YAC1B,aAAa,EAAE,SAAS;SACzB,CAAC,CAAA;IACJ,CAAC;IAED,wBAAwB;QACtB,OAAO,IAAI,CAAC,WAAW,EAAE,CAAC,GAAG,CAAC,eAAe,CAAqB,CAAC;IACrE,CAAC;IACD,sBAAsB,CACpB,KAAkC,EAClC,SAA2B,EAC3B,KAAU;QAEV,IAAI,KAAK,CAAC,SAAS,EAAE,MAAM,GAAG,CAAC,EAAE,CAAC;YAChC,IAAI,iBAAiB,GAAG,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,UAAU,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;YACvF,SAAS,CAAC,aAAa,CAAC,WAAW,CAAC,CAAA;YACpC,SAAS,CAAC,UAAU,CAAC,WAAW,EAAE,iBAAiB,CAAC,CAAA;QACtD,CAAC;IACH,CAAC;IACD,kCAAkC,CAChC,KAAkC,EAClC,OAA2B,EAC3B,SAA2B,EAC3B,KAAU;QAEV,IAAI,OAAO,CAAC,KAAK,EAAE,KAAK,KAAK,KAAK,CAAC,KAAK,EAAE,CAAC;YACzC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QAC1B,CAAC;;YACI,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;QAC1B,IAAI,CAAC,sBAAsB,CAAC,KAAK,EAAE,SAAS,EAAE,KAAK,CAAC,CAAC;QACrD,OAAO,CAAC,aAAa,EAAE,CAAC;IAC1B,CAAC;IACD,iCAAiC,CAC/B,KAAkC,EAClC,OAA2B,EAC3B,SAA2B,EAC3B,MAAkB;QAElB,IAAI,cAAc,GAAyC,OAAO,CAAC,KAAK,CAAC;QACzE,KAAK,IAAI,KAAK,IAAI,MAAM,EAAE,CAAC;YACzB,IAAI,SAAS,GAAG,cAAc,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,KAAK,KAAK,CAAC,KAAK,CAAC,CAAC;YAC7E,IAAI,SAAS,GAAG,CAAC,CAAC,EAAE,CAAC;gBACnB,cAAc,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;YACtC,CAAC;iBAAM,CAAC;gBACN,cAAc,CAAC,IAAI,CAAC,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC;YACpC,CAAC;QACH,CAAC;QACD,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC;QACjC,IAAI,CAAC,sBAAsB,CAAC,KAAK,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC;QACtD,OAAO,CAAC,aAAa,EAAE,CAAC;IAC1B,CAAC;IACD,kBAAkB,CAAC,KAAa,EAAE,cAAuD;QACvF,OAAO,cAAc,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,KAAK,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC;IACrE,CAAC;IAED,0BAA0B,CAAC,SAAS,EAAE,KAAK,EAAE,aAAa;QACxD,IAAG,CAAC;YACF,MAAM,sBAAsB,GAAG,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,iBAAiB,KAAK,KAAK,CAAC,CAAC,aAAa,CAAC,CAAC;YACzG,OAAO,sBAAsB,CAAC;QAChC,CAAC;QACD,OAAM,CAAC,EAAC,CAAC;YACP,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;QAC9C,CAAC;IACH,CAAC;IAED,iBAAiB,CAAC,SAAS,EAAE,KAAK;QAChC,IAAI,CAAC,SAAS,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACzC,OAAO,KAAK,CAAC;QACf,CAAC;QACD,OAAO,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,iBAAiB,KAAK,KAAK,CAAC,CAAC;IAClE,CAAC;IAED,wBAAwB,CACtB,UAAe,EACf,WAAwC,EACxC,WAA2H;QAE3H,IAAI,QAAQ,GAAG,IAAI,gBAAgB,CAAC,EAAE,CAAC,CAAA;QACvC,IAAI,SAAS,GAAG,WAAW,CAAC,SAAS,CAAA;QACrC,IAAI,eAAe,GAAG,UAAU,CAAC,WAAW,CAAC,UAAU,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC,UAAU,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAA;QACvH,IAAG,CAAC,SAAS;YAAE,OAAO,QAAQ,CAAC;QAC/B,IAAI,WAAW,CAAC,SAAS,KAAK,cAAc,EAAE,CAAC;YAC7C,SAAS,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,iBAAiB,KAAuC,WAAY,EAAE,KAAK,CAAC,CAAC;QACnI,CAAC;aACI,IAAI,WAAW,CAAC,SAAS,KAAK,aAAa,EAAE,CAAC;YACjD,IAAI,YAAY,GAAG,IAAI,GAAG,CAAoD,WAAY,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;YACxH,SAAS,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,YAAY,CAAC,GAAG,CAAC,QAAQ,CAAC,iBAAiB,CAAC,CAAC,CAAC;QAC3F,CAAC;QAED,IAAI,SAAS,EAAE,MAAM,GAAG,CAAC,EAAE,CAAC;YACxB,KAAK,IAAI,QAAQ,IAAI,SAAS,EAAE,CAAC;gBAC/B,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,uBAAuB,CAAC,QAAQ,EAAE,eAAe,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,CAAA;YAC7F,CAAC;QACH,CAAC;QACH,OAAO,QAAQ,CAAC;IAClB,CAAC;IACD,uBAAuB,CAAC,SAAsC,EAAE,SAAc;QAC5E,IAAI,UAAU,GAAG,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,qBAAqB,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAA,CAAC,CAAC,EAAE,CAAA;QACzF,IAAI,OAAO,GAAG,IAAI,kBAAkB,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;QAEvD;;;WAGG;QACH,MAAM,WAAW,GAAG,SAAS,EAAE,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC;QAEjF,IAAI,SAAS,CAAC,SAAS,KAAK,OAAO,EAAE,CAAC;YACpC,IAAI,SAAS,CAAC,cAAc,KAAK,MAAM,IAAI,SAAS,CAAC,cAAc,KAAK,UAAU;gBAAE,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;iBAChI,IAAI,SAAS,CAAC,cAAc,KAAK,QAAQ;gBAAE,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;iBAC3F,IAAI,SAAS,CAAC,cAAc,KAAK,MAAM,EAAE,CAAC;gBAC7C,IAAI,WAAW,IAAI,OAAO,WAAW,KAAK,QAAQ,EAAE,CAAC;oBACnD,MAAM,QAAQ,GAAG,CAAC,SAAS,CAAC,WAAW,IAAI,SAAS,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,cAAc,CAAC;oBAC7F,MAAM,MAAM,GAAG,CAAC,SAAS,CAAC,WAAW,IAAI,SAAS,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,YAAY,CAAC;oBACvF,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;gBACnE,CAAC;qBAAM,IAAI,WAAW,IAAI,OAAO,WAAW,KAAK,QAAQ,EAAE,CAAC;oBAC1D,MAAM,QAAQ,GAAG,CAAC,SAAS,CAAC,WAAW,IAAI,SAAS,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,cAAc,CAAC;oBAC7F,MAAM,MAAM,GAAG,CAAC,SAAS,CAAC,WAAW,IAAI,SAAS,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,YAAY,CAAC;oBACvF,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC,WAAW,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;gBAC3E,CAAC;qBAAM,CAAC;oBACN,MAAM,QAAQ,GAAG,CAAC,SAAS,CAAC,WAAW,IAAI,SAAS,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,cAAc,CAAC;oBAC7F,MAAM,MAAM,GAAG,CAAC,SAAS,CAAC,WAAW,IAAI,SAAS,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,YAAY,CAAC;oBACvF,OAAO,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;gBACxD,CAAC;YACH,CAAC;QACH,CAAC;aAAM,IAAI,SAAS,CAAC,SAAS,KAAK,cAAc,EAAE,CAAC;YAClD,MAAM,iBAAiB,GAAG,GAAG,EAAE;gBAC7B,IAAI,KAAK,GAAG,SAAS,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,KAAK,WAAW,CAAC,CAAA;gBAC7E,OAAO,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,CAAA,CAAC,CAAC,EAAE,CAAC;YACrD,CAAC,CAAA;YACD,IAAI,SAAS,CAAC,cAAc,KAAK,UAAU,EAAE,CAAC;gBAC5C,IAAI,CAAC,WAAW;oBAAE,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;;oBACtD,OAAO,CAAC,QAAQ,CAAC,iBAAiB,EAAE,CAAC,CAAA;YAC5C,CAAC;iBACI,IAAI,SAAS,CAAC,cAAc,KAAK,OAAO,EAAE,CAAC;gBAC9C,OAAO,CAAC,QAAQ,CAAC,iBAAiB,EAAE,CAAC,CAAA;YACvC,CAAC;QACH,CAAC;aAAM,IAAI,SAAS,CAAC,SAAS,KAAK,aAAa,EAAE,CAAC;YACjD,IAAI,WAAW,IAAI,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE,CAAC;gBAC9C,IAAI,cAAc,GAAG,EAAE,CAAC;gBACxB,KAAK,IAAI,KAAK,IAAI,WAAW,EAAE,CAAC;oBAC9B,IAAI,KAAK,GAAG,SAAS,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,KAAK,KAAK,CAAC,CAAC;oBACxE,IAAI,KAAK,GAAG,CAAC,CAAC;wBAAE,cAAc,CAAC,IAAI,CAAC,EAAE,GAAG,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;gBACzE,CAAC;gBACD,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC;YACnC,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;YACvB,CAAC;QACH,CAAC;aAAM,IAAI,SAAS,CAAC,SAAS,KAAK,SAAS,EAAE,CAAC;YAC7C,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC;QAClC,CAAC;;YAAM,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAC9B,OAAO,OAAO,CAAC;IACjB,CAAC;IACD,uBAAuB,CAAC,SAAsC,EAAE,SAAc;QAC5E,IAAI,SAAS,CAAC,SAAS,KAAK,OAAO,EAAE,CAAC;YACpC,IAAI,SAAS,CAAC,cAAc,KAAK,MAAM,IAAI,SAAS,CAAC,cAAc,KAAK,UAAU;gBAAE,OAAO,SAAS,CAAC;iBAChG,IAAI,SAAS,CAAC,cAAc,KAAK,QAAQ;gBAAE,OAAO,CAAC,SAAS,CAAC;iBAC7D,IAAI,SAAS,CAAC,cAAc,KAAK,MAAM,EAAE,CAAC;gBAC7C,MAAM,MAAM,GAAG,CAAC,SAAS,CAAC,WAAW,IAAI,SAAS,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,YAAY,CAAC;gBACvF,MAAM,QAAQ,GAAG,CAAC,SAAS,CAAC,WAAW,IAAI,SAAS,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,cAAc,CAAC;gBAC7F,OAAO,KAAK,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC,OAAO,EAAE,CAAC;YACzD,CAAC;QACH,CAAC;aAAM,IAAI,SAAS,CAAC,SAAS,KAAK,cAAc,EAAE,CAAC;YAClD,OAAO,SAAS,EAAE,KAAK,IAAI,EAAE,CAAC;QAChC,CAAC;aAAM,IAAI,SAAS,CAAC,SAAS,KAAK,aAAa,EAAE,CAAC;YACjD,OAAO,SAAS,EAAE,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC5C,CAAC;aAAM,IAAI,SAAS,CAAC,SAAS,KAAK,SAAS,EAAE,CAAC;YAC7C,OAAO,SAAS,CAAC;QACnB,CAAC;;YAAM,OAAO,SAAS,CAAC;IAC1B,CAAC;qHA5WU,oBAAoB;oEAApB,oBAAoB;;;;;;;;;;;;;;;;;;;;YCjBjC,gCAAkC;YAChC,iCAA4C;YAC1C,wFAAkH;;YAuBtH,iBAAO;YAmOP,AAhOA,sHAAqF,yGAgOzC;;YA5PtC,6CAA2B;YAE8B,eAAwC;YAAxC,iEAAwC;;;iFDe1F,oBAAoB;cALhC,SAAS;2BACE,kBAAkB;oBAoC5B,qBAAqB;kBADpB,YAAY;mBAAC,uBAAuB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;YAIxD,mBAAmB;kBADlB,YAAY;mBAAC,qBAAqB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;YAItD,eAAe;kBADd,YAAY;mBAAC,iBAAiB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;YAIlD,mBAAmB;kBADlB,YAAY;mBAAC,qBAAqB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;YAItD,0BAA0B;kBADzB,YAAY;mBAAC,4BAA4B,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;YAI7D,uBAAuB;kBADtB,YAAY;mBAAC,yBAAyB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;YAI1D,yBAAyB;kBADxB,YAAY;mBAAC,2BAA2B,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;YAI5D,yBAAyB;kBADxB,YAAY;mBAAC,2BAA2B,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;;kFApDjD,oBAAoB;AA+WjC,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAAC,UAAuD,EAAe,EAAE;IAC5G,OAAO,CAAC,OAAwB,EAA2B,EAAE;QAC3D,IAAI,KAAK,GAAG,OAAO,CAAC,KAAK,CAAA;QACzB,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;YACzB,OAAO,IAAI,CAAC;QACd,CAAC;aACI,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;YACnC,KAAK,GAAG,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAA;QACzC,CAAC;QACD,IAAI,MAAM,GAAG,IAAI,CAAA;QAEjB,UAAU,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,EAAE;YAC/B,IAAI,KAAK,GAAG,IAAI,CAAA;YAChB,IAAI,OAAO,GAAG,SAAS,CAAC,OAAO,CAAA;YAC/B,QAAQ,SAAS,CAAC,IAAI,EAAE,CAAC;gBACvB,KAAK,UAAU;oBACb,KAAK,GAAG,UAAU,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;oBACrC,IAAI,CAAC,KAAK,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC;wBAC/D,KAAK,GAAG,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC;oBAChC,CAAC;oBACD,IAAG,KAAK;wBAAE,KAAK,GAAG,EAAC,QAAQ,EAAE,OAAO,EAAC,CAAA;oBACrC,MAAM;gBACR,KAAK,WAAW;oBACd,KAAK,GAAG,UAAU,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAA;oBACvD,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,MAAM,EAAE,KAAK,EAAE,SAAS,CAAC,cAAc,CAAC,CAAA;oBAClE,IAAG,KAAK;wBAAE,KAAK,GAAG,EAAE,SAAS,EAAE,OAAO,EAAE,CAAA;oBACxC,MAAM;gBACR,KAAK,WAAW;oBACd,KAAK,GAAG,UAAU,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAA;oBACvD,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,MAAM,EAAE,KAAK,EAAE,YAAY,CAAC,CAAA;oBACtD,IAAG,KAAK;wBAAE,KAAK,GAAG,EAAE,SAAS,EAAE,OAAO,EAAE,CAAA;oBACxC,MAAM;gBACR,KAAK,OAAO;oBACV,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;oBACjC,IAAG,KAAK;wBAAE,KAAK,GAAG,EAAC,KAAK,EAAE,OAAO,EAAC,CAAA;oBAClC,MAAM;gBACR,KAAK,QAAQ;oBACX,KAAK,GAAG,UAAU,CAAC,OAAO,CAAC,GAAG,SAAS,CAAC,KAAK,EAAE,CAAC,CAAC,OAAO,CAAC,CAAA;oBACzD,IAAG,KAAK;wBAAE,KAAK,GAAG,EAAC,MAAM,EAAE,OAAO,EAAC,CAAA;oBACnC,MAAM;gBACR;oBACE,MAAM;YACV,CAAC;YACD,IAAI,KAAK;gBAAE,MAAM,GAAG,EAAE,GAAG,MAAM,EAAE,GAAG,KAAK,EAAE,CAAA;QAC7C,CAAC,CAAC,CAAA;QACF,OAAO,MAAM,CAAA;IACf,CAAC,CAAA;AACH,CAAC,CAAA","sourcesContent":["import { Component, ContentChild, HostListener, OnDestroy, OnInit, TemplateRef, input, output, signal, computed, effect, untracked } from \"@angular/core\";\nimport { NsDynamicForm } from \"./dynamic-form.namespace\";\nimport { AbstractControl, UntypedFormArray, UntypedFormControl, UntypedFormGroup, ValidationErrors, ValidatorFn, Validators } from \"@angular/forms\";\n\nimport dayjs from 'dayjs';\nimport timezone from 'dayjs/plugin/timezone';\nimport customParseFormat from 'dayjs/plugin/customParseFormat'\n\ndayjs.extend(timezone);\ndayjs.extend(customParseFormat);\nimport { Subscription } from \"rxjs\";\n\n@Component({\n  selector: \"mis-dynamic-form\",\n  templateUrl: \"./dynamic-form.component.html\",\n  styleUrls: [\"./dynamic-form.component.scss\"]\n})\nexport class DynamicFormComponent implements OnInit, OnDestroy {\n  /**\n   * formFields:  Dynamic fields recieved from the API metadata to build a dynamic form\n   * formValues:  Holds the value of the dynamic form with \"key\" being dynamic field \"title\"\n   *              and value being the user input.\n   */\n  formFields = input<Array<NsDynamicForm.IDynamicField>>([]);\n  formValues = input<{ [key: string]: any }>({});\n  // Need to deprecate these inputs and use constants.\n  activeBtnIconUrl = input<string>(\"\");\n  calendarIconUrl = input<string>(\"\");\n  removeIconUrl = input<string>(\"\");\n  removeSepratorForSubFields = input<boolean>(false);\n  /**\n   * dynamicForm: Constructed using formFields and formValues(in case of edit)\n   */\n\n  /**\n   * formUpdated: Emits formValues Object whenever there is a change in the dynamic form.\n   */\n  formUpdated = output<{ [key: string]: any }>();\n  /**\n   * formValid: Emits boolean depending on validity of the form\n   */\n  formValid = output<boolean>();\n  /**\n   * formInitialized: Emits dynamic form API on form initilization\n   */\n  formInitialized = output<any>();\n  fieldRemoved = output<NsDynamicForm.IDynamicField>();\n\n  @ContentChild(\"customInputTextNumber\", { static: false })\n  customInputTextNumber: TemplateRef<Element>;\n  \n  @ContentChild(\"customInputTextarea\", { static: false })\n  customInputTextarea: TemplateRef<Element>;\n\n  @ContentChild(\"customInputDate\", { static: false })\n  customInputDate: TemplateRef<Element>;\n\n  @ContentChild(\"customBooleanToggle\", { static: false })\n  customBooleanToggle: TemplateRef<Element>;\n\n  @ContentChild(\"customSingleSelectDropdown\", { static: false })\n  customSingleSelectDropdown: TemplateRef<Element>;\n\n  @ContentChild(\"customSingleSelectRadio\", { static: false })\n  customSingleSelectRadio: TemplateRef<Element>;\n\n  @ContentChild(\"customMultiSelectCheckbox\", { static: false })\n  customMultiSelectCheckbox: TemplateRef<Element>;\n\n  @ContentChild(\"customMultiSelectDropdown\", { static: false })\n  customMultiSelectDropdown: TemplateRef<Element>;\n\n  // Signal-based state management\n  private readonly dynamicFormSignal = signal<UntypedFormGroup | null>(null);\n  private readonly dynamicFormAPISignal = signal<NsDynamicForm.IDynamicFormAPI | null>(null);\n  private readonly valueChangesSubscriptionSignal = signal<Subscription | null>(null);\n  \n  // Computed properties for template access\n  dynamicForm = computed(() => this.dynamicFormSignal());\n  dynamicFormAPI = computed(() => this.dynamicFormAPISignal());\n  valueChangesSubscription$ = computed(() => this.valueChangesSubscriptionSignal());\n  \n  // Backward compatibility: handle both signal and property access\n  get formFieldsArray() {\n    return this.formFields();\n  }\n  \n  // dynamic-form.component.ts (in constructor)\nconstructor() {\n  // Watch for changes in **form structure/metadata (formFields)** and update the form accordingly\n  effect(() => {\n    const formFields = this.formFields();\n    \n    // Use untracked to access formValues so that this effect only runs when formFields changes,\n    // not when the formValues output (which feeds back as an input) changes.\n    untracked(() => {\n      const formValues = this.formValues();\n      \n      // Only update if we have form fields\n      if (formFields) {\n        const form = this.generateDynamicForm(formFields, formValues);\n        this.dynamicFormSignal.set(form);\n        \n        // Re-subscribe to form changes\n        this.valueChangesSubscriptionSignal()?.unsubscribe();\n        this.valueChangesSubscriptionSignal.set(form.valueChanges.subscribe(formValue => {\n          this.onFormValueChanges();\n        }));\n        \n        // Emit form validity status\n        this.formValid.emit(form.valid);\n        \n        // Update the API with the new form\n        this.dynamicFormAPISignal.set({\n          defaultFormValues: () => {\n            return this.generateDynamicFieldsValueObject(form.value.dynamicFields);\n          }\n        });\n        \n        // Also, emit the initial or updated values right after generating the form\n        this.onFormValueChanges();\n      }\n    });\n  });\n}\n\n\n\n  ngOnInit(): void {\n    // Building the form with proper null checks\n    const formFields = this.formFields() || [];\n    const formValues = this.formValues() || {};\n    \n    // Only create form if we have form fields\n    if (formFields.length > 0) {\n      const form = this.generateDynamicForm(formFields, formValues);\n      this.dynamicFormSignal.set(form);\n    } else {\n      // Create an empty form as fallback\n      const emptyForm = new UntypedFormGroup({\n        dynamicFields: new UntypedFormArray([])\n      });\n      this.dynamicFormSignal.set(emptyForm);\n    }\n\n    // Subscribing to form changes and emiting values.\n    const currentForm = this.dynamicFormSignal();\n    if (currentForm) {\n      this.valueChangesSubscriptionSignal.set(currentForm.valueChanges.subscribe(formValue => {\n        this.onFormValueChanges();\n      }));\n    }\n\n    //api to expose functions\n    this.dynamicFormAPISignal.set({\n      defaultFormValues: () => {\n        return this.generateDynamicFieldsValueObject(this.dynamicForm().value.dynamicFields);\n      }\n    });\n    this.formInitialized.emit(this.dynamicFormAPI());\n    this.formValid.emit(this.dynamicForm().valid);\n  }\n  ngOnDestroy(): void {\n    this.valueChangesSubscription$()?.unsubscribe();\n  }\n  onFormValueChanges(): void {\n    let formValues = this.generateDynamicFieldsValueObject(this.dynamicForm().value.dynamicFields);\n    this.formValid.emit(this.dynamicForm().valid);\n    this.formUpdated.emit(formValues);\n    console.log(formValues)\n  }\n  generateDynamicFieldsValueObject(formValues: Array<any>): { [key: string]: any } {\n    let dynamicFieldsValue = {};\n    formValues.forEach((fieldValue, index) => {\n      if(typeof fieldValue?.value === 'string') fieldValue.value = fieldValue?.value?.trim()\n      let formattedValue = this.mapFormFieldToFormValue(this.formFields()[index], fieldValue.value);\n      if (fieldValue.subFields?.length > 0) {\n        let formattedSubFieldsValues = {}\n        let subField = this.formFields()[index].subFields\n        if(this.formFields()[index].fieldType === 'singleSelect' || this.formFields()[index].fieldType === 'multiSelect') {\n          subField = subField.filter((subField) => subField.parentConfigValue === fieldValue.value.value);\n        }\n        fieldValue.subFields.forEach((subFieldValue, subIndex) => {\n          let subFormField = subField[subIndex]\n          if(typeof subFieldValue?.value === 'string') subFieldValue.value = subFieldValue?.value?.trim()\n          formattedSubFieldsValues[subFormField.configName] = this.mapFormFieldToFormValue(subFormField, subFieldValue)\n        })\n        dynamicFieldsValue[this.formFields()[index].configName] = {\n          value: formattedValue,\n          subFields: formattedSubFieldsValues\n        }\n      }\n      else {\n        dynamicFieldsValue[this.formFields()[index].configName] = formattedValue;\n      }\n    });\n    return dynamicFieldsValue;\n  }\n  generateDynamicForm(\n    formFields: Array<NsDynamicForm.IDynamicField>,\n    formValues: { [key: string]: any }\n  ): UntypedFormGroup {\n    let formArray = new UntypedFormArray([])\n\n    for (let field of formFields) {\n      let fieldValue = formValues[field.configName];\n      let fieldControl = this.mapFormValueToFormField(field, fieldValue);\n      let subFieldsControls = this.generateSubDynamicFields(formValues, field, fieldControl.value);\n      formArray.push(new UntypedFormGroup({\n        value: fieldControl,\n        subFields: subFieldsControls\n      }))\n    }  \n    return new UntypedFormGroup({\n      dynamicFields: formArray\n    })\n  }\n  \n  getDynamicFieldsControls(): UntypedFormArray {\n    return this.dynamicForm().get(\"dynamicFields\") as UntypedFormArray;\n  }\n  updateSubDynamicFields(\n    field: NsDynamicForm.IDynamicField,\n    formGroup: UntypedFormGroup,\n    value: any\n  ): void {\n    if (field.subFields?.length > 0) {\n      let subFieldsControls = this.generateSubDynamicFields(this.formValues(), field, value);\n      formGroup.removeControl('subFields')\n      formGroup.addControl('subFields', subFieldsControls)\n    }\n  }\n  updateSelectedValueForSingleSelect(\n    field: NsDynamicForm.IDynamicField,\n    control: UntypedFormControl,\n    formGroup: UntypedFormGroup,\n    value: any\n  ): void {\n    if (control.value?.value !== value.value) {\n      control.setValue(value);\n    }\n    else control.setValue('');\n    this.updateSubDynamicFields(field, formGroup, value);\n    control.markAsTouched();\n  }\n  updateSelectedValueForMultiSelect(\n    field: NsDynamicForm.IDynamicField,\n    control: UntypedFormControl,\n    formGroup: UntypedFormGroup,\n    values: Array<any>\n  ): void {\n    let selectedValues: Array<{ label: string; value: any }> = control.value;\n    for (let value of values) {\n      let itemIndex = selectedValues.findIndex(item => item.label === value.label);\n      if (itemIndex > -1) {\n        selectedValues.splice(itemIndex, 1);\n      } else {\n        selectedValues.push({ ...value });\n      }\n    }\n    control.setValue(selectedValues);\n    this.updateSubDynamicFields(field, formGroup, values);\n    control.markAsTouched();\n  }\n  isCheckBoxSelected(value: string, selectedValues: Array<{ label: string; value: string }>): boolean {\n    return selectedValues.findIndex(item => item.label === value) > -1;\n  }\n\n  findSelectedSubFieldConfig(subfields, value, subFieldIndex) {\n    try{\n      const selectedSubFieldConfig = subfields.filter(item => item.parentConfigValue === value)[subFieldIndex];\n      return selectedSubFieldConfig;\n    }\n    catch(e){\n      throw new Error('Subfield index not found');\n    }\n  }\n\n  matchParentConfig(subfields, value) {\n    if (!subfields || subfields.length === 0) {\n      return false;\n    }\n    return subfields.some(item => item.parentConfigValue === value);\n  }\n\n  generateSubDynamicFields(\n    formValues: any,\n    parentField: NsDynamicForm.IDynamicField,\n    parentValue: Array<{ label: string, value: string | number }> | {label: string, value: string } | string | number | boolean\n  ): UntypedFormArray {\n    let controls = new UntypedFormArray([])\n    let subFields = parentField.subFields\n    let subFieldsValues = formValues[parentField.configName]?.subFields ? formValues[parentField.configName].subFields : {}\n    if(!subFields) return controls;\n    if (parentField.fieldType === 'singleSelect') {\n      subFields = subFields.filter((subField) => subField.parentConfigValue === (<{label: string, value: string }>parentValue)?.value);\n    }\n    else if (parentField.fieldType === 'multiSelect') {\n      let parentValues = new Set((<Array<{ label: string, value: string | number }>>parentValue).map((value) => value.value));\n      subFields = subFields.filter((subField) => parentValues.has(subField.parentConfigValue));\n    }\n\n    if (subFields?.length > 0) {\n        for (let subField of subFields) {\n          controls.push(this.mapFormValueToFormField(subField, subFieldsValues[subField.configName]))\n        }\n      }\n    return controls;\n  }\n  mapFormValueToFormField(formField: NsDynamicForm.IDynamicField, formValue: any): any {\n    let validators = formField.validators ? [dynamicFieldValidator(formField.validators)]: []\n    let control = new UntypedFormControl(null, validators);\n\n    /**\n     * Extract actual value if formValue has nested structure (for fields with subFields)\n     * Format: { value: \"actualValue\", subFields: {...} }\n     */\n    const actualValue = formValue?.value !== undefined ? formValue.value : formValue;\n\n    if (formField.fieldType === \"input\") {\n      if (formField.fieldInputType === \"text\" || formField.fieldInputType === \"textarea\") control.setValue(actualValue ? actualValue : \"\");\n      else if (formField.fieldInputType === \"number\") control.setValue(actualValue ? actualValue : 0);\n      else if (formField.fieldInputType === \"date\") {\n        if (actualValue && typeof actualValue === \"number\") {\n          const timezone = (formField.fieldConfig && formField.fieldConfig.timezone) || 'Asia/Kolkata';\n          const format = (formField.fieldConfig && formField.fieldConfig.format) || 'DD/MM/YYYY';\n          control.setValue(dayjs(actualValue).tz(timezone).format(format));\n        } else if (actualValue && typeof actualValue === \"string\") {\n          const timezone = (formField.fieldConfig && formField.fieldConfig.timezone) || 'Asia/Kolkata';\n          const format = (formField.fieldConfig && formField.fieldConfig.format) || 'DD/MM/YYYY';\n          control.setValue(dayjs.tz(actualValue, format, timezone).format(format));\n        } else {\n          const timezone = (formField.fieldConfig && formField.fieldConfig.timezone) || 'Asia/Kolkata';\n          const format = (formField.fieldConfig && formField.fieldConfig.format) || 'DD/MM/YYYY';\n          control.setValue(dayjs().tz(timezone).format(format));\n        }\n      }\n    } else if (formField.fieldType === \"singleSelect\") {\n      const findSelectedValue = () => {\n        let index = formField.itemsList.findIndex(item => item.value === actualValue)\n        return index >= 0 ? formField.itemsList[index]: \"\";\n      }\n      if (formField.fieldInputType === \"dropdown\") {\n        if (!actualValue) control.setValue(formField.itemsList[0]);\n        else control.setValue(findSelectedValue())\n      }\n      else if (formField.fieldInputType === \"radio\") {\n        control.setValue(findSelectedValue())\n      }\n    } else if (formField.fieldType === \"multiSelect\") {\n      if (actualValue && Array.isArray(actualValue)) {\n        let selectedValues = [];\n        for (let value of actualValue) {\n          let index = formField.itemsList.findIndex(item => item.value === value);\n          if (index > -1) selectedValues.push({ ...formField.itemsList[index] });\n        }\n        control.setValue(selectedValues);\n      } else {\n        control.setValue([]);\n      }\n    } else if (formField.fieldType === \"boolean\") {\n      control.setValue(!!actualValue);\n    } else control.setValue(null);\n    return control;\n  }\n  mapFormFieldToFormValue(formField: NsDynamicForm.IDynamicField, formValue: any): any {\n    if (formField.fieldType === \"input\") {\n      if (formField.fieldInputType === \"text\" || formField.fieldInputType === \"textarea\") return formValue;\n      else if (formField.fieldInputType === \"number\") return +formValue;\n      else if (formField.fieldInputType === \"date\") {\n        const format = (formField.fieldConfig && formField.fieldConfig.format) || 'DD/MM/YYYY';\n        const timezone = (formField.fieldConfig && formField.fieldConfig.timezone) || 'Asia/Kolkata';\n        return dayjs.tz(formValue, format, timezone).valueOf();\n      }\n    } else if (formField.fieldType === \"singleSelect\") {\n      return formValue?.value ?? '';\n    } else if (formField.fieldType === \"multiSelect\") {\n      return formValue?.map(item => item.value);\n    } else if (formField.fieldType === \"boolean\") {\n      return formValue;\n    } else return formValue;\n  }\n}\n\nexport const dynamicFieldValidator = (validators: Array<NsDynamicForm.IDynamicFieldValidator>): ValidatorFn => {\n  return (control: AbstractControl): ValidationErrors | null => {\n    let value = control.value\n    if (Array.isArray(value)) {\n      return null;\n    }\n    else if (typeof value === 'object') {\n      value = value?.value ? value.value : ''\n    }\n    let errors = null\n\n    validators.forEach((validator) => {\n      let error = null\n      let message = validator.message\n      switch (validator.type) {\n        case \"Required\":\n          error = Validators.required(control);\n          if (!error && typeof value === 'string' && value.trim() === '') {\n            error = { Required: message };\n          }\n          if(error) error = {Required: message}\n          break;\n        case \"MinLength\":\n          error = Validators.minLength(+validator.value)(control)\n          message = message.replace('${0}', error?.minlength.requiredLength)\n          if(error) error = { MinLength: message }\n          break;\n        case \"MaxLength\":\n          error = Validators.maxLength(+validator.value)(control)\n          message = message.replace('${0}', error?.actualLength)\n          if(error) error = { MaxLength: message }\n          break;\n        case \"Email\":\n          error = Validators.email(control)\n          if(error) error = {Email: message}\n          break;\n        case \"Custom\":\n          error = Validators.pattern(`${validator.value}`)(control)\n          if(error) error = {Custom: message}\n          break;\n        default:\n          break;\n      }\n      if (error) errors = { ...errors, ...error }\n    })\n    return errors\n  }\n}","<form [formGroup]=\"dynamicForm()\">\n  <ng-container formArrayName=\"dynamicFields\">\n    <ng-container [formGroupName]=\"i\" *ngFor=\"let fieldControl of getDynamicFieldsControls().controls; let i = index\">\n        <ng-container\n        [ngTemplateOutlet]=\"dynamicField\"\n        [ngTemplateOutletContext]=\"{\n          $implicit: formFieldsArray?.[i],\n          formGroup: fieldControl,\n          control: fieldControl.controls.value\n        }\"\n      >\n      </ng-container>\n      <div class=\"sub-dynamic-form\" *ngIf=\"fieldControl?.value && (!!formFieldsArray?.[i]?.subFields && formFieldsArray?.[i]?.subFields?.length > 0 && matchParentConfig(formFieldsArray?.[i]?.subFields, fieldControl?.controls?.value?.value?.value))\">\n        <ng-container *ngFor=\"let subFieldControl of fieldControl.controls.subFields.controls; let j = index\">\n          <ng-container\n            [ngTemplateOutlet]=\"dynamicField\"\n            [ngTemplateOutletContext]=\"{\n              $implicit: findSelectedSubFieldConfig(formFieldsArray?.[i]?.subFields, fieldControl.controls.value.value.value,j),\n              control: subFieldControl\n            }\">\n          </ng-container>\n        </ng-container>\n      </div>\n    </ng-container>\n  </ng-container>\n</form>\n\n\n<ng-template #dynamicField let-field let-control=\"control\" let-formgroup=\"formGroup\">\n\n  <!-- fieldType: 'input' fieldInputType: 'text' | 'number' -->\n  <ng-container *ngIf=\"field.fieldType === 'input' && (field.fieldInputType === 'text' || field.fieldInputType === 'number')\">\n    <ng-container *ngIf=\"customInputTextNumber; else defaultInputTextNumber\">\n      <ng-template\n        [ngTemplateOutlet]=\"customInputTextNumber\"\n        [ngTemplateOutletContext]=\"{ field: field, control: control, formgroup: formgroup }\"\n      ></ng-template>\n    </ng-container>\n    <ng-template #defaultInputTextNumber>\n      <div class=\"dynamic-field multi-line-field-container\"\n        [ngStyle]=\"{'border-bottom': (formgroup?.controls?.subFields?.controls?.length && removeSepratorForSubFields) ?  'none':''}\">\n        <p class=\"h7 field-title-sm\">\n          {{ field?.title }} <span *ngIf=\"field.validators && field.validators.length > 0\"> *</span>\n        </p>\n        <div style=\"flex-basis: 100%\"></div>\n        <input class=\"input-field ip-text\" [type]=\"field.fieldInputType\" [formControl]=\"control\"\n          (ngModelChange)=\"updateSubDynamicFields(field, formgroup, $event)\" \n          [ngStyle]=\"{'border': control.touched && control.errors ? '1px solid #B00020': ''}\"\n          [placeholder]=\"field.placeholderText ? field.placeholderText : 'Input Text'\" \n          [min]=\"field.fieldInputType === 'number' ? 0 : '' \"/>\n        <ng-container *ngIf=\"control.touched && control.errors\"\n          [ngTemplateOutlet]=\"dynamicFieldErrors\" \n          [ngTemplateOutletContext]=\"{ $implicit: control.errors }\"\n        >\n        </ng-container>\n      </div>\n    </ng-template>\n  </ng-container>\n  \n  <!-- fieldType: 'input' fieldInputType: 'textarea' -->\n  <ng-container *ngIf=\"field.fieldType === 'input' && field.fieldInputType === 'textarea'\">\n    <ng-container *ngIf=\"customInputTextarea; else defaultInputTextarea\">\n      <ng-template\n      [ngTemplateOutlet]=\"customInputTextarea\"\n      [ngTemplateOutletContext]=\"{ field: field, control: control, formgroup: formgroup }\"\n    ></ng-template>\n    </ng-container>\n    <ng-template #defaultInputTextarea>\n      <div class=\"dynamic-field multi-line-field-container\"\n      [ngStyle]=\"{'border-bottom': (formgroup?.controls?.subFields?.controls?.length && removeSepratorForSubFields) ?  'none':''}\">\n        <p class=\"h7 field-title-sm\">\n          {{ field.title }}<span *ngIf=\"field.validators && field.validators.length > 0\"> *</span>\n        </p>\n        <div style=\"flex-basis: 100%\"></div>\n        <textarea class=\"input-field ip-textarea\" type=\"text\"\n          [ngStyle]=\"{'border': control.touched && control.errors ? '1px solid #B00020': ''}\"\n          [placeholder]=\"field.placeholderText ? field.placeholderText : 'Input Text'\" [formControl]=\"control\" (ngModelChange)=\"updateSubDynamicFields(field, formgroup, $event)\"></textarea>\n          <ng-container *ngIf=\"control.touched && control.errors\" [ngTemplateOutlet]=\"dynamicFieldErrors\"\n            [ngTemplateOutletContext]=\"{ $implicit: control.errors }\">\n          </ng-container>\n      </div>\n    </ng-template>\n  </ng-container>\n  \n  <!-- fieldType: 'input' fieldInputType: 'date' -->\n  <ng-container *ngIf=\"field.fieldType === 'input' && field.fieldInputType === 'date'\">\n    <ng-container *ngIf=\"customInputDate; else defaultInputDate\">\n      <ng-template\n        [ngTemplateOutlet]=\"customInputDate\"\n        [ngTemplateOutletContext]=\"{ field: field, control: control, formgroup: formgroup }\"\n      ></ng-template>\n    </ng-container>\n    <ng-template #defaultInputDate>\n      <div class=\"dynamic-field single-line-field-container\"\n      [ngStyle]=\"{'border-bottom': (formgroup?.controls?.subFields?.controls?.length && removeSepratorForSubFields) ?  'none':''}\"\n        *ngIf=\"field.fieldType === 'input' && field.fieldInputType === 'date'\">\n        <p class=\"h6\">\n          {{ field.title }} <span *ngIf=\"field.validators && field.validators.length > 0\"> *</span>\n        </p>\n        <div class=\"date-picker-container\">\n          <input class=\"date-picker\" readonly misTzDp [dpConfig]=\"field.fieldConfig\"\n            (dateChange)=\"control.setValue($event)\" [selectedDate]=\"control.value\" [offsetY]=\"0\"\n            [value]=\"control.value\" #dp />\n          <img alt=\"data-picker\" *ngIf=\"calendarIconUrl()\" class=\"date-picker-icon\" [src]=\"calendarIconUrl()\"\n            (click)=\"dp.click()\" />\n        </div>\n        <ng-container *ngIf=\"control.touched && control.errors\" [ngTemplateOutlet]=\"dynamicFieldErrors\"\n          [ngTemplateOutletContext]=\"{ $implicit: control.errors }\">\n        </ng-container>\n      </div>\n    </ng-template>\n  </ng-container>\n\n  <!-- fieldType: 'boolean' fieldInputType: 'toggle' -->\n  <ng-container *ngIf=\"field.fieldType === 'boolean' && field.fieldInputType === 'toggle'\">\n    <ng-container *ngIf=\"customBooleanToggle; else defaultBooleanToggle\">\n      <ng-template\n        [ngTemplateOutlet]=\"customBooleanToggle\"\n        [ngTemplateOutletContext]=\"{ field: field, control: control, formgroup: formgroup }\"\n      ></ng-template>\n    </ng-container>\n    <ng-template #defaultBooleanToggle>\n      <div class=\"dynamic-field single-line-field-container\"\n      [ngStyle]=\"{'border-bottom': (formgroup?.controls?.subFields?.controls?.length && removeSepratorForSubFields) ?  'none':''}\">\n        <p class=\"h6\">\n          {{ field.title }}<span *ngIf=\"field.validators && field.validators.length > 0\"> *</span>\n        </p>\n        <mis-switch [control]=\"control\" (valueChanged)=\"updateSubDynamicFields(field, formgroup, $event)\"></mis-switch>\n        <ng-container *ngIf=\"control.touched && control.errors\" [ngTemplateOutlet]=\"dynamicFieldErrors\"\n          [ngTemplateOutletContext]=\"{ $implicit: control.errors }\">\n        </ng-container>\n      </div>    \n    </ng-template>\n  </ng-container>\n\n  <!-- fieldType: 'singleSelect' fieldInputType: 'dropdown' -->\n  <ng-container *ngIf=\"field.fieldType === 'singleSelect' && field.fieldInputType === 'dropdown'\">\n    <ng-container *ngIf=\"customSingleSelectDropdown; else defaultSingleSelectDropdown\">\n      <ng-template\n        [ngTemplateOutlet]=\"customSingleSelectDropdown\"\n        [ngTemplateOutletContext]=\"{ field: field, control: control, formgroup: formgroup }\"\n      ></ng-template>\n    </ng-container>\n    <ng-template #defaultSingleSelectDropdown>\n      <div class=\"dynamic-field single-line-field-container\"\n        [ngStyle]=\"{'border-bottom': (formgroup?.controls?.subFields?.controls?.length && removeSepratorForSubFields) ?  'none':''}\">\n        <p class=\"h6\">\n          {{ field.title }}<span *ngIf=\"field.validators && field.validators.length > 0\"> *</span>\n        </p>\n        <div [ngClass]=\"{'removeable-container' : field?.isRemoveable}\">\n          <mis-dropdown [searchEnabled]=\"false\" [width]=\"'140px'\" [data]=\"field.itemsList\" [selectedItem]=\"control.value\"\n          (onChange)=\"updateSelectedValueForSingleSelect(field, control, formgroup, $event);\">\n          </mis-dropdown>\n          <img *ngIf=\"field.isRemoveable && removeIconUrl()\" class=\"remove-icon\" [src]=\"removeIconUrl()\" (click)=\"fieldRemoved.emit(field)\">\n        </div>\n        <ng-container *ngIf=\"control.touched && control.errors\" [ngTemplateOutlet]=\"dynamicFieldErrors\"\n          [ngTemplateOutletContext]=\"{ $implicit: control.errors }\">\n        </ng-container>\n      </div>\n    </ng-template>\n  </ng-container >\n  \n\n  <!-- fieldType: 'singleSelect' fieldInputType: 'radio' -->\n  <ng-container *ngIf=\"field.fieldType === 'singleSelect' && field.fieldInputType === 'radio'\">\n    <ng-container *ngIf=\"customSingleSelectRadio; else defaultSingleSelectRadio\">\n      <ng-template\n        [ngTemplateOutlet]=\"customSingleSelectRadio\"\n        [ngTemplateOutletContext]=\"{ field: field, control: control, formgroup: formgroup }\"\n      ></ng-template>\n    </ng-container>\n    <ng-template #defaultSingleSelectRadio>\n      <div class=\"dynamic-field multi-line-field-container\"\n      [ngStyle]=\"{'border-bottom': (formgroup?.controls?.subFields?.controls?.length && removeSepratorForSubFields) ?  'none':''}\">\n        <p class=\"h7 field-title-sm\">\n          {{ field.title }}<span *ngIf=\"field.validators && field.validators.length > 0\"> *</span>\n        </p>\n        <div style=\"flex-basis: 100%\"></div>\n        <div id=\"checkboxes-container\">\n          <div class=\"radio-checkbox-common\" *ngFor=\"let item of field.itemsList\"\n            [ngClass]=\"{ 'checkbox-active': item.label === control.value?.label }\"\n            (click)=\"updateSelectedValueForSingleSelect(field, control, formgroup, item);\">\n            <img *ngIf=\"(item.label === control.value?.label) && activeBtnIconUrl()\" [src]=\"activeBtnIconUrl()\" alt=\"\" />\n            <p class=\"h6\">{{ item.label }}</p>\n          </div>\n        </div>\n        <ng-container *ngIf=\"control.touched && control.errors\" [ngTemplateOutlet]=\"dynamicFieldErrors\"\n          [ngTemplateOutletContext]=\"{ $implicit: control.errors }\">\n        </ng-container>\n      </div>\n    </ng-template>\n  </ng-container>\n  \n\n  <!-- fieldType: 'multiSelect' fieldInputType: 'checkbox' -->\n  <ng-container *ngIf=\"field.fieldType === 'multiSelect' && field.fieldInputType === 'checkbox'\">\n    <ng-container *ngIf=\"customMultiSelectCheckbox; else defaultMultiSelectCheckbox\">\n      <ng-template\n        [ngTemplateOutlet]=\"customMultiSelectCheckbox\"\n        [ngTemplateOutletContext]=\"{ field: field, control: control, formgroup: formgroup }\"\n      ></ng-template>\n    </ng-container>\n    <ng-template #defaultMultiSelectCheckbox>\n      <div class=\"dynamic-field multi-line-field-container\"\n      [ngStyle]=\"{'border-bottom': (formgroup?.controls?.subFields?.controls?.length && removeSepratorForSubFields) ?  'none':''}\">\n        <p class=\"h7 field-title-sm\">\n          {{ field.title }}<span *ngIf=\"field.validators && field.validators.length > 0\"> *</span>\n        </p>\n        <div style=\"flex-basis: 100%\"></div>\n        <div id=\"checkboxes-container\">\n          <div class=\"radio-checkbox-common\" *ngFor=\"let item of field.itemsList\"\n            [ngClass]=\"{ 'checkbox-active': isCheckBoxSelected(item.label, control.value) }\"\n            (click)=\"updateSelectedValueForMultiSelect(field, control, formgroup, [item])\">\n            <img *ngIf=\"isCheckBoxSelected(item.label, control.value) && activeBtnIconUrl()\" [src]=\"activeBtnIconUrl()\"\n              alt=\"\" />\n            <p class=\"h6\">{{ item.label }}</p>\n          </div>\n        </div>\n        <ng-container *ngIf=\"control.touched && control.errors\" [ngTemplateOutlet]=\"dynamicFieldErrors\"\n          [ngTemplateOutletContext]=\"{ $implicit: control.errors }\">\n        </ng-container>\n      </div>\n    </ng-template>\n  </ng-container>\n\n\n  <!-- fieldType: 'multiSelect' fieldInputType: 'dropdown' -->\n  <ng-container *ngIf=\"field.fieldType === 'multiSelect' && field.fieldInputType === 'dropdown'\">\n    <ng-container *ngIf=\"customMultiSelectDropdown; else defaultMultiSelectDropdown\">\n      <ng-template\n        [ngTemplateOutlet]=\"customMultiSelectDropdown\"\n        [ngTemplateOutletContext]=\"{ field: field, control: control, formgroup: formgroup }\"\n      ></ng-template>\n    </ng-container>\n    <ng-template #defaultMultiSelectDropdown>\n      <div class=\"dynamic-field single-line-field-container\"\n      [ngStyle]=\"{'border-bottom': (formgroup?.controls?.subFields?.controls?.length && removeSepratorForSubFields) ?  'none':''}\">\n        <p class=\"h6\">\n          {{ field.title }}<span *ngIf=\"field.validators && field.validators.length > 0\"> *</span>\n        </p>\n        <mis-multi-select-dropdown [width]=\"'140px'\" [showSelectedCount]=\"true\" [dropdownListWidth]=\"'256px'\"\n          [searchEnabled]=\"false\" [hideApplyButton]=\"true\" [data]=\"field.itemsList\"\n          [selectedItems]=\"control.value\" (onChange)=\"updateSelectedValueForMultiSelect(field, control, formgroup, $event);\"></mis-multi-select-dropdown>\n        <ng-container *ngIf=\"control.touched && control.errors\" [ngTemplateOutlet]=\"dynamicFieldErrors\"\n          [ngTemplateOutletContext]=\"{ $implicit: control.errors }\">\n        </ng-container>\n      </div>\n    </ng-template>\n  </ng-container>\n\n</ng-template>\n\n<ng-template #dynamicFieldErrors let-errors>\n  <div id=\"error-messages-container\">\n    <ng-container *ngFor=\"let error of errors | keyvalue\">\n      <p class=\"h8\">\n        {{\" • &nbsp;\" + error.value}}\n      </p>\n      <div [ngStyle]=\"{ 'flex-basis': '100%', 'height': '0' }\"></div>\n    </ng-container>\n  </div>\n</ng-template>"]}
@@ -2,21 +2,27 @@ import { Component, input } from "@angular/core";
2
2
  import * as i0 from "@angular/core";
3
3
  import * as i1 from "@angular/common";
4
4
  const _c0 = a0 => ({ mobile: a0 });
5
+ const _c1 = (a0, a1, a2, a3) => ({ "width": a0, "height": a1, "border": a2, "border-top-color": a3 });
5
6
  export class LoaderComponent {
6
7
  constructor() {
7
8
  /** Controls loader size */
8
9
  this.mobileView = input(false);
10
+ this.color = input('var(--border-primary, #E0E0E0)');
11
+ this.height = input('40px');
12
+ this.width = input('40px');
13
+ this.borderTopColor = input('var(--brand-primary, #0937b2)');
9
14
  }
15
+ ngOnInit() { }
10
16
  static { this.ɵfac = function LoaderComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || LoaderComponent)(); }; }
11
- static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: LoaderComponent, selectors: [["mis-loader"]], inputs: { mobileView: [1, "mobileView"] }, decls: 1, vars: 3, consts: [["id", "spinner", 3, "ngClass"]], template: function LoaderComponent_Template(rf, ctx) { if (rf & 1) {
17
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: LoaderComponent, selectors: [["mis-loader"]], inputs: { mobileView: [1, "mobileView"], color: [1, "color"], height: [1, "height"], width: [1, "width"], borderTopColor: [1, "borderTopColor"] }, decls: 1, vars: 9, consts: [["id", "spinner", 3, "ngClass", "ngStyle"]], template: function LoaderComponent_Template(rf, ctx) { if (rf & 1) {
12
18
  i0.ɵɵelement(0, "div", 0);
13
19
  } if (rf & 2) {
14
- i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(1, _c0, ctx.mobileView()));
15
- } }, dependencies: [i1.NgClass], styles: ["[_ngcontent-%COMP%]:root{--pmry-200: #99BAF7;--pmry-100: #CBDDFB;--pmry-500: #0937B2;--pmry-400: #3C68D0;--pmry-600: #062A99;--pmry-700: #041F80;--pmry-300: #638FE7;--pmry-800: #021567;--pmry-900: #010F55;--sec-d-purple: #40447F;--sec-maroon: #6B034E;--sec-mud-red: #B23600;--sec-orange: #ED711C;--sec-purple: #815FD5;--sec-teal: #10ADAE;--sec-yellow: #D4900C;--sec-green: #547F40;--sec-bright-green: #27D22E;--sec-dark-teal: #035F6B;--sec-chocolate: #7C2F33;--sec-rube-pink: #C13D6D;--sec-cerulean: #0087B2;--sem-error: #B00020;--sem-info: #0091FF;--sem-warning: #FF9D00;--sem-success: #38AF49;--grey-bg-1: #FAFAFA;--grey-bg: #F5F5F5;--grey-seperators: #E0E0E0;--grey-disabled: #C8CDD3;--grey-hover: #F5F7FC;--grey-pressed: #E6EBF7;--grey-row: #F5F7FC;--dec-light-yellow: #F4E7C3;--dec-light-purple: #DACFF9;--dec-light-green: #E4F5E9;--dec-light-green2: #F1FFF3;--dec-light-pink: #FAE1EA;--dec-: #F4CBC1;--dec-lt-orange: #FAEFED;--dec-light-blue: #CFECF9;--dec-row-selection: #F1FDF8;--dec-row-selection2: #F2FBFF;--dec-row-lines: #D3E1E9;--text-white: #FFFFFF;--text-muted: #6A737D;--text-black: #181F33;--MR-solid-blue2:#C8D5F6;--MR-solid-purple:#C9C3FB;--MR-solid-orange:#EEAC9F;--MR-solid-green:#ACDADA;--MR-solid-brown:#E8C8AF;--MR-solid-yellow:#FFEFC7;--MR-solid-blue:#BBE6FF;--MR-solid-pink:#FFC6F2;--tr-hover:#F0F3FA;--tr-pressed:#DAE1F3;--brand-primary: #0937B2;--brand-primary-light: #3C68D0;--brand-primary-dark: #062A99;--brand-primary-darker: #041F80;--brand-primary-lighter: #638FE7;--brand-primary-lightest: #CBDDFB;--brand-primary-hover: #F0F3FA;--brand-primary-active: #DAE1F3;--brand-secondary: #ED711C;--brand-secondary-light: #F09E65;--brand-secondary-dark: #B23600;--brand-secondary-lighter: #FFC6F2;--brand-accent: #10ADAE;--brand-accent-light: #16CBBC;--brand-accent-dark: #035F6B;--brand-accent-lighter: #ACDADA;--brand-success: #38AF49;--brand-success-light: #4CAF50;--brand-success-dark: #216531;--brand-success-lighter: #E4F5E9;--brand-success-lightest: #F1FFF3;--brand-error: #B00020;--brand-error-light: #F04E4E;--brand-error-dark: #A60060;--brand-error-lighter: #FAE1EA;--brand-error-lightest: #FDF2F2;--brand-warning: #FF9D00;--brand-warning-light: #D4900C;--brand-warning-dark: #624000;--brand-warning-lighter: #F4E7C3;--brand-warning-lightest: #FAEFED;--brand-info: #0091FF;--brand-info-light: #35A1FF;--brand-info-dark: #0087B2;--brand-info-lighter: #CFECF9;--text-primary: #181F33;--text-secondary: #6A737D;--text-tertiary: #929DAB;--text-disabled: #929DAB;--text-primary-87: rgba(24, 31, 51, .87);--text-primary-60: rgba(24, 31, 51, .6);--text-primary-38: rgba(24, 31, 51, .38);--text-primary-12: rgba(24, 31, 51, .12);--bg-primary: #FFFFFF;--bg-secondary: #FAFAFA;--bg-tertiary: #F5F5F5;--bg-overlay: rgba(0, 0, 0, .32);--bg-overlay-light: rgba(0, 0, 0, .12);--bg-overlay-lighter: rgba(0, 0, 0, .08);--bg-overlay-lightest: rgba(0, 0, 0, .04);--border-primary: #E0E0E0;--border-secondary: #D6DCE2;--border-tertiary: #C8CDD3;--border-light: #F1F4F8;--border-primary-12: rgba(0, 0, 0, .12);--border-primary-08: rgba(0, 0, 0, .08);--border-primary-06: rgba(0, 0, 0, .06);--shadow-primary: rgba(0, 0, 0, .12);--shadow-secondary: rgba(0, 0, 0, .08);--shadow-tertiary: rgba(0, 0, 0, .04);--shadow-light: rgba(0, 0, 0, .06);--status-available: #929DAB;--status-unavailable: #CCD3DA;--status-hotseat: #857BFF;--status-multiteam: #10ADAE;--status-selected: #10ADAE;--status-upcoming: #D4900C;--status-room: #38AF49;--status-room-booked: #B23600;--status-room-unavailable: #181F33;--team-color-1: #F8C52E;--team-color-2: #FA8E20;--team-color-3: #987CDD;--team-color-4: #16CBBC;--team-color-5: #E65010;--team-color-6: #A60060;--team-color-7: #ED323B;--team-color-8: #35A1FF;--team-color-9: #80D348}#spinner[_ngcontent-%COMP%]{-webkit-animation:_ngcontent-%COMP%_frames 1s infinite linear;animation:_ngcontent-%COMP%_frames 1s infinite linear;background:transparent;border:4px solid var(--border-primary, #E0E0E0);border-radius:100%;border-top-color:var(--brand-primary, #0937B2);width:40px;height:40px;padding:0;position:absolute}@keyframes _ngcontent-%COMP%_frames{0%{-webkit-transform:rotate(0deg);transform:rotate(0)}to{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}.mobile[_ngcontent-%COMP%]{height:20px!important;width:20px!important;border:2px solid var(--border-primary, #E0E0E0)!important;border-top-color:var(--brand-primary, #0937B2)!important}"] }); }
20
+ i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(2, _c0, ctx.mobileView()))("ngStyle", i0.ɵɵpureFunction4(4, _c1, ctx.width(), ctx.height(), "4px solid " + ctx.color(), ctx.borderTopColor()));
21
+ } }, dependencies: [i1.NgClass, i1.NgStyle], styles: ["[_ngcontent-%COMP%]:root{--pmry-200: #99BAF7;--pmry-100: #CBDDFB;--pmry-500: #0937B2;--pmry-400: #3C68D0;--pmry-600: #062A99;--pmry-700: #041F80;--pmry-300: #638FE7;--pmry-800: #021567;--pmry-900: #010F55;--sec-d-purple: #40447F;--sec-maroon: #6B034E;--sec-mud-red: #B23600;--sec-orange: #ED711C;--sec-purple: #815FD5;--sec-teal: #10ADAE;--sec-yellow: #D4900C;--sec-green: #547F40;--sec-bright-green: #27D22E;--sec-dark-teal: #035F6B;--sec-chocolate: #7C2F33;--sec-rube-pink: #C13D6D;--sec-cerulean: #0087B2;--sem-error: #B00020;--sem-info: #0091FF;--sem-warning: #FF9D00;--sem-success: #38AF49;--grey-bg-1: #FAFAFA;--grey-bg: #F5F5F5;--grey-seperators: #E0E0E0;--grey-disabled: #C8CDD3;--grey-hover: #F5F7FC;--grey-pressed: #E6EBF7;--grey-row: #F5F7FC;--dec-light-yellow: #F4E7C3;--dec-light-purple: #DACFF9;--dec-light-green: #E4F5E9;--dec-light-green2: #F1FFF3;--dec-light-pink: #FAE1EA;--dec-: #F4CBC1;--dec-lt-orange: #FAEFED;--dec-light-blue: #CFECF9;--dec-row-selection: #F1FDF8;--dec-row-selection2: #F2FBFF;--dec-row-lines: #D3E1E9;--text-white: #FFFFFF;--text-muted: #6A737D;--text-black: #181F33;--MR-solid-blue2:#C8D5F6;--MR-solid-purple:#C9C3FB;--MR-solid-orange:#EEAC9F;--MR-solid-green:#ACDADA;--MR-solid-brown:#E8C8AF;--MR-solid-yellow:#FFEFC7;--MR-solid-blue:#BBE6FF;--MR-solid-pink:#FFC6F2;--tr-hover:#F0F3FA;--tr-pressed:#DAE1F3;--brand-primary: #0937B2;--brand-primary-light: #3C68D0;--brand-primary-dark: #062A99;--brand-primary-darker: #041F80;--brand-primary-lighter: #638FE7;--brand-primary-lightest: #CBDDFB;--brand-primary-hover: #F0F3FA;--brand-primary-active: #DAE1F3;--brand-secondary: #ED711C;--brand-secondary-light: #F09E65;--brand-secondary-dark: #B23600;--brand-secondary-lighter: #FFC6F2;--brand-accent: #10ADAE;--brand-accent-light: #16CBBC;--brand-accent-dark: #035F6B;--brand-accent-lighter: #ACDADA;--brand-success: #38AF49;--brand-success-light: #4CAF50;--brand-success-dark: #216531;--brand-success-lighter: #E4F5E9;--brand-success-lightest: #F1FFF3;--brand-error: #B00020;--brand-error-light: #F04E4E;--brand-error-dark: #A60060;--brand-error-lighter: #FAE1EA;--brand-error-lightest: #FDF2F2;--brand-warning: #FF9D00;--brand-warning-light: #D4900C;--brand-warning-dark: #624000;--brand-warning-lighter: #F4E7C3;--brand-warning-lightest: #FAEFED;--brand-info: #0091FF;--brand-info-light: #35A1FF;--brand-info-dark: #0087B2;--brand-info-lighter: #CFECF9;--text-primary: #181F33;--text-secondary: #6A737D;--text-tertiary: #929DAB;--text-disabled: #929DAB;--text-primary-87: rgba(24, 31, 51, .87);--text-primary-60: rgba(24, 31, 51, .6);--text-primary-38: rgba(24, 31, 51, .38);--text-primary-12: rgba(24, 31, 51, .12);--bg-primary: #FFFFFF;--bg-secondary: #FAFAFA;--bg-tertiary: #F5F5F5;--bg-overlay: rgba(0, 0, 0, .32);--bg-overlay-light: rgba(0, 0, 0, .12);--bg-overlay-lighter: rgba(0, 0, 0, .08);--bg-overlay-lightest: rgba(0, 0, 0, .04);--border-primary: #E0E0E0;--border-secondary: #D6DCE2;--border-tertiary: #C8CDD3;--border-light: #F1F4F8;--border-primary-12: rgba(0, 0, 0, .12);--border-primary-08: rgba(0, 0, 0, .08);--border-primary-06: rgba(0, 0, 0, .06);--shadow-primary: rgba(0, 0, 0, .12);--shadow-secondary: rgba(0, 0, 0, .08);--shadow-tertiary: rgba(0, 0, 0, .04);--shadow-light: rgba(0, 0, 0, .06);--status-available: #929DAB;--status-unavailable: #CCD3DA;--status-hotseat: #857BFF;--status-multiteam: #10ADAE;--status-selected: #10ADAE;--status-upcoming: #D4900C;--status-room: #38AF49;--status-room-booked: #B23600;--status-room-unavailable: #181F33;--team-color-1: #F8C52E;--team-color-2: #FA8E20;--team-color-3: #987CDD;--team-color-4: #16CBBC;--team-color-5: #E65010;--team-color-6: #A60060;--team-color-7: #ED323B;--team-color-8: #35A1FF;--team-color-9: #80D348}#spinner[_ngcontent-%COMP%]{-webkit-animation:_ngcontent-%COMP%_frames 1s infinite linear;animation:_ngcontent-%COMP%_frames 1s infinite linear;background:transparent;border:4px solid var(--border-primary, #E0E0E0);border-radius:100%;border-top-color:var(--brand-primary, #0937B2);width:40px;height:40px;padding:0;position:absolute}@keyframes _ngcontent-%COMP%_frames{0%{-webkit-transform:rotate(0deg);transform:rotate(0)}to{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}.mobile[_ngcontent-%COMP%]{height:20px!important;width:20px!important;border:2px solid var(--border-primary, #E0E0E0)!important;border-top-color:var(--brand-primary, #0937B2)!important}"] }); }
16
22
  }
17
23
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(LoaderComponent, [{
18
24
  type: Component,
19
- args: [{ selector: "mis-loader", template: "<div\n id=\"spinner\"\n [ngClass]=\"{\n mobile: mobileView()\n }\"\n></div>\n", styles: [":root{--pmry-200: #99BAF7;--pmry-100: #CBDDFB;--pmry-500: #0937B2;--pmry-400: #3C68D0;--pmry-600: #062A99;--pmry-700: #041F80;--pmry-300: #638FE7;--pmry-800: #021567;--pmry-900: #010F55;--sec-d-purple: #40447F;--sec-maroon: #6B034E;--sec-mud-red: #B23600;--sec-orange: #ED711C;--sec-purple: #815FD5;--sec-teal: #10ADAE;--sec-yellow: #D4900C;--sec-green: #547F40;--sec-bright-green: #27D22E;--sec-dark-teal: #035F6B;--sec-chocolate: #7C2F33;--sec-rube-pink: #C13D6D;--sec-cerulean: #0087B2;--sem-error: #B00020;--sem-info: #0091FF;--sem-warning: #FF9D00;--sem-success: #38AF49;--grey-bg-1: #FAFAFA;--grey-bg: #F5F5F5;--grey-seperators: #E0E0E0;--grey-disabled: #C8CDD3;--grey-hover: #F5F7FC;--grey-pressed: #E6EBF7;--grey-row: #F5F7FC;--dec-light-yellow: #F4E7C3;--dec-light-purple: #DACFF9;--dec-light-green: #E4F5E9;--dec-light-green2: #F1FFF3;--dec-light-pink: #FAE1EA;--dec-: #F4CBC1;--dec-lt-orange: #FAEFED;--dec-light-blue: #CFECF9;--dec-row-selection: #F1FDF8;--dec-row-selection2: #F2FBFF;--dec-row-lines: #D3E1E9;--text-white: #FFFFFF;--text-muted: #6A737D;--text-black: #181F33;--MR-solid-blue2:#C8D5F6;--MR-solid-purple:#C9C3FB;--MR-solid-orange:#EEAC9F;--MR-solid-green:#ACDADA;--MR-solid-brown:#E8C8AF;--MR-solid-yellow:#FFEFC7;--MR-solid-blue:#BBE6FF;--MR-solid-pink:#FFC6F2;--tr-hover:#F0F3FA;--tr-pressed:#DAE1F3;--brand-primary: #0937B2;--brand-primary-light: #3C68D0;--brand-primary-dark: #062A99;--brand-primary-darker: #041F80;--brand-primary-lighter: #638FE7;--brand-primary-lightest: #CBDDFB;--brand-primary-hover: #F0F3FA;--brand-primary-active: #DAE1F3;--brand-secondary: #ED711C;--brand-secondary-light: #F09E65;--brand-secondary-dark: #B23600;--brand-secondary-lighter: #FFC6F2;--brand-accent: #10ADAE;--brand-accent-light: #16CBBC;--brand-accent-dark: #035F6B;--brand-accent-lighter: #ACDADA;--brand-success: #38AF49;--brand-success-light: #4CAF50;--brand-success-dark: #216531;--brand-success-lighter: #E4F5E9;--brand-success-lightest: #F1FFF3;--brand-error: #B00020;--brand-error-light: #F04E4E;--brand-error-dark: #A60060;--brand-error-lighter: #FAE1EA;--brand-error-lightest: #FDF2F2;--brand-warning: #FF9D00;--brand-warning-light: #D4900C;--brand-warning-dark: #624000;--brand-warning-lighter: #F4E7C3;--brand-warning-lightest: #FAEFED;--brand-info: #0091FF;--brand-info-light: #35A1FF;--brand-info-dark: #0087B2;--brand-info-lighter: #CFECF9;--text-primary: #181F33;--text-secondary: #6A737D;--text-tertiary: #929DAB;--text-disabled: #929DAB;--text-primary-87: rgba(24, 31, 51, .87);--text-primary-60: rgba(24, 31, 51, .6);--text-primary-38: rgba(24, 31, 51, .38);--text-primary-12: rgba(24, 31, 51, .12);--bg-primary: #FFFFFF;--bg-secondary: #FAFAFA;--bg-tertiary: #F5F5F5;--bg-overlay: rgba(0, 0, 0, .32);--bg-overlay-light: rgba(0, 0, 0, .12);--bg-overlay-lighter: rgba(0, 0, 0, .08);--bg-overlay-lightest: rgba(0, 0, 0, .04);--border-primary: #E0E0E0;--border-secondary: #D6DCE2;--border-tertiary: #C8CDD3;--border-light: #F1F4F8;--border-primary-12: rgba(0, 0, 0, .12);--border-primary-08: rgba(0, 0, 0, .08);--border-primary-06: rgba(0, 0, 0, .06);--shadow-primary: rgba(0, 0, 0, .12);--shadow-secondary: rgba(0, 0, 0, .08);--shadow-tertiary: rgba(0, 0, 0, .04);--shadow-light: rgba(0, 0, 0, .06);--status-available: #929DAB;--status-unavailable: #CCD3DA;--status-hotseat: #857BFF;--status-multiteam: #10ADAE;--status-selected: #10ADAE;--status-upcoming: #D4900C;--status-room: #38AF49;--status-room-booked: #B23600;--status-room-unavailable: #181F33;--team-color-1: #F8C52E;--team-color-2: #FA8E20;--team-color-3: #987CDD;--team-color-4: #16CBBC;--team-color-5: #E65010;--team-color-6: #A60060;--team-color-7: #ED323B;--team-color-8: #35A1FF;--team-color-9: #80D348}#spinner{-webkit-animation:frames 1s infinite linear;animation:frames 1s infinite linear;background:transparent;border:4px solid var(--border-primary, #E0E0E0);border-radius:100%;border-top-color:var(--brand-primary, #0937B2);width:40px;height:40px;padding:0;position:absolute}@keyframes frames{0%{-webkit-transform:rotate(0deg);transform:rotate(0)}to{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}.mobile{height:20px!important;width:20px!important;border:2px solid var(--border-primary, #E0E0E0)!important;border-top-color:var(--brand-primary, #0937B2)!important}\n"] }]
20
- }], null, null); })();
25
+ args: [{ selector: "mis-loader", template: "<div\n id=\"spinner\"\n [ngClass]=\"{\n mobile: mobileView()\n }\"\n [ngStyle]=\"{\n 'width': width(),\n 'height': height(),\n 'border': '4px solid ' + color(),\n 'border-top-color': borderTopColor()\n }\"\n></div>\n", styles: [":root{--pmry-200: #99BAF7;--pmry-100: #CBDDFB;--pmry-500: #0937B2;--pmry-400: #3C68D0;--pmry-600: #062A99;--pmry-700: #041F80;--pmry-300: #638FE7;--pmry-800: #021567;--pmry-900: #010F55;--sec-d-purple: #40447F;--sec-maroon: #6B034E;--sec-mud-red: #B23600;--sec-orange: #ED711C;--sec-purple: #815FD5;--sec-teal: #10ADAE;--sec-yellow: #D4900C;--sec-green: #547F40;--sec-bright-green: #27D22E;--sec-dark-teal: #035F6B;--sec-chocolate: #7C2F33;--sec-rube-pink: #C13D6D;--sec-cerulean: #0087B2;--sem-error: #B00020;--sem-info: #0091FF;--sem-warning: #FF9D00;--sem-success: #38AF49;--grey-bg-1: #FAFAFA;--grey-bg: #F5F5F5;--grey-seperators: #E0E0E0;--grey-disabled: #C8CDD3;--grey-hover: #F5F7FC;--grey-pressed: #E6EBF7;--grey-row: #F5F7FC;--dec-light-yellow: #F4E7C3;--dec-light-purple: #DACFF9;--dec-light-green: #E4F5E9;--dec-light-green2: #F1FFF3;--dec-light-pink: #FAE1EA;--dec-: #F4CBC1;--dec-lt-orange: #FAEFED;--dec-light-blue: #CFECF9;--dec-row-selection: #F1FDF8;--dec-row-selection2: #F2FBFF;--dec-row-lines: #D3E1E9;--text-white: #FFFFFF;--text-muted: #6A737D;--text-black: #181F33;--MR-solid-blue2:#C8D5F6;--MR-solid-purple:#C9C3FB;--MR-solid-orange:#EEAC9F;--MR-solid-green:#ACDADA;--MR-solid-brown:#E8C8AF;--MR-solid-yellow:#FFEFC7;--MR-solid-blue:#BBE6FF;--MR-solid-pink:#FFC6F2;--tr-hover:#F0F3FA;--tr-pressed:#DAE1F3;--brand-primary: #0937B2;--brand-primary-light: #3C68D0;--brand-primary-dark: #062A99;--brand-primary-darker: #041F80;--brand-primary-lighter: #638FE7;--brand-primary-lightest: #CBDDFB;--brand-primary-hover: #F0F3FA;--brand-primary-active: #DAE1F3;--brand-secondary: #ED711C;--brand-secondary-light: #F09E65;--brand-secondary-dark: #B23600;--brand-secondary-lighter: #FFC6F2;--brand-accent: #10ADAE;--brand-accent-light: #16CBBC;--brand-accent-dark: #035F6B;--brand-accent-lighter: #ACDADA;--brand-success: #38AF49;--brand-success-light: #4CAF50;--brand-success-dark: #216531;--brand-success-lighter: #E4F5E9;--brand-success-lightest: #F1FFF3;--brand-error: #B00020;--brand-error-light: #F04E4E;--brand-error-dark: #A60060;--brand-error-lighter: #FAE1EA;--brand-error-lightest: #FDF2F2;--brand-warning: #FF9D00;--brand-warning-light: #D4900C;--brand-warning-dark: #624000;--brand-warning-lighter: #F4E7C3;--brand-warning-lightest: #FAEFED;--brand-info: #0091FF;--brand-info-light: #35A1FF;--brand-info-dark: #0087B2;--brand-info-lighter: #CFECF9;--text-primary: #181F33;--text-secondary: #6A737D;--text-tertiary: #929DAB;--text-disabled: #929DAB;--text-primary-87: rgba(24, 31, 51, .87);--text-primary-60: rgba(24, 31, 51, .6);--text-primary-38: rgba(24, 31, 51, .38);--text-primary-12: rgba(24, 31, 51, .12);--bg-primary: #FFFFFF;--bg-secondary: #FAFAFA;--bg-tertiary: #F5F5F5;--bg-overlay: rgba(0, 0, 0, .32);--bg-overlay-light: rgba(0, 0, 0, .12);--bg-overlay-lighter: rgba(0, 0, 0, .08);--bg-overlay-lightest: rgba(0, 0, 0, .04);--border-primary: #E0E0E0;--border-secondary: #D6DCE2;--border-tertiary: #C8CDD3;--border-light: #F1F4F8;--border-primary-12: rgba(0, 0, 0, .12);--border-primary-08: rgba(0, 0, 0, .08);--border-primary-06: rgba(0, 0, 0, .06);--shadow-primary: rgba(0, 0, 0, .12);--shadow-secondary: rgba(0, 0, 0, .08);--shadow-tertiary: rgba(0, 0, 0, .04);--shadow-light: rgba(0, 0, 0, .06);--status-available: #929DAB;--status-unavailable: #CCD3DA;--status-hotseat: #857BFF;--status-multiteam: #10ADAE;--status-selected: #10ADAE;--status-upcoming: #D4900C;--status-room: #38AF49;--status-room-booked: #B23600;--status-room-unavailable: #181F33;--team-color-1: #F8C52E;--team-color-2: #FA8E20;--team-color-3: #987CDD;--team-color-4: #16CBBC;--team-color-5: #E65010;--team-color-6: #A60060;--team-color-7: #ED323B;--team-color-8: #35A1FF;--team-color-9: #80D348}#spinner{-webkit-animation:frames 1s infinite linear;animation:frames 1s infinite linear;background:transparent;border:4px solid var(--border-primary, #E0E0E0);border-radius:100%;border-top-color:var(--brand-primary, #0937B2);width:40px;height:40px;padding:0;position:absolute}@keyframes frames{0%{-webkit-transform:rotate(0deg);transform:rotate(0)}to{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}.mobile{height:20px!important;width:20px!important;border:2px solid var(--border-primary, #E0E0E0)!important;border-top-color:var(--brand-primary, #0937B2)!important}\n"] }]
26
+ }], () => [], null); })();
21
27
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(LoaderComponent, { className: "LoaderComponent" }); })();
22
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL21pcy1jb21wb25lbnRzL2xvYWRlci9sb2FkZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vcHJvamVjdHMvbWlzLWNvbXBvbmVudHMvbG9hZGVyL2xvYWRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBMkIsTUFBTSxlQUFlLENBQUM7Ozs7QUFPMUUsTUFBTSxPQUFPLGVBQWU7SUFMNUI7UUFNRSwyQkFBMkI7UUFDM0IsZUFBVSxHQUFHLEtBQUssQ0FBVSxLQUFLLENBQUMsQ0FBQztLQUNwQztnSEFIWSxlQUFlO29FQUFmLGVBQWU7WUNQNUIseUJBS087O1lBSEwsc0VBRUU7OztpRkRHUyxlQUFlO2NBTDNCLFNBQVM7MkJBQ0UsWUFBWTs7a0ZBSVgsZUFBZSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgaW5wdXQsIENoYW5nZURldGVjdGlvblN0cmF0ZWd5IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiBcIm1pcy1sb2FkZXJcIixcbiAgdGVtcGxhdGVVcmw6IFwiLi9sb2FkZXIuY29tcG9uZW50Lmh0bWxcIixcbiAgc3R5bGVVcmxzOiBbXCIuL2xvYWRlci5jb21wb25lbnQuc2Nzc1wiXSxcbn0pXG5leHBvcnQgY2xhc3MgTG9hZGVyQ29tcG9uZW50IHtcbiAgLyoqIENvbnRyb2xzIGxvYWRlciBzaXplICovXG4gIG1vYmlsZVZpZXcgPSBpbnB1dDxib29sZWFuPihmYWxzZSk7XG59XG4iLCI8ZGl2XG4gIGlkPVwic3Bpbm5lclwiXG4gIFtuZ0NsYXNzXT1cIntcbiAgICBtb2JpbGU6IG1vYmlsZVZpZXcoKVxuICB9XCJcbj48L2Rpdj5cbiJdfQ==
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL21pcy1jb21wb25lbnRzL2xvYWRlci9sb2FkZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vcHJvamVjdHMvbWlzLWNvbXBvbmVudHMvbG9hZGVyL2xvYWRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFPakQsTUFBTSxPQUFPLGVBQWU7SUFRMUI7UUFQQSwyQkFBMkI7UUFDM0IsZUFBVSxHQUFHLEtBQUssQ0FBVSxLQUFLLENBQUMsQ0FBQztRQUNuQyxVQUFLLEdBQUcsS0FBSyxDQUFTLGdDQUFnQyxDQUFDLENBQUM7UUFDeEQsV0FBTSxHQUFHLEtBQUssQ0FBUyxNQUFNLENBQUMsQ0FBQztRQUMvQixVQUFLLEdBQUcsS0FBSyxDQUFTLE1BQU0sQ0FBQyxDQUFDO1FBQzlCLG1CQUFjLEdBQUcsS0FBSyxDQUFTLCtCQUErQixDQUFDLENBQUM7SUFFakQsQ0FBQztJQUNoQixRQUFRLEtBQUksQ0FBQztnSEFURixlQUFlO29FQUFmLGVBQWU7WUNQNUIseUJBV087O1lBTkwsQUFIQSxzRUFFRSxvSEFNQTs7O2lGREhTLGVBQWU7Y0FMM0IsU0FBUzsyQkFDRSxZQUFZOztrRkFJWCxlQUFlIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBpbnB1dCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogXCJtaXMtbG9hZGVyXCIsXG4gIHRlbXBsYXRlVXJsOiBcIi4vbG9hZGVyLmNvbXBvbmVudC5odG1sXCIsXG4gIHN0eWxlVXJsczogW1wiLi9sb2FkZXIuY29tcG9uZW50LnNjc3NcIl0sXG59KVxuZXhwb3J0IGNsYXNzIExvYWRlckNvbXBvbmVudCB7XG4gIC8qKiBDb250cm9scyBsb2FkZXIgc2l6ZSAqL1xuICBtb2JpbGVWaWV3ID0gaW5wdXQ8Ym9vbGVhbj4oZmFsc2UpO1xuICBjb2xvciA9IGlucHV0PHN0cmluZz4oJ3ZhcigtLWJvcmRlci1wcmltYXJ5LCAjRTBFMEUwKScpO1xuICBoZWlnaHQgPSBpbnB1dDxzdHJpbmc+KCc0MHB4Jyk7XG4gIHdpZHRoID0gaW5wdXQ8c3RyaW5nPignNDBweCcpO1xuICBib3JkZXJUb3BDb2xvciA9IGlucHV0PHN0cmluZz4oJ3ZhcigtLWJyYW5kLXByaW1hcnksICMwOTM3YjIpJyk7XG5cbiAgY29uc3RydWN0b3IoKSB7fVxuICBuZ09uSW5pdCgpIHt9XG5cbn1cbiIsIjxkaXZcbiAgaWQ9XCJzcGlubmVyXCJcbiAgW25nQ2xhc3NdPVwie1xuICAgIG1vYmlsZTogbW9iaWxlVmlldygpXG4gIH1cIlxuICBbbmdTdHlsZV09XCJ7XG4gICAgJ3dpZHRoJzogd2lkdGgoKSxcbiAgICAnaGVpZ2h0JzogaGVpZ2h0KCksXG4gICAgJ2JvcmRlcic6ICc0cHggc29saWQgJyArIGNvbG9yKCksXG4gICAgJ2JvcmRlci10b3AtY29sb3InOiBib3JkZXJUb3BDb2xvcigpXG4gIH1cIlxuPjwvZGl2PlxuIl19
@@ -24,11 +24,11 @@ export class SliderComponent {
24
24
  } if (rf & 2) {
25
25
  i0.ɵɵadvance();
26
26
  i0.ɵɵproperty("min", ctx.min())("max", ctx.max())("value", ctx.currentValue());
27
- } }, styles: [".slider[_ngcontent-%COMP%]{width:100%;display:flex;align-items:center;input[type=range]{width:100%;-webkit-appearance:none;appearance:none;height:8px;background:var(--brand-primary-lightest, #CBDDFB);outline:none;border-radius:5px;&::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:22px;height:22px;background:var(--brand-primary, #0937B2);cursor:pointer;border-radius:50%}&::-moz-range-thumb{width:15px;height:15px;background:var(--brand-primary, #0937B2);cursor:pointer;border-radius:50%}}span{margin-left:10px}}"] }); }
27
+ } }, styles: [".slider[_ngcontent-%COMP%]{width:100%;display:flex;align-items:center}.slider[_ngcontent-%COMP%] input[type=range][_ngcontent-%COMP%]{width:100%;-webkit-appearance:none;appearance:none;height:8px;background:var(--brand-primary-lightest, #CBDDFB);outline:none;border-radius:5px}.slider[_ngcontent-%COMP%] input[type=range][_ngcontent-%COMP%]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:22px;height:22px;background:var(--brand-primary, #0937B2);cursor:pointer;border-radius:50%}.slider[_ngcontent-%COMP%] input[type=range][_ngcontent-%COMP%]::-moz-range-thumb{width:15px;height:15px;background:var(--brand-primary, #0937B2);cursor:pointer;border-radius:50%}.slider[_ngcontent-%COMP%] span[_ngcontent-%COMP%]{margin-left:10px}"] }); }
28
28
  }
29
29
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SliderComponent, [{
30
30
  type: Component,
31
- args: [{ selector: 'mis-slider', template: "<div class=\"slider\">\n <input \n type=\"range\" \n [min]=\"min()\" \n [max]=\"max()\" \n [value]=\"currentValue()\"\n (input)=\"onInputChange($event.target.value)\" />\n</div>\n \n\n ", styles: [".slider{width:100%;display:flex;align-items:center;input[type=range]{width:100%;-webkit-appearance:none;appearance:none;height:8px;background:var(--brand-primary-lightest, #CBDDFB);outline:none;border-radius:5px;&::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:22px;height:22px;background:var(--brand-primary, #0937B2);cursor:pointer;border-radius:50%}&::-moz-range-thumb{width:15px;height:15px;background:var(--brand-primary, #0937B2);cursor:pointer;border-radius:50%}}span{margin-left:10px}}\n"] }]
31
+ args: [{ selector: 'mis-slider', template: "<div class=\"slider\">\n <input \n type=\"range\" \n [min]=\"min()\" \n [max]=\"max()\" \n [value]=\"currentValue()\"\n (input)=\"onInputChange($event.target.value)\" />\n</div>\n \n\n ", styles: [".slider{width:100%;display:flex;align-items:center}.slider input[type=range]{width:100%;-webkit-appearance:none;appearance:none;height:8px;background:var(--brand-primary-lightest, #CBDDFB);outline:none;border-radius:5px}.slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:22px;height:22px;background:var(--brand-primary, #0937B2);cursor:pointer;border-radius:50%}.slider input[type=range]::-moz-range-thumb{width:15px;height:15px;background:var(--brand-primary, #0937B2);cursor:pointer;border-radius:50%}.slider span{margin-left:10px}\n"] }]
32
32
  }], () => [], { valueChange: [{
33
33
  type: Output
34
34
  }] }); })();