chrv-components 1.8.3 → 1.8.5

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.
Binary file
@@ -34,10 +34,6 @@ export class ChrFormComponent {
34
34
  this.values = {};
35
35
  this.controlTypes = {};
36
36
  this.flattenedControls = [];
37
- this.updateValueAndValidity = () => {
38
- this.form.markAsDirty();
39
- this.form.updateValueAndValidity({ emitEvent: true });
40
- };
41
37
  this.initialized = false;
42
38
  this.initModel = () => {
43
39
  if (this.model == null)
@@ -61,9 +57,9 @@ export class ChrFormComponent {
61
57
  this.controlTypes[control.name] = control.type;
62
58
  }
63
59
  this.form = this.builder.group(formControls);
60
+ this.valid = this.form.valid;
64
61
  };
65
62
  this.initListeners = () => {
66
- // Listen for changes and update the model
67
63
  this.form.valueChanges.subscribe((values) => {
68
64
  for (const key in values) {
69
65
  if (values.hasOwnProperty(key)) {
@@ -96,6 +92,7 @@ export class ChrFormComponent {
96
92
  this.setValue(key, value);
97
93
  else
98
94
  this.setValue(key, this.datePipe.transform(value, dateFormat));
95
+ this.form.get(key)?.updateValueAndValidity();
99
96
  this.detectChanges();
100
97
  };
101
98
  this.patch = (model, dateFormat = null) => {
@@ -104,6 +101,17 @@ export class ChrFormComponent {
104
101
  }
105
102
  this.detectChanges();
106
103
  };
104
+ this.checkValidity = () => {
105
+ for (const control of this.flattenedControls) {
106
+ this.form.get(control.name)?.updateValueAndValidity();
107
+ }
108
+ this.valid = this.form.valid;
109
+ this.detectChanges();
110
+ };
111
+ this.updateValueAndValidity = () => {
112
+ this.form.markAsDirty();
113
+ this.form.updateValueAndValidity({ emitEvent: true });
114
+ };
107
115
  this.setValue = (key, value) => {
108
116
  this.form.get(key)?.patchValue(value);
109
117
  this.values[key] = value;
@@ -125,10 +133,6 @@ export class ChrFormComponent {
125
133
  this.transformDate = (value, format) => {
126
134
  return this.datePipe.transform(value, format);
127
135
  };
128
- this.reset = () => {
129
- this.form.reset();
130
- this.detectChanges();
131
- };
132
136
  this.resize = (textArea) => {
133
137
  const initialHeight = textArea.style.height;
134
138
  textArea.style.height = initialHeight;
@@ -261,4 +265,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.6", ngImpor
261
265
  }], tabDisplay: [{
262
266
  type: Input
263
267
  }] } });
264
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chr-form.component.js","sourceRoot":"","sources":["../../../../../projects/chrv-components/src/lib/chr-form/chr-form.component.ts","../../../../../projects/chrv-components/src/lib/chr-form/chr-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n\tComponent,\n\tInput,\n\tOutput,\n\tEventEmitter,\n\tAfterViewInit,\n\tChangeDetectionStrategy,\n\tViewEncapsulation,\n\tChangeDetectorRef,\n\tOnChanges,\n\tSimpleChanges,\n\tOnInit,\n} from \"@angular/core\";\nimport { ValidatorFn, ReactiveFormsModule, FormsModule } from \"@angular/forms\";\nimport {\n\tFormBuilder,\n\tFormGroup,\n\tValidators,\n\tFormControl,\n} from \"@angular/forms\";\nimport { MatError } from \"@angular/material/form-field\";\nimport { MatIconModule } from \"@angular/material/icon\";\nimport { MatTooltipModule } from \"@angular/material/tooltip\";\nimport { ChrSearchSelectComponent } from \"../chr-search-select/chr-search-select.component\";\nimport { MatSlideToggleModule } from \"@angular/material/slide-toggle\";\nimport {\n\tDatePipe,\n\tCommonModule,\n\tDATE_PIPE_DEFAULT_OPTIONS,\n} from \"@angular/common\";\nimport { MatAutocompleteModule } from \"@angular/material/autocomplete\";\nimport { MatTabsModule } from \"@angular/material/tabs\";\nimport {\n\ttype,\n\tTypeValidatorDirective,\n} from \"../models/chr-validators/type-validator\";\nimport { decimal } from \"../models/chr-validators/decimal-validator\";\nimport { maxDate } from \"../models/chr-validators/max-date-validator\";\n\nexport interface IFormControlCollection {\n\t[key: string]: FormControl;\n}\n\nexport interface ISearchFilter {\n\tdisplay: string;\n\tcallback?: Function;\n\ttooltip?: string;\n}\n\nexport interface IControlValidation {\n\trule: string;\n\tvalue?: any;\n\tdisplay?: string;\n}\n\nexport interface IControl {\n\tlabel?: string;\n\tname: string;\n\tspan?: string;\n\twidth?: \"col\" | \"row\";\n\tcol?: number;\n\trow?: number;\n\ttype:\n\t\t| \"text\"\n\t\t| \"password\"\n\t\t| \"textArea\"\n\t\t| \"number\"\n\t\t| \"date\"\n\t\t| \"datetime\"\n\t\t| \"searchSelect\"\n\t\t| \"color\"\n\t\t| \"toggle\";\n\tvalue?: any;\n\tdata?: any[] | null;\n\ticon?: string;\n\ticonCallback?: Function;\n\ticonCallbackDisabled?: boolean;\n\ticonTooltip?: string;\n\tfn?: (object: any) => string;\n\tfilters?: ISearchFilter[];\n\tvalidations?: IControlValidation[];\n}\n\nexport interface IFormSection {\n\ttitle?: string;\n\tcontrols: IControl[];\n}\n\nexport interface IFormControl {\n\t[key: string]: any;\n}\n@Component({\n\tselector: \"app-chr-form\",\n\ttemplateUrl: \"./chr-form.component.html\",\n\tstyleUrls: [\n\t\t\"./chr-form.component.scss\",\n\t\t\"../../../../../tailwindbuild.css\",\n\t\t\"./chr-form.component.scss\",\n\t],\n\tstandalone: true,\n\timports: [\n\t\tReactiveFormsModule,\n\t\tFormsModule,\n\t\tMatTooltipModule,\n\t\tMatIconModule,\n\t\tMatSlideToggleModule,\n\t\tMatError,\n\t\tChrSearchSelectComponent,\n\t\tMatAutocompleteModule,\n\t\tDatePipe,\n\t\tCommonModule,\n\t\tTypeValidatorDirective,\n\t\tMatTabsModule,\n\t],\n\tproviders: [\n\t\tDatePipe,\n\t\t{\n\t\t\tprovide: DATE_PIPE_DEFAULT_OPTIONS,\n\t\t\tuseValue: { dateFormat: \"shortDate\" },\n\t\t},\n\t],\n\tchangeDetection: ChangeDetectionStrategy.Default,\n})\nexport class ChrFormComponent implements OnInit {\n\t@Input() sections?: IFormSection[];\n\t@Input() controls?: IControl[];\n\n\t@Input() valid?: boolean;\n\t@Output() validChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n\t@Input() model: any = null;\n\t@Output() modelChange: EventEmitter<any> = new EventEmitter<any>();\n\n\t@Input() disabled?: boolean;\n\t@Output() valuesChange: EventEmitter<any> = new EventEmitter();\n\n\t@Input() submit?: Function;\n\n\t@Input() compact: boolean = false;\n\n\t@Output() formChange: EventEmitter<IFormControl> =\n\t\tnew EventEmitter<IFormControl>();\n\n\t@Input() tabDisplay: boolean = false;\n\n\tform: FormGroup = this.builder.group({});\n\n\tprivate values: { [key: string]: any } = {};\n\tprivate controlTypes: { [key: string]: string } = {};\n\tprivate flattenedControls: IControl[] = [];\n\n\tupdateValueAndValidity = () => {\n\t\tthis.form.markAsDirty();\n\t\tthis.form.updateValueAndValidity({ emitEvent: true });\n\t};\n\n\tpublic initialized: boolean = false;\n\n\tconstructor(\n\t\tprivate builder: FormBuilder,\n\t\tprivate datePipe: DatePipe,\n\t\tprivate changeDetector: ChangeDetectorRef\n\t) {\n\t\tif (this.controls != null && this.sections != null)\n\t\t\tthrow new Error(\n\t\t\t\t\"You can't use both controls and sections in the same form\"\n\t\t\t);\n\t}\n\n\tngOnInit(): void {\n\t\tthis.flattenedControls =\n\t\t\tthis.sections\n\t\t\t\t?.map((s) => s.controls)\n\t\t\t\t.flat()\n\t\t\t\t.concat(this.controls ?? []) || [];\n\t\tthis.initModel();\n\t\tthis.initValues();\n\t\tthis.initControls();\n\t\tthis.initListeners();\n\t\tthis.initialized = true;\n\t}\n\n\tinitModel = () => {\n\t\tif (this.model == null) this.model = {};\n\n\t\tfor (const control of this.flattenedControls) {\n\t\t\tif (!this.model[control.name]) this.model[control.name] = control.value;\n\t\t}\n\t};\n\n\tinitValues = () => {\n\t\tfor (const control of this.flattenedControls) {\n\t\t\tif (!this.values[control.name])\n\t\t\t\tthis.values[control.name] = this.toInputValue(\n\t\t\t\t\tcontrol,\n\t\t\t\t\tthis.model[control.name]\n\t\t\t\t);\n\t\t}\n\t};\n\n\tinitControls = () => {\n\t\tconst formControls = {} as IFormControlCollection;\n\t\tfor (const control of this.flattenedControls) {\n\t\t\tconst validators = this._getValidators(control.validations);\n\t\t\tformControls[control.name] = new FormControl(\n\t\t\t\tthis.values[control.name],\n\t\t\t\tvalidators\n\t\t\t);\n\t\t\tthis.controlTypes[control.name] = control.type;\n\t\t}\n\n\t\tthis.form = this.builder.group(formControls);\n\t};\n\n\tinitListeners = () => {\n\t\t// Listen for changes and update the model\n\t\tthis.form.valueChanges.subscribe((values) => {\n\t\t\tfor (const key in values) {\n\t\t\t\tif (values.hasOwnProperty(key)) {\n\t\t\t\t\tthis.model[key] = values[key];\n\t\t\t\t\tthis.values[key] = values[key];\n\t\t\t\t}\n\t\t\t}\n\t\t\tthis.valid = this.form.valid;\n\t\t\tthis.validChange.emit(this.valid);\n\t\t\tthis.modelChange.emit(this.model);\n\t\t\tthis.changeDetector.detectChanges();\n\t\t});\n\t};\n\n\tvalue = (input?: string) => this.getValue(input);\n\n\tgetValue = (input?: string) => {\n\t\tif (input) return this.form.controls[input]?.value;\n\t\treturn this.form.value;\n\t};\n\n\tisValid = (input?: string) => {\n\t\tif (input) return this.form.get(input)?.valid;\n\t\treturn this.valid;\n\t};\n\n\tisControlRequired = (control: IControl) => {\n\t\treturn control.validations?.find((v) => v.rule.toLowerCase() == \"required\");\n\t};\n\n\tpatchValue = (key: string, value: any, dateFormat: string | null = null) => {\n\t\tif (dateFormat == null) this.setValue(key, value);\n\t\telse this.setValue(key, this.datePipe.transform(value, dateFormat));\n\t\tthis.detectChanges();\n\t};\n\n\tpatch = (model: any, dateFormat: string | null = null) => {\n\t\tfor (const key of Object.keys(model)) {\n\t\t\tthis.patchValue(key, model[key], dateFormat);\n\t\t}\n\t\tthis.detectChanges();\n\t};\n\n\tprivate setValue = (key: string, value: any) => {\n\t\tthis.form.get(key)?.patchValue(value);\n\t\tthis.values[key] = value;\n\t};\n\n\tprivate toInputValue = (control: IControl, value: any | null = null) => {\n\t\tswitch (control.type) {\n\t\t\tcase \"date\":\n\t\t\t\treturn value\n\t\t\t\t\t? this.transformDate(value, \"yyyy-MM-dd\")\n\t\t\t\t\t: this.transformDate(control.value, \"yyyy-MM-dd\");\n\t\t\tcase \"datetime\":\n\t\t\t\treturn value\n\t\t\t\t\t? this.transformDate(value, \"yyyy-MM-ddTHH:mm\")\n\t\t\t\t\t: this.transformDate(control.value, \"yyyy-MM-ddTHH:mm\");\n\t\t\tdefault:\n\t\t\t\treturn value || control.value;\n\t\t}\n\t};\n\n\tprivate transformDate = (value: any, format: string) => {\n\t\treturn this.datePipe.transform(value, format);\n\t};\n\n\treset = () => {\n\t\tthis.form.reset();\n\t\tthis.detectChanges();\n\t};\n\n\tpublic resize = (textArea: HTMLTextAreaElement) => {\n\t\tconst initialHeight = textArea.style.height;\n\t\ttextArea.style.height = initialHeight;\n\t\ttextArea.style.height = \"\" + textArea.scrollHeight + \"px\";\n\t};\n\n\tpublic doSubmit = () => {\n\t\tthis.form.markAllAsTouched();\n\t\tif (this.valid && this.form.valid) this.submit?.(this.form.value);\n\t};\n\n\tprivate detectChanges = () => {\n\t\tthis.form.markAsDirty();\n\t\tthis.form.updateValueAndValidity({ emitEvent: true });\n\t\tthis.changeDetector.detectChanges();\n\t};\n\n\tprivate _getValidators = (validations?: IControlValidation[]) => {\n\t\tconst validators: ValidatorFn[] = [];\n\t\tif (!validations) return validators;\n\t\t//Switch case breaks the mobile app so we'll do if statements\n\t\tfor (const validation of validations) {\n\t\t\tconst rule = validation.rule.toLocaleLowerCase();\n\t\t\tif (rule == \"min\") {\n\t\t\t\tvalidation.display = \"Cette valeur est trop petite !\";\n\t\t\t\tvalidators.push(Validators.min(validation.value));\n\t\t\t}\n\t\t\tif (rule == \"max\") {\n\t\t\t\tvalidation.display = \"Cette valeur est trop grande !\";\n\t\t\t\tvalidators.push(Validators.max(validation.value));\n\t\t\t}\n\t\t\tif (rule == \"required\") {\n\t\t\t\tvalidation.display = \"Ce champs est requis !\";\n\t\t\t\tvalidators.push(Validators.required);\n\t\t\t}\n\t\t\tif (rule == \"email\") {\n\t\t\t\tvalidation.display = \"Cette adresse email n'est pas valide !\";\n\t\t\t\tvalidators.push(Validators.email);\n\t\t\t}\n\t\t\tif (rule == \"minlength\") {\n\t\t\t\tvalidation.display = \"Cette valeur est trop petite !\";\n\t\t\t\tvalidators.push(Validators.minLength(validation.value));\n\t\t\t}\n\t\t\tif (rule == \"maxlength\") {\n\t\t\t\tvalidation.display = \"Cette valeur est trop grande !\";\n\t\t\t\tvalidators.push(Validators.maxLength(validation.value));\n\t\t\t}\n\t\t\tif (rule == \"type\") {\n\t\t\t\tvalidation.display = \"Cette valeur n'est pas valide !\";\n\t\t\t\tvalidators.push(type(validation.value));\n\t\t\t}\n\t\t\tif (rule == \"decimal\") {\n\t\t\t\tvalidation.display = `Le nombre de décimal n'est pas valide (max: ${validation.value}) !`;\n\t\t\t\tvalidators.push(decimal(validation.value));\n\t\t\t}\n\t\t\tif (rule == \"maxdate\") {\n\t\t\t\tvalidation.display = `Cette date est trop grande ! (max: ${validation.value}) !`;\n\t\t\t\tvalidators.push(maxDate(validation.value));\n\t\t\t}\n\t\t}\n\t\treturn validators;\n\t};\n}\n","<div class=\"flex flex-col justify-center min-h-5/6 mt-2\">\n  <form [formGroup]=\"form\" *ngIf=\"initialized\">\n    <ng-container *ngIf=\"!tabDisplay || !sections\" [ngTemplateOutlet]=\"singleTemplate\"\n      [ngTemplateOutletContext]=\"{controls: controls}\">\n    </ng-container>\n    <ng-container *ngIf=\"!tabDisplay && sections\" [ngTemplateOutlet]=\"sectionTemplate\"\n      [ngTemplateOutletContext]=\"{sections: sections}\">\n    </ng-container>\n    <ng-container *ngIf=\"tabDisplay && sections\" [ngTemplateOutlet]=\"tabsTemplate\"\n      [ngTemplateOutletContext]=\"{sects: sections}\">\n    </ng-container>\n  </form>\n</div>\n\n<ng-template #tabsTemplate let-sections='sects'>\n  <fieldset [disabled]=\"disabled\">\n    <mat-tab-group>\n      @for (section of sections; track section; let index = $index) {\n      <mat-tab [label]=\"section.title || 'Étape ' + (index + 1)\">\n        <div *ngIf=\"initialized\" class=\"mt-4\"\n          [ngClass]=\"compact ? 'grid gap-y-2 gap-x-6 sm:grid-cols-4':'grid gap-y-2 gap-x-6 sm:grid-cols-2'\">\n          @for (ctrl of section.controls; track index; let index = $index; let\n          last =\n          $last)\n          {\n          <ng-container [ngTemplateOutlet]=\"controlTemplate\"\n            [ngTemplateOutletContext]=\"{control: ctrl, index: index, last: $last}\">\n          </ng-container>\n          }\n        </div>\n      </mat-tab>\n      }\n    </mat-tab-group>\n  </fieldset>\n</ng-template>\n\n<ng-template #singleTemplate let-controls=\"controls\">\n  <fieldset [disabled]=\"disabled\">\n    <div *ngIf=\"initialized\"\n      [ngClass]=\"compact ? 'grid gap-y-2 gap-x-6 sm:grid-cols-4':'grid gap-y-2 gap-x-6 sm:grid-cols-2'\">\n      @for (control of controls; track control; let index = $index; let last = $last) {\n      <ng-container [ngTemplateOutlet]=\"controlTemplate\"\n        [ngTemplateOutletContext]=\"{control: control, index: index, last: last}\">\n      </ng-container>\n      }\n    </div>\n\n  </fieldset>\n</ng-template>\n\n<ng-template #sectionTemplate let-sections='sections'>\n  <fieldset [disabled]=\"disabled\">\n    @for (section of sections; track section; let index = $index) {\n    <div>\n      @if (section.title) {\n      <h2 class=\"mb-2 font-bold text-xl text-gray-900 dark:text-white\">\n        {{ section.title }}\n      </h2>\n      }\n      <div *ngIf=\"initialized\"\n        [ngClass]=\"compact ? 'grid gap-y-2 gap-x-6 sm:grid-cols-4':'grid gap-y-2 gap-x-6 sm:grid-cols-2'\">\n        @for (control of section.controls; track index; let index = $index; let\n        last =\n        $last)\n        {\n        <ng-container [ngTemplateOutlet]=\"controlTemplate\"\n          [ngTemplateOutletContext]=\"{control: control, index: index, last: $last}\">\n        </ng-container>\n        }\n      </div>\n      @if (index != (sections||[]).length - 1 && !compact) {\n      <div class=\"py-4\">\n        <hr class=\"\" />\n      </div>\n      }\n    </div>\n    }\n  </fieldset>\n</ng-template>\n\n<ng-template #controlTemplate let-control='control' let-last='last' let-index='index'>\n  <div class=\"relative h-min mt-2\" [formGroup]=\"form\" [ngClass]=\"{\n    'sm:col-span-2': (control.width == 'row' && !compact) || control.type=='textArea' && compact && control.width != 'row',\n    'sm:col-span-4': control.width =='row' && compact,\n    }\">\n    @if (control.type=='searchSelect') {\n    <div app-chr-search-select class=\"relative input z-0 w-full\" id=\"{{ control.name }}_{{ index }}\"\n      [ngClass]=\"(form.get([control.name])?.touched && form.get([control.name])?.errors) ? 'error':'border-gray-300 dark:border-gray-600'\"\n      [data]=\"control.data || []\" [display]=\"control.fn!\" [name]=\"control.name\" placeholder=\" \"\n      [filters]=\"control.filters\" [formControlName]=\"control.name\" (keyup.enter)=\"last ? doSubmit() : ''\">\n      <label class=\"label absolute text-sm text-gray-500 dark:text-gray-400\" [for]=\"control.name\">{{\n        control.label\n        }}\n        @if (isControlRequired(control)) {\n        <span class=\"text-red-500\">*</span>\n        }\n        :\n        @for (validation of control.validations; track validation) {\n        @if (\n        form.get([control.name])?.touched &&\n        form.hasError(validation.rule.toLowerCase(), control.name)\n        ) {\n        <mat-error class=\"text-red-500 dark:text-red-800\">{{ validation.display }}</mat-error>\n        }\n        }\n      </label>\n    </div>\n    }\n    <div class=\"relative z-0 w-full group/inputs content\">\n      <!-- Here we will *ngIf each type of input cause it's the cleanest way I can imagine-->\n      <!--TEXT-->\n      @if (control.type == 'text') {\n      <input class=\"relative\"\n        [ngClass]=\"(form.get([control.name])?.touched && form.get([control.name])?.errors) ? 'error':'border-gray-300 dark:border-gray-600'\"\n        type=\"text\" id=\"{{ control.name }}_{{ index }}\" name=\"{{ control.name }}\" [formControlName]=\"control.name\"\n        placeholder=\" \" [value]=\"model?.[control.name] || control.value || ''\" (keyup.enter)=\"last ? doSubmit() : ''\"\n        class=\"block input py-2.5 px-0 w-full text-sm text-gray-900 dark:text-white bg-transparent border-0 border-b-2 appearance-none dark:focus:border-chrlblue focus:outline-none focus:ring-0 focus:border-chrdblue peer/inputs\" />\n      }\n      <!--PASSWORD-->\n      @if (control.type == 'password') {\n      <input class=\"relative\"\n        [ngClass]=\"(form.get([control.name])?.touched && form.get([control.name])?.errors) ? 'error':'border-gray-300 dark:border-gray-600'\"\n        type=\"password\" id=\"{{ control.name }}_{{ index }}\" name=\"{{ control.name }}\" [formControlName]=\"control.name\"\n        placeholder=\" \" (keyup.enter)=\"last ? doSubmit() : ''\"\n        class=\"block input py-2.5 px-0 w-full text-sm text-gray-900 dark:text-white bg-transparent border-0 border-b-2 appearance-none dark:border-gray-600 dark:focus:border-chrlblue focus:outline-none focus:ring-0 focus:border-chrdblue peer/inputs\" />\n      }\n      <!--TEXT AREA-->\n      @if (control.type == 'textArea') {\n      <textarea #textArea class=\"relative\"\n        [ngClass]=\"(form.get([control.name])?.touched && form.get([control.name])?.errors) ? 'error':'border-gray-300 dark:border-gray-600'\"\n        id=\"{{ control.name }}_{{ index }}\" name=\"{{ control.name }}\" [formControlName]=\"control.name\" placeholder=\" \"\n        (input)=\"resize(textArea)\" (keyup.enter)=\"last ? doSubmit() : ''\"\n        class=\"no-scrollbar input !resize-none height-normalized block py-2 px-0 w-full text-sm text-gray-900 dark:text-white bg-transparent border-0 border-b-2 appearance-none dark:border-gray-600 dark:focus:border-chrlblue focus:outline-none focus:ring-0 focus:border-chrdblue peer/inputs\"></textarea>\n      }\n      <!--NUMBER-->\n      @if (control.type == 'number') {\n      <input class=\"relative\"\n        [ngClass]=\"(form.get([control.name])?.touched && form.get([control.name])?.errors) ? 'error':'border-gray-300 dark:border-gray-600'\"\n        type=\"number\" id=\"{{ control.name }}_{{ index }}\" name=\"{{ control.name }}\" placeholder=\" \"\n        [formControlName]=\"control.name\" (keyup.enter)=\"last ? doSubmit() : ''\"\n        class=\"block input py-2.5 px-0 w-full text-sm text-gray-900 dark:text-white bg-transparent border-0 border-b-2 appearance-none dark:border-gray-600 dark:focus:border-chrlblue focus:outline-none focus:ring-0 focus:border-chrdblue peer/inputs\" />\n      }\n      <!--DATE-->\n      @if (control.type == 'date') {\n      <input class=\"relative\"\n        [ngClass]=\"(form.get([control.name])?.touched && form.get([control.name])?.errors) ? 'error':'border-gray-300 dark:border-gray-600'\"\n        type=\"date\" id=\"{{ control.name }}_{{ index }}\" name=\"{{ control.name }}\" [formControlName]=\"control.name\"\n        placeholder=\" \" (keyup.enter)=\"last ? doSubmit() : ''\"\n        class=\"block input py-2 px-0 w-full height-normalized text-sm text-gray-900 dark:text-white bg-transparent border-0 border-b-2 appearance-none dark:border-gray-600 dark:focus:border-chrlblue focus:outline-none focus:ring-0 focus:border-chrdblue peer/inputs\" />\n      }\n      @if (control.type == 'datetime') {\n      <input class=\"relative\"\n        [ngClass]=\"(form.get([control.name])?.touched && form.get([control.name])?.errors) ? 'error':'border-gray-300 dark:border-gray-600'\"\n        type=\"datetime-local\" id=\"{{ control.name }}_{{ index }}\" name=\"{{ control.name }}\"\n        [formControlName]=\"control.name\" placeholder=\" \" (keyup.enter)=\"last ? doSubmit() : ''\"\n        class=\"block input py-2 px-0 w-full height-normalized text-sm text-gray-900 dark:text-white bg-transparent border-0 border-b-2 appearance-none dark:border-gray-600 dark:focus:border-chrlblue focus:outline-none focus:ring-0 focus:border-chrdblue peer/inputs\" />\n      }\n      <!--COLOR-->\n      @if (control.type == 'color') {\n      <input class=\"relative\"\n        [ngClass]=\"(form.get([control.name])?.touched && form.get([control.name])?.errors) ? 'error':'border-gray-300 dark:border-gray-600'\"\n        type=\"color\" id=\"{{ control.name }}_{{ index }}\" name=\"{{ control.name }}\" [formControlName]=\"control.name\"\n        placeholder=\" \" (keyup.enter)=\"last ? doSubmit() : ''\" style=\"height: 42px;\"\n        class=\"block input py-1.5 m-0 px-0 w-full bg-transparent border-0 border-b-2 dark:focus:border-chrlblue focus:outline-none focus:ring-0 focus:border-chrdblue peer/inputs\" />\n      }\n      @if (control.type == 'toggle'){\n      <input #toggle type=\"checkbox\" class=\"hidden checkbox\" [formControlName]=\"control.name\" placeholder=\" \" />\n      <div\n        class=\"relative toggle-wrapper block input bg-transparent border-0 border-b-2 border-gray-300 dark:focus:border-chrlblue focus:outline-none focus:ring-0 focus:border-chrdblue peer/inputs\">\n        <div (click)=\"toggle?.click()\" class=\"relative block input toggle\">\n        </div>\n      </div>\n      }\n      @if (control.type != 'searchSelect') {\n      <label class=\"label absolute text-sm text-gray-500 dark:text-gray-400\" [for]=\"control.name\">{{\n        control.label\n        }}\n        @if(control.label && control.label != '' && control.label != ' '){\n        @if (isControlRequired(control)) {\n        <span class=\"text-red-500\">*</span>\n        }\n        :\n        }\n        @for (validation of control.validations; track validation) {\n        @if (\n        form.get([control.name])?.touched &&\n        form.hasError(validation.rule.toLowerCase(), control.name)\n        ) {\n        <mat-error class=\"text-red-500 dark:text-red-800\">{{ validation.display }}</mat-error>\n        }\n        }\n      </label>\n      }\n      @if (control.icon && !disabled) {\n      <span\n        [ngClass]=\"control.iconCallbackDisabled ? 'text-gray-400 dark:text-gray-500':'text-gray-900 dark:text-white'\"\n        class=\"absolute p-2.5 bottom-0 right-0\" [matTooltip]=\"control.iconTooltip || ''\" matTooltipPosition=\"above\"\n        (click)=\"!control.iconCallbackDisabled && control.iconCallback?.(form.get([control.name])?.value)\"><mat-icon\n          class=\"flex input justify-center align-middle items-center content-center text-lg\">{{control.icon}}</mat-icon></span>\n      }\n    </div>\n    @if (control.span) {\n    <span\n      [ngClass]=\"!form.get([control.name])?.errors || !form.get([control.name])?.touched ? 'text-gray-600 dark:text-gray-300' : '!text-red-500 dark:!text-red-800'\"\n      class=\"h-0 text-xs\">{{ control.span\n      }}</span>\n    }\n  </div>\n</ng-template>"]}
268
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chr-form.component.js","sourceRoot":"","sources":["../../../../../projects/chrv-components/src/lib/chr-form/chr-form.component.ts","../../../../../projects/chrv-components/src/lib/chr-form/chr-form.component.html"],"names":[],"mappings":"AAAA,OAAO,EACN,SAAS,EACT,KAAK,EACL,MAAM,EACN,YAAY,EAEZ,uBAAuB,GAMvB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAe,mBAAmB,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC/E,OAAO,EAGN,UAAU,EACV,WAAW,GACX,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,QAAQ,EAAE,MAAM,8BAA8B,CAAC;AACxD,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAE,wBAAwB,EAAE,MAAM,kDAAkD,CAAC;AAC5F,OAAO,EAAE,oBAAoB,EAAE,MAAM,gCAAgC,CAAC;AACtE,OAAO,EACN,QAAQ,EACR,YAAY,EACZ,yBAAyB,GACzB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,qBAAqB,EAAE,MAAM,gCAAgC,CAAC;AACvE,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EACN,IAAI,EACJ,sBAAsB,GACtB,MAAM,yCAAyC,CAAC;AACjD,OAAO,EAAE,OAAO,EAAE,MAAM,4CAA4C,CAAC;AACrE,OAAO,EAAE,OAAO,EAAE,MAAM,6CAA6C,CAAC;;;;;;;AAsFtE,MAAM,OAAO,gBAAgB;IA8B5B,YACS,OAAoB,EACpB,QAAkB,EAClB,cAAiC;QAFjC,YAAO,GAAP,OAAO,CAAa;QACpB,aAAQ,GAAR,QAAQ,CAAU;QAClB,mBAAc,GAAd,cAAc,CAAmB;QA5BhC,gBAAW,GAA0B,IAAI,YAAY,EAAW,CAAC;QAElE,UAAK,GAAQ,IAAI,CAAC;QACjB,gBAAW,GAAsB,IAAI,YAAY,EAAO,CAAC;QAGzD,iBAAY,GAAsB,IAAI,YAAY,EAAE,CAAC;QAItD,YAAO,GAAY,KAAK,CAAC;QAExB,eAAU,GACnB,IAAI,YAAY,EAAgB,CAAC;QAEzB,eAAU,GAAY,KAAK,CAAC;QAErC,SAAI,GAAc,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAEjC,WAAM,GAA2B,EAAE,CAAC;QACpC,iBAAY,GAA8B,EAAE,CAAC;QAC7C,sBAAiB,GAAe,EAAE,CAAC;QAEpC,gBAAW,GAAY,KAAK,CAAC;QA0B5B,cAAS,GAAG,GAAG,EAAE;YACxB,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI;gBAAE,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;YAExC,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;gBAC9C,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC;oBAAE,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,KAAK,CAAC;YACzE,CAAC;QACF,CAAC,CAAC;QAEM,eAAU,GAAG,GAAG,EAAE;YACzB,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;gBAC9C,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC;oBAC7B,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,YAAY,CAC5C,OAAO,EACP,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CACxB,CAAC;YACJ,CAAC;QACF,CAAC,CAAC;QAEM,iBAAY,GAAG,GAAG,EAAE;YAC3B,MAAM,YAAY,GAAG,EAA4B,CAAC;YAClD,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;gBAC9C,MAAM,UAAU,GAAG,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;gBAC5D,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,WAAW,CAC3C,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,EACzB,UAAU,CACV,CAAC;gBACF,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;YAChD,CAAC;YAED,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;YAC7C,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;QAC9B,CAAC,CAAC;QAEM,kBAAa,GAAG,GAAG,EAAE;YAC5B,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;gBAC3C,KAAK,MAAM,GAAG,IAAI,MAAM,EAAE,CAAC;oBAC1B,IAAI,MAAM,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,CAAC;wBAChC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC;wBAC9B,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC;oBAChC,CAAC;gBACF,CAAC;gBACD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;gBAC7B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAClC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAClC,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;YACrC,CAAC,CAAC,CAAC;QACJ,CAAC,CAAC;QAEF,UAAK,GAAG,CAAC,KAAc,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QAEjD,aAAQ,GAAG,CAAC,KAAc,EAAE,EAAE;YAC7B,IAAI,KAAK;gBAAE,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,KAAK,CAAC;YACnD,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;QACxB,CAAC,CAAC;QAEF,YAAO,GAAG,CAAC,KAAc,EAAE,EAAE;YAC5B,IAAI,KAAK;gBAAE,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,KAAK,CAAC;YAC9C,OAAO,IAAI,CAAC,KAAK,CAAC;QACnB,CAAC,CAAC;QAEF,sBAAiB,GAAG,CAAC,OAAiB,EAAE,EAAE;YACzC,OAAO,OAAO,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,UAAU,CAAC,CAAC;QAC7E,CAAC,CAAC;QAEF,eAAU,GAAG,CAAC,GAAW,EAAE,KAAU,EAAE,aAA4B,IAAI,EAAE,EAAE;YAC1E,IAAI,UAAU,IAAI,IAAI;gBAAE,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;;gBAC7C,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC,CAAC;YACpE,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,sBAAsB,EAAE,CAAC;YAC7C,IAAI,CAAC,aAAa,EAAE,CAAC;QACtB,CAAC,CAAC;QAEF,UAAK,GAAG,CAAC,KAAU,EAAE,aAA4B,IAAI,EAAE,EAAE;YACxD,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;gBACtC,IAAI,CAAC,UAAU,CAAC,GAAG,EAAE,KAAK,CAAC,GAAG,CAAC,EAAE,UAAU,CAAC,CAAC;YAC9C,CAAC;YACD,IAAI,CAAC,aAAa,EAAE,CAAC;QACtB,CAAC,CAAC;QAEF,kBAAa,GAAG,GAAG,EAAE;YACpB,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;gBAC9C,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,sBAAsB,EAAE,CAAC;YACvD,CAAC;YACD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;YAC7B,IAAI,CAAC,aAAa,EAAE,CAAC;QACtB,CAAC,CAAC;QAEF,2BAAsB,GAAG,GAAG,EAAE;YAC7B,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACxB,IAAI,CAAC,IAAI,CAAC,sBAAsB,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QACvD,CAAC,CAAC;QAEM,aAAQ,GAAG,CAAC,GAAW,EAAE,KAAU,EAAE,EAAE;YAC9C,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,UAAU,CAAC,KAAK,CAAC,CAAC;YACtC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;QAC1B,CAAC,CAAC;QAEM,iBAAY,GAAG,CAAC,OAAiB,EAAE,QAAoB,IAAI,EAAE,EAAE;YACtE,QAAQ,OAAO,CAAC,IAAI,EAAE,CAAC;gBACtB,KAAK,MAAM;oBACV,OAAO,KAAK;wBACX,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,YAAY,CAAC;wBACzC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,KAAK,EAAE,YAAY,CAAC,CAAC;gBACpD,KAAK,UAAU;oBACd,OAAO,KAAK;wBACX,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,kBAAkB,CAAC;wBAC/C,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,KAAK,EAAE,kBAAkB,CAAC,CAAC;gBAC1D;oBACC,OAAO,KAAK,IAAI,OAAO,CAAC,KAAK,CAAC;YAChC,CAAC;QACF,CAAC,CAAC;QAEM,kBAAa,GAAG,CAAC,KAAU,EAAE,MAAc,EAAE,EAAE;YACtD,OAAO,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;QAC/C,CAAC,CAAC;QAEK,WAAM,GAAG,CAAC,QAA6B,EAAE,EAAE;YACjD,MAAM,aAAa,GAAG,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC;YAC5C,QAAQ,CAAC,KAAK,CAAC,MAAM,GAAG,aAAa,CAAC;YACtC,QAAQ,CAAC,KAAK,CAAC,MAAM,GAAG,EAAE,GAAG,QAAQ,CAAC,YAAY,GAAG,IAAI,CAAC;QAC3D,CAAC,CAAC;QAEK,aAAQ,GAAG,GAAG,EAAE;YACtB,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC7B,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK;gBAAE,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACnE,CAAC,CAAC;QAEM,kBAAa,GAAG,GAAG,EAAE;YAC5B,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACxB,IAAI,CAAC,IAAI,CAAC,sBAAsB,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;YACtD,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;QACrC,CAAC,CAAC;QAEM,mBAAc,GAAG,CAAC,WAAkC,EAAE,EAAE;YAC/D,MAAM,UAAU,GAAkB,EAAE,CAAC;YACrC,IAAI,CAAC,WAAW;gBAAE,OAAO,UAAU,CAAC;YACpC,6DAA6D;YAC7D,KAAK,MAAM,UAAU,IAAI,WAAW,EAAE,CAAC;gBACtC,MAAM,IAAI,GAAG,UAAU,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC;gBACjD,IAAI,IAAI,IAAI,KAAK,EAAE,CAAC;oBACnB,UAAU,CAAC,OAAO,GAAG,gCAAgC,CAAC;oBACtD,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC;gBACnD,CAAC;gBACD,IAAI,IAAI,IAAI,KAAK,EAAE,CAAC;oBACnB,UAAU,CAAC,OAAO,GAAG,gCAAgC,CAAC;oBACtD,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC;gBACnD,CAAC;gBACD,IAAI,IAAI,IAAI,UAAU,EAAE,CAAC;oBACxB,UAAU,CAAC,OAAO,GAAG,wBAAwB,CAAC;oBAC9C,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;gBACtC,CAAC;gBACD,IAAI,IAAI,IAAI,OAAO,EAAE,CAAC;oBACrB,UAAU,CAAC,OAAO,GAAG,wCAAwC,CAAC;oBAC9D,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;gBACnC,CAAC;gBACD,IAAI,IAAI,IAAI,WAAW,EAAE,CAAC;oBACzB,UAAU,CAAC,OAAO,GAAG,gCAAgC,CAAC;oBACtD,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC;gBACzD,CAAC;gBACD,IAAI,IAAI,IAAI,WAAW,EAAE,CAAC;oBACzB,UAAU,CAAC,OAAO,GAAG,gCAAgC,CAAC;oBACtD,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC;gBACzD,CAAC;gBACD,IAAI,IAAI,IAAI,MAAM,EAAE,CAAC;oBACpB,UAAU,CAAC,OAAO,GAAG,iCAAiC,CAAC;oBACvD,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC;gBACzC,CAAC;gBACD,IAAI,IAAI,IAAI,SAAS,EAAE,CAAC;oBACvB,UAAU,CAAC,OAAO,GAAG,+CAA+C,UAAU,CAAC,KAAK,KAAK,CAAC;oBAC1F,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC;gBAC5C,CAAC;gBACD,IAAI,IAAI,IAAI,SAAS,EAAE,CAAC;oBACvB,UAAU,CAAC,OAAO,GAAG,sCAAsC,UAAU,CAAC,KAAK,KAAK,CAAC;oBACjF,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC;gBAC5C,CAAC;YACF,CAAC;YACD,OAAO,UAAU,CAAC;QACnB,CAAC,CAAC;QAnMD,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI;YACjD,MAAM,IAAI,KAAK,CACd,2DAA2D,CAC3D,CAAC;IACJ,CAAC;IAED,QAAQ;QACP,IAAI,CAAC,iBAAiB;YACrB,IAAI,CAAC,QAAQ;gBACZ,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC;iBACvB,IAAI,EAAE;iBACN,MAAM,CAAC,IAAI,CAAC,QAAQ,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC;QACrC,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IACzB,CAAC;8GApDW,gBAAgB;kGAAhB,gBAAgB,sWATjB;YACV,QAAQ;YACR;gBACC,OAAO,EAAE,yBAAyB;gBAClC,QAAQ,EAAE,EAAE,UAAU,EAAE,WAAW,EAAE;aACrC;SACD,0BCxHF,28WAgNc,6nqLD3GZ,mBAAmB,+xCACnB,WAAW,8BACX,gBAAgB,4TAChB,aAAa,mLACb,oBAAoB,+BACpB,QAAQ,kFACR,wBAAwB,uNACxB,qBAAqB,8BAErB,YAAY,uYAEZ,aAAa;;2FAWF,gBAAgB;kBAhC5B,SAAS;+BACC,cAAc,cAOZ,IAAI,WACP;wBACR,mBAAmB;wBACnB,WAAW;wBACX,gBAAgB;wBAChB,aAAa;wBACb,oBAAoB;wBACpB,QAAQ;wBACR,wBAAwB;wBACxB,qBAAqB;wBACrB,QAAQ;wBACR,YAAY;wBACZ,sBAAsB;wBACtB,aAAa;qBACb,aACU;wBACV,QAAQ;wBACR;4BACC,OAAO,EAAE,yBAAyB;4BAClC,QAAQ,EAAE,EAAE,UAAU,EAAE,WAAW,EAAE;yBACrC;qBACD,mBACgB,uBAAuB,CAAC,OAAO;uIAGvC,QAAQ;sBAAhB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBAEG,KAAK;sBAAb,KAAK;gBACI,WAAW;sBAApB,MAAM;gBAEE,KAAK;sBAAb,KAAK;gBACI,WAAW;sBAApB,MAAM;gBAEE,QAAQ;sBAAhB,KAAK;gBACI,YAAY;sBAArB,MAAM;gBAEE,MAAM;sBAAd,KAAK;gBAEG,OAAO;sBAAf,KAAK;gBAEI,UAAU;sBAAnB,MAAM;gBAGE,UAAU;sBAAlB,KAAK","sourcesContent":["import {\n\tComponent,\n\tInput,\n\tOutput,\n\tEventEmitter,\n\tAfterViewInit,\n\tChangeDetectionStrategy,\n\tViewEncapsulation,\n\tChangeDetectorRef,\n\tOnChanges,\n\tSimpleChanges,\n\tOnInit,\n} from \"@angular/core\";\nimport { ValidatorFn, ReactiveFormsModule, FormsModule } from \"@angular/forms\";\nimport {\n\tFormBuilder,\n\tFormGroup,\n\tValidators,\n\tFormControl,\n} from \"@angular/forms\";\nimport { MatError } from \"@angular/material/form-field\";\nimport { MatIconModule } from \"@angular/material/icon\";\nimport { MatTooltipModule } from \"@angular/material/tooltip\";\nimport { ChrSearchSelectComponent } from \"../chr-search-select/chr-search-select.component\";\nimport { MatSlideToggleModule } from \"@angular/material/slide-toggle\";\nimport {\n\tDatePipe,\n\tCommonModule,\n\tDATE_PIPE_DEFAULT_OPTIONS,\n} from \"@angular/common\";\nimport { MatAutocompleteModule } from \"@angular/material/autocomplete\";\nimport { MatTabsModule } from \"@angular/material/tabs\";\nimport {\n\ttype,\n\tTypeValidatorDirective,\n} from \"../models/chr-validators/type-validator\";\nimport { decimal } from \"../models/chr-validators/decimal-validator\";\nimport { maxDate } from \"../models/chr-validators/max-date-validator\";\n\nexport interface IFormControlCollection {\n\t[key: string]: FormControl;\n}\n\nexport interface ISearchFilter {\n\tdisplay: string;\n\tcallback?: Function;\n\ttooltip?: string;\n}\n\nexport interface IControlValidation {\n\trule: string;\n\tvalue?: any;\n\tdisplay?: string;\n}\n\nexport interface IControl {\n\tlabel?: string;\n\tname: string;\n\tspan?: string;\n\twidth?: \"col\" | \"row\";\n\tcol?: number;\n\trow?: number;\n\ttype:\n\t\t| \"text\"\n\t\t| \"password\"\n\t\t| \"textArea\"\n\t\t| \"number\"\n\t\t| \"date\"\n\t\t| \"datetime\"\n\t\t| \"searchSelect\"\n\t\t| \"color\"\n\t\t| \"toggle\";\n\tvalue?: any;\n\tdata?: any[] | null;\n\ticon?: string;\n\ticonCallback?: Function;\n\ticonCallbackDisabled?: boolean;\n\ticonTooltip?: string;\n\tfn?: (object: any) => string;\n\tfilters?: ISearchFilter[];\n\tvalidations?: IControlValidation[];\n}\n\nexport interface IFormSection {\n\ttitle?: string;\n\tcontrols: IControl[];\n}\n\nexport interface IFormControl {\n\t[key: string]: any;\n}\n@Component({\n\tselector: \"app-chr-form\",\n\ttemplateUrl: \"./chr-form.component.html\",\n\tstyleUrls: [\n\t\t\"./chr-form.component.scss\",\n\t\t\"../../../../../tailwindbuild.css\",\n\t\t\"./chr-form.component.scss\",\n\t],\n\tstandalone: true,\n\timports: [\n\t\tReactiveFormsModule,\n\t\tFormsModule,\n\t\tMatTooltipModule,\n\t\tMatIconModule,\n\t\tMatSlideToggleModule,\n\t\tMatError,\n\t\tChrSearchSelectComponent,\n\t\tMatAutocompleteModule,\n\t\tDatePipe,\n\t\tCommonModule,\n\t\tTypeValidatorDirective,\n\t\tMatTabsModule,\n\t],\n\tproviders: [\n\t\tDatePipe,\n\t\t{\n\t\t\tprovide: DATE_PIPE_DEFAULT_OPTIONS,\n\t\t\tuseValue: { dateFormat: \"shortDate\" },\n\t\t},\n\t],\n\tchangeDetection: ChangeDetectionStrategy.Default,\n})\nexport class ChrFormComponent implements OnInit {\n\t@Input() sections?: IFormSection[];\n\t@Input() controls?: IControl[];\n\n\t@Input() valid?: boolean;\n\t@Output() validChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n\t@Input() model: any = null;\n\t@Output() modelChange: EventEmitter<any> = new EventEmitter<any>();\n\n\t@Input() disabled?: boolean;\n\t@Output() valuesChange: EventEmitter<any> = new EventEmitter();\n\n\t@Input() submit?: Function;\n\n\t@Input() compact: boolean = false;\n\n\t@Output() formChange: EventEmitter<IFormControl> =\n\t\tnew EventEmitter<IFormControl>();\n\n\t@Input() tabDisplay: boolean = false;\n\n\tform: FormGroup = this.builder.group({});\n\n\tprivate values: { [key: string]: any } = {};\n\tprivate controlTypes: { [key: string]: string } = {};\n\tprivate flattenedControls: IControl[] = [];\n\n\tpublic initialized: boolean = false;\n\n\tconstructor(\n\t\tprivate builder: FormBuilder,\n\t\tprivate datePipe: DatePipe,\n\t\tprivate changeDetector: ChangeDetectorRef\n\t) {\n\t\tif (this.controls != null && this.sections != null)\n\t\t\tthrow new Error(\n\t\t\t\t\"You can't use both controls and sections in the same form\"\n\t\t\t);\n\t}\n\n\tngOnInit(): void {\n\t\tthis.flattenedControls =\n\t\t\tthis.sections\n\t\t\t\t?.map((s) => s.controls)\n\t\t\t\t.flat()\n\t\t\t\t.concat(this.controls ?? []) || [];\n\t\tthis.initModel();\n\t\tthis.initValues();\n\t\tthis.initControls();\n\t\tthis.initListeners();\n\t\tthis.initialized = true;\n\t}\n\n\tprivate initModel = () => {\n\t\tif (this.model == null) this.model = {};\n\n\t\tfor (const control of this.flattenedControls) {\n\t\t\tif (!this.model[control.name]) this.model[control.name] = control.value;\n\t\t}\n\t};\n\n\tprivate initValues = () => {\n\t\tfor (const control of this.flattenedControls) {\n\t\t\tif (!this.values[control.name])\n\t\t\t\tthis.values[control.name] = this.toInputValue(\n\t\t\t\t\tcontrol,\n\t\t\t\t\tthis.model[control.name]\n\t\t\t\t);\n\t\t}\n\t};\n\n\tprivate initControls = () => {\n\t\tconst formControls = {} as IFormControlCollection;\n\t\tfor (const control of this.flattenedControls) {\n\t\t\tconst validators = this._getValidators(control.validations);\n\t\t\tformControls[control.name] = new FormControl(\n\t\t\t\tthis.values[control.name],\n\t\t\t\tvalidators\n\t\t\t);\n\t\t\tthis.controlTypes[control.name] = control.type;\n\t\t}\n\n\t\tthis.form = this.builder.group(formControls);\n\t\tthis.valid = this.form.valid;\n\t};\n\n\tprivate initListeners = () => {\n\t\tthis.form.valueChanges.subscribe((values) => {\n\t\t\tfor (const key in values) {\n\t\t\t\tif (values.hasOwnProperty(key)) {\n\t\t\t\t\tthis.model[key] = values[key];\n\t\t\t\t\tthis.values[key] = values[key];\n\t\t\t\t}\n\t\t\t}\n\t\t\tthis.valid = this.form.valid;\n\t\t\tthis.validChange.emit(this.valid);\n\t\t\tthis.modelChange.emit(this.model);\n\t\t\tthis.changeDetector.detectChanges();\n\t\t});\n\t};\n\n\tvalue = (input?: string) => this.getValue(input);\n\n\tgetValue = (input?: string) => {\n\t\tif (input) return this.form.controls[input]?.value;\n\t\treturn this.form.value;\n\t};\n\n\tisValid = (input?: string) => {\n\t\tif (input) return this.form.get(input)?.valid;\n\t\treturn this.valid;\n\t};\n\n\tisControlRequired = (control: IControl) => {\n\t\treturn control.validations?.find((v) => v.rule.toLowerCase() == \"required\");\n\t};\n\n\tpatchValue = (key: string, value: any, dateFormat: string | null = null) => {\n\t\tif (dateFormat == null) this.setValue(key, value);\n\t\telse this.setValue(key, this.datePipe.transform(value, dateFormat));\n\t\tthis.form.get(key)?.updateValueAndValidity();\n\t\tthis.detectChanges();\n\t};\n\n\tpatch = (model: any, dateFormat: string | null = null) => {\n\t\tfor (const key of Object.keys(model)) {\n\t\t\tthis.patchValue(key, model[key], dateFormat);\n\t\t}\n\t\tthis.detectChanges();\n\t};\n\n\tcheckValidity = () => {\n\t\tfor (const control of this.flattenedControls) {\n\t\t\tthis.form.get(control.name)?.updateValueAndValidity();\n\t\t}\n\t\tthis.valid = this.form.valid;\n\t\tthis.detectChanges();\n\t};\n\n\tupdateValueAndValidity = () => {\n\t\tthis.form.markAsDirty();\n\t\tthis.form.updateValueAndValidity({ emitEvent: true });\n\t};\n\n\tprivate setValue = (key: string, value: any) => {\n\t\tthis.form.get(key)?.patchValue(value);\n\t\tthis.values[key] = value;\n\t};\n\n\tprivate toInputValue = (control: IControl, value: any | null = null) => {\n\t\tswitch (control.type) {\n\t\t\tcase \"date\":\n\t\t\t\treturn value\n\t\t\t\t\t? this.transformDate(value, \"yyyy-MM-dd\")\n\t\t\t\t\t: this.transformDate(control.value, \"yyyy-MM-dd\");\n\t\t\tcase \"datetime\":\n\t\t\t\treturn value\n\t\t\t\t\t? this.transformDate(value, \"yyyy-MM-ddTHH:mm\")\n\t\t\t\t\t: this.transformDate(control.value, \"yyyy-MM-ddTHH:mm\");\n\t\t\tdefault:\n\t\t\t\treturn value || control.value;\n\t\t}\n\t};\n\n\tprivate transformDate = (value: any, format: string) => {\n\t\treturn this.datePipe.transform(value, format);\n\t};\n\n\tpublic resize = (textArea: HTMLTextAreaElement) => {\n\t\tconst initialHeight = textArea.style.height;\n\t\ttextArea.style.height = initialHeight;\n\t\ttextArea.style.height = \"\" + textArea.scrollHeight + \"px\";\n\t};\n\n\tpublic doSubmit = () => {\n\t\tthis.form.markAllAsTouched();\n\t\tif (this.valid && this.form.valid) this.submit?.(this.form.value);\n\t};\n\n\tprivate detectChanges = () => {\n\t\tthis.form.markAsDirty();\n\t\tthis.form.updateValueAndValidity({ emitEvent: true });\n\t\tthis.changeDetector.detectChanges();\n\t};\n\n\tprivate _getValidators = (validations?: IControlValidation[]) => {\n\t\tconst validators: ValidatorFn[] = [];\n\t\tif (!validations) return validators;\n\t\t//Switch case breaks the mobile app so we'll do if statements\n\t\tfor (const validation of validations) {\n\t\t\tconst rule = validation.rule.toLocaleLowerCase();\n\t\t\tif (rule == \"min\") {\n\t\t\t\tvalidation.display = \"Cette valeur est trop petite !\";\n\t\t\t\tvalidators.push(Validators.min(validation.value));\n\t\t\t}\n\t\t\tif (rule == \"max\") {\n\t\t\t\tvalidation.display = \"Cette valeur est trop grande !\";\n\t\t\t\tvalidators.push(Validators.max(validation.value));\n\t\t\t}\n\t\t\tif (rule == \"required\") {\n\t\t\t\tvalidation.display = \"Ce champs est requis !\";\n\t\t\t\tvalidators.push(Validators.required);\n\t\t\t}\n\t\t\tif (rule == \"email\") {\n\t\t\t\tvalidation.display = \"Cette adresse email n'est pas valide !\";\n\t\t\t\tvalidators.push(Validators.email);\n\t\t\t}\n\t\t\tif (rule == \"minlength\") {\n\t\t\t\tvalidation.display = \"Cette valeur est trop petite !\";\n\t\t\t\tvalidators.push(Validators.minLength(validation.value));\n\t\t\t}\n\t\t\tif (rule == \"maxlength\") {\n\t\t\t\tvalidation.display = \"Cette valeur est trop grande !\";\n\t\t\t\tvalidators.push(Validators.maxLength(validation.value));\n\t\t\t}\n\t\t\tif (rule == \"type\") {\n\t\t\t\tvalidation.display = \"Cette valeur n'est pas valide !\";\n\t\t\t\tvalidators.push(type(validation.value));\n\t\t\t}\n\t\t\tif (rule == \"decimal\") {\n\t\t\t\tvalidation.display = `Le nombre de décimal n'est pas valide (max: ${validation.value}) !`;\n\t\t\t\tvalidators.push(decimal(validation.value));\n\t\t\t}\n\t\t\tif (rule == \"maxdate\") {\n\t\t\t\tvalidation.display = `Cette date est trop grande ! (max: ${validation.value}) !`;\n\t\t\t\tvalidators.push(maxDate(validation.value));\n\t\t\t}\n\t\t}\n\t\treturn validators;\n\t};\n}\n","<div class=\"flex flex-col justify-center min-h-5/6 mt-2\">\n  <form [formGroup]=\"form\" *ngIf=\"initialized\">\n    <ng-container *ngIf=\"!tabDisplay || !sections\" [ngTemplateOutlet]=\"singleTemplate\"\n      [ngTemplateOutletContext]=\"{controls: controls}\">\n    </ng-container>\n    <ng-container *ngIf=\"!tabDisplay && sections\" [ngTemplateOutlet]=\"sectionTemplate\"\n      [ngTemplateOutletContext]=\"{sections: sections}\">\n    </ng-container>\n    <ng-container *ngIf=\"tabDisplay && sections\" [ngTemplateOutlet]=\"tabsTemplate\"\n      [ngTemplateOutletContext]=\"{sects: sections}\">\n    </ng-container>\n  </form>\n</div>\n\n<ng-template #tabsTemplate let-sections='sects'>\n  <fieldset [disabled]=\"disabled\">\n    <mat-tab-group>\n      @for (section of sections; track section; let index = $index) {\n      <mat-tab [label]=\"section.title || 'Étape ' + (index + 1)\">\n        <div *ngIf=\"initialized\" class=\"mt-4\"\n          [ngClass]=\"compact ? 'grid gap-y-2 gap-x-6 sm:grid-cols-4':'grid gap-y-2 gap-x-6 sm:grid-cols-2'\">\n          @for (ctrl of section.controls; track index; let index = $index; let\n          last =\n          $last)\n          {\n          <ng-container [ngTemplateOutlet]=\"controlTemplate\"\n            [ngTemplateOutletContext]=\"{control: ctrl, index: index, last: $last}\">\n          </ng-container>\n          }\n        </div>\n      </mat-tab>\n      }\n    </mat-tab-group>\n  </fieldset>\n</ng-template>\n\n<ng-template #singleTemplate let-controls=\"controls\">\n  <fieldset [disabled]=\"disabled\">\n    <div *ngIf=\"initialized\"\n      [ngClass]=\"compact ? 'grid gap-y-2 gap-x-6 sm:grid-cols-4':'grid gap-y-2 gap-x-6 sm:grid-cols-2'\">\n      @for (control of controls; track control; let index = $index; let last = $last) {\n      <ng-container [ngTemplateOutlet]=\"controlTemplate\"\n        [ngTemplateOutletContext]=\"{control: control, index: index, last: last}\">\n      </ng-container>\n      }\n    </div>\n\n  </fieldset>\n</ng-template>\n\n<ng-template #sectionTemplate let-sections='sections'>\n  <fieldset [disabled]=\"disabled\">\n    @for (section of sections; track section; let index = $index) {\n    <div>\n      @if (section.title) {\n      <h2 class=\"mb-2 font-bold text-xl text-gray-900 dark:text-white\">\n        {{ section.title }}\n      </h2>\n      }\n      <div *ngIf=\"initialized\"\n        [ngClass]=\"compact ? 'grid gap-y-2 gap-x-6 sm:grid-cols-4':'grid gap-y-2 gap-x-6 sm:grid-cols-2'\">\n        @for (control of section.controls; track index; let index = $index; let\n        last =\n        $last)\n        {\n        <ng-container [ngTemplateOutlet]=\"controlTemplate\"\n          [ngTemplateOutletContext]=\"{control: control, index: index, last: $last}\">\n        </ng-container>\n        }\n      </div>\n      @if (index != (sections||[]).length - 1 && !compact) {\n      <div class=\"py-4\">\n        <hr class=\"\" />\n      </div>\n      }\n    </div>\n    }\n  </fieldset>\n</ng-template>\n\n<ng-template #controlTemplate let-control='control' let-last='last' let-index='index'>\n  <div class=\"relative h-min mt-2\" [formGroup]=\"form\" [ngClass]=\"{\n    'sm:col-span-2': (control.width == 'row' && !compact) || control.type=='textArea' && compact && control.width != 'row',\n    'sm:col-span-4': control.width =='row' && compact,\n    }\">\n    @if (control.type=='searchSelect') {\n    <div app-chr-search-select class=\"relative input z-0 w-full\" id=\"{{ control.name }}_{{ index }}\"\n      [ngClass]=\"(form.get([control.name])?.touched && form.get([control.name])?.errors) ? 'error':'border-gray-300 dark:border-gray-600'\"\n      [data]=\"control.data || []\" [display]=\"control.fn!\" [name]=\"control.name\" placeholder=\" \"\n      [filters]=\"control.filters\" [formControlName]=\"control.name\" (keyup.enter)=\"last ? doSubmit() : ''\">\n      <label class=\"label absolute text-sm text-gray-500 dark:text-gray-400\" [for]=\"control.name\">{{\n        control.label\n        }}\n        @if (isControlRequired(control)) {\n        <span class=\"text-red-500\">*</span>\n        }\n        :\n        @for (validation of control.validations; track validation) {\n        @if (\n        form.get([control.name])?.touched &&\n        form.hasError(validation.rule.toLowerCase(), control.name)\n        ) {\n        <mat-error class=\"text-red-500 dark:text-red-800\">{{ validation.display }}</mat-error>\n        }\n        }\n      </label>\n    </div>\n    }\n    <div class=\"relative z-0 w-full group/inputs content\">\n      <!-- Here we will *ngIf each type of input cause it's the cleanest way I can imagine-->\n      <!--TEXT-->\n      @if (control.type == 'text') {\n      <input class=\"relative\"\n        [ngClass]=\"(form.get([control.name])?.touched && form.get([control.name])?.errors) ? 'error':'border-gray-300 dark:border-gray-600'\"\n        type=\"text\" id=\"{{ control.name }}_{{ index }}\" name=\"{{ control.name }}\" [formControlName]=\"control.name\"\n        placeholder=\" \" [value]=\"model?.[control.name] || control.value || ''\" (keyup.enter)=\"last ? doSubmit() : ''\"\n        class=\"block input py-2.5 px-0 w-full text-sm text-gray-900 dark:text-white bg-transparent border-0 border-b-2 appearance-none dark:focus:border-chrlblue focus:outline-none focus:ring-0 focus:border-chrdblue peer/inputs\" />\n      }\n      <!--PASSWORD-->\n      @if (control.type == 'password') {\n      <input class=\"relative\"\n        [ngClass]=\"(form.get([control.name])?.touched && form.get([control.name])?.errors) ? 'error':'border-gray-300 dark:border-gray-600'\"\n        type=\"password\" id=\"{{ control.name }}_{{ index }}\" name=\"{{ control.name }}\" [formControlName]=\"control.name\"\n        placeholder=\" \" (keyup.enter)=\"last ? doSubmit() : ''\"\n        class=\"block input py-2.5 px-0 w-full text-sm text-gray-900 dark:text-white bg-transparent border-0 border-b-2 appearance-none dark:border-gray-600 dark:focus:border-chrlblue focus:outline-none focus:ring-0 focus:border-chrdblue peer/inputs\" />\n      }\n      <!--TEXT AREA-->\n      @if (control.type == 'textArea') {\n      <textarea #textArea class=\"relative\"\n        [ngClass]=\"(form.get([control.name])?.touched && form.get([control.name])?.errors) ? 'error':'border-gray-300 dark:border-gray-600'\"\n        id=\"{{ control.name }}_{{ index }}\" name=\"{{ control.name }}\" [formControlName]=\"control.name\" placeholder=\" \"\n        (input)=\"resize(textArea)\" (keyup.enter)=\"last ? doSubmit() : ''\"\n        class=\"no-scrollbar input !resize-none height-normalized block py-2 px-0 w-full text-sm text-gray-900 dark:text-white bg-transparent border-0 border-b-2 appearance-none dark:border-gray-600 dark:focus:border-chrlblue focus:outline-none focus:ring-0 focus:border-chrdblue peer/inputs\"></textarea>\n      }\n      <!--NUMBER-->\n      @if (control.type == 'number') {\n      <input class=\"relative\"\n        [ngClass]=\"(form.get([control.name])?.touched && form.get([control.name])?.errors) ? 'error':'border-gray-300 dark:border-gray-600'\"\n        type=\"number\" id=\"{{ control.name }}_{{ index }}\" name=\"{{ control.name }}\" placeholder=\" \"\n        [formControlName]=\"control.name\" (keyup.enter)=\"last ? doSubmit() : ''\"\n        class=\"block input py-2.5 px-0 w-full text-sm text-gray-900 dark:text-white bg-transparent border-0 border-b-2 appearance-none dark:border-gray-600 dark:focus:border-chrlblue focus:outline-none focus:ring-0 focus:border-chrdblue peer/inputs\" />\n      }\n      <!--DATE-->\n      @if (control.type == 'date') {\n      <input class=\"relative\"\n        [ngClass]=\"(form.get([control.name])?.touched && form.get([control.name])?.errors) ? 'error':'border-gray-300 dark:border-gray-600'\"\n        type=\"date\" id=\"{{ control.name }}_{{ index }}\" name=\"{{ control.name }}\" [formControlName]=\"control.name\"\n        placeholder=\" \" (keyup.enter)=\"last ? doSubmit() : ''\"\n        class=\"block input py-2 px-0 w-full height-normalized text-sm text-gray-900 dark:text-white bg-transparent border-0 border-b-2 appearance-none dark:border-gray-600 dark:focus:border-chrlblue focus:outline-none focus:ring-0 focus:border-chrdblue peer/inputs\" />\n      }\n      @if (control.type == 'datetime') {\n      <input class=\"relative\"\n        [ngClass]=\"(form.get([control.name])?.touched && form.get([control.name])?.errors) ? 'error':'border-gray-300 dark:border-gray-600'\"\n        type=\"datetime-local\" id=\"{{ control.name }}_{{ index }}\" name=\"{{ control.name }}\"\n        [formControlName]=\"control.name\" placeholder=\" \" (keyup.enter)=\"last ? doSubmit() : ''\"\n        class=\"block input py-2 px-0 w-full height-normalized text-sm text-gray-900 dark:text-white bg-transparent border-0 border-b-2 appearance-none dark:border-gray-600 dark:focus:border-chrlblue focus:outline-none focus:ring-0 focus:border-chrdblue peer/inputs\" />\n      }\n      <!--COLOR-->\n      @if (control.type == 'color') {\n      <input class=\"relative\"\n        [ngClass]=\"(form.get([control.name])?.touched && form.get([control.name])?.errors) ? 'error':'border-gray-300 dark:border-gray-600'\"\n        type=\"color\" id=\"{{ control.name }}_{{ index }}\" name=\"{{ control.name }}\" [formControlName]=\"control.name\"\n        placeholder=\" \" (keyup.enter)=\"last ? doSubmit() : ''\" style=\"height: 42px;\"\n        class=\"block input py-1.5 m-0 px-0 w-full bg-transparent border-0 border-b-2 dark:focus:border-chrlblue focus:outline-none focus:ring-0 focus:border-chrdblue peer/inputs\" />\n      }\n      @if (control.type == 'toggle'){\n      <input #toggle type=\"checkbox\" class=\"hidden checkbox\" [formControlName]=\"control.name\" placeholder=\" \" />\n      <div\n        class=\"relative toggle-wrapper block input bg-transparent border-0 border-b-2 border-gray-300 dark:focus:border-chrlblue focus:outline-none focus:ring-0 focus:border-chrdblue peer/inputs\">\n        <div (click)=\"toggle?.click()\" class=\"relative block input toggle\">\n        </div>\n      </div>\n      }\n      @if (control.type != 'searchSelect') {\n      <label class=\"label absolute text-sm text-gray-500 dark:text-gray-400\" [for]=\"control.name\">{{\n        control.label\n        }}\n        @if(control.label && control.label != '' && control.label != ' '){\n        @if (isControlRequired(control)) {\n        <span class=\"text-red-500\">*</span>\n        }\n        :\n        }\n        @for (validation of control.validations; track validation) {\n        @if (\n        form.get([control.name])?.touched &&\n        form.hasError(validation.rule.toLowerCase(), control.name)\n        ) {\n        <mat-error class=\"text-red-500 dark:text-red-800\">{{ validation.display }}</mat-error>\n        }\n        }\n      </label>\n      }\n      @if (control.icon && !disabled) {\n      <span\n        [ngClass]=\"control.iconCallbackDisabled ? 'text-gray-400 dark:text-gray-500':'text-gray-900 dark:text-white'\"\n        class=\"absolute p-2.5 bottom-0 right-0\" [matTooltip]=\"control.iconTooltip || ''\" matTooltipPosition=\"above\"\n        (click)=\"!control.iconCallbackDisabled && control.iconCallback?.(form.get([control.name])?.value)\"><mat-icon\n          class=\"flex input justify-center align-middle items-center content-center text-lg\">{{control.icon}}</mat-icon></span>\n      }\n    </div>\n    @if (control.span) {\n    <span\n      [ngClass]=\"!form.get([control.name])?.errors || !form.get([control.name])?.touched ? 'text-gray-600 dark:text-gray-300' : '!text-red-500 dark:!text-red-800'\"\n      class=\"h-0 text-xs\">{{ control.span\n      }}</span>\n    }\n  </div>\n</ng-template>"]}
@@ -3,10 +3,12 @@ import { HttpResponse, } from "@angular/common/http";
3
3
  import { finalize, tap } from "rxjs";
4
4
  import { LiveUpdateService } from "../../services/live-update.service";
5
5
  import { XSRFHEADERNAME } from "../providers/xsrf-provider";
6
+ import { DataService } from "../../services/data.service";
6
7
  export const XsrfInterceptor = (req, next) => {
7
8
  const headerName = inject(XSRFHEADERNAME);
8
- const csrfToken = localStorage.getItem(headerName);
9
9
  const liveUpdateService = inject(LiveUpdateService);
10
+ const dataService = inject(DataService);
11
+ const csrfToken = dataService.getSync(headerName);
10
12
  const hasCsrfToken = csrfToken !== null && csrfToken !== undefined;
11
13
  const shouldIntercept = ["PUT", "POST", "DELETE"].includes(req.method);
12
14
  const isWebSocket = req.url.includes(liveUpdateService.getHubUrl());
@@ -15,23 +17,23 @@ export const XsrfInterceptor = (req, next) => {
15
17
  headers: req.headers.set(headerName, csrfToken),
16
18
  });
17
19
  liveUpdateService.initConnection().subscribe();
18
- return next(cloned).pipe(WaitAndStoreXsrfToken(headerName), finalize(() => liveUpdateService.closeConnection().subscribe()));
20
+ return next(cloned).pipe(WaitAndStoreXsrfToken(headerName, dataService), finalize(() => liveUpdateService.closeConnection().subscribe()));
19
21
  }
20
22
  else {
21
- return next(req).pipe(WaitAndStoreXsrfToken(headerName));
23
+ return next(req).pipe(WaitAndStoreXsrfToken(headerName, dataService));
22
24
  }
23
25
  };
24
- export const WaitAndStoreXsrfToken = (headername) => {
26
+ export const WaitAndStoreXsrfToken = (headername, dataService) => {
25
27
  return (source) => {
26
28
  return source.pipe(tap((event) => {
27
29
  if (event instanceof HttpResponse) {
28
30
  const xsrfToken = event.headers.get(headername);
29
31
  if (xsrfToken) {
30
- localStorage.setItem(headername, xsrfToken);
32
+ dataService.set(headername, xsrfToken);
31
33
  }
32
34
  }
33
35
  return event;
34
36
  }));
35
37
  };
36
38
  };
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiWHNyZkludGVyY2VwdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2hydi1jb21wb25lbnRzL3NyYy9saWIvY29uZmlnL2ludGVyY2VwdG9ycy9Yc3JmSW50ZXJjZXB0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN2QyxPQUFPLEVBSU4sWUFBWSxHQUNaLE1BQU0sc0JBQXNCLENBQUM7QUFDOUIsT0FBTyxFQUFFLFFBQVEsRUFBYyxHQUFHLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDakQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDdkUsT0FBTyxFQUFrQixjQUFjLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUU1RSxNQUFNLENBQUMsTUFBTSxlQUFlLEdBQXNCLENBQUMsR0FBRyxFQUFFLElBQUksRUFBRSxFQUFFO0lBQy9ELE1BQU0sVUFBVSxHQUFXLE1BQU0sQ0FBQyxjQUFjLENBQUMsQ0FBQztJQUVsRCxNQUFNLFNBQVMsR0FBRyxZQUFZLENBQUMsT0FBTyxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQ25ELE1BQU0saUJBQWlCLEdBQXNCLE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO0lBRXZFLE1BQU0sWUFBWSxHQUFHLFNBQVMsS0FBSyxJQUFJLElBQUksU0FBUyxLQUFLLFNBQVMsQ0FBQztJQUNuRSxNQUFNLGVBQWUsR0FBRyxDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUUsUUFBUSxDQUFDLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUN2RSxNQUFNLFdBQVcsR0FBRyxHQUFHLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxpQkFBaUIsQ0FBQyxTQUFTLEVBQUUsQ0FBQyxDQUFDO0lBRXBFLElBQUksWUFBWSxJQUFJLGVBQWUsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBQ3JELE1BQU0sTUFBTSxHQUFHLEdBQUcsQ0FBQyxLQUFLLENBQUM7WUFDeEIsT0FBTyxFQUFFLEdBQUcsQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLFVBQVUsRUFBRSxTQUFTLENBQUM7U0FDL0MsQ0FBQyxDQUFDO1FBRUgsaUJBQWlCLENBQUMsY0FBYyxFQUFFLENBQUMsU0FBUyxFQUFFLENBQUM7UUFDL0MsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsSUFBSSxDQUN2QixxQkFBcUIsQ0FBQyxVQUFVLENBQUMsRUFDakMsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLGlCQUFpQixDQUFDLGVBQWUsRUFBRSxDQUFDLFNBQVMsRUFBRSxDQUFDLENBQy9ELENBQUM7SUFDSCxDQUFDO1NBQU0sQ0FBQztRQUNQLE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDO0lBQzFELENBQUM7QUFDRixDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxxQkFBcUIsR0FBRyxDQUFDLFVBQWtCLEVBQUUsRUFBRTtJQUMzRCxPQUFPLENBQUMsTUFBa0MsRUFBRSxFQUFFO1FBQzdDLE9BQU8sTUFBTSxDQUFDLElBQUksQ0FDakIsR0FBRyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUU7WUFDYixJQUFJLEtBQUssWUFBWSxZQUFZLEVBQUUsQ0FBQztnQkFDbkMsTUFBTSxTQUFTLEdBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLENBQUM7Z0JBQ2hELElBQUksU0FBUyxFQUFFLENBQUM7b0JBQ2YsWUFBWSxDQUFDLE9BQU8sQ0FBQyxVQUFVLEVBQUUsU0FBUyxDQUFDLENBQUM7Z0JBQzdDLENBQUM7WUFDRixDQUFDO1lBQ0QsT0FBTyxLQUFLLENBQUM7UUFDZCxDQUFDLENBQUMsQ0FDRixDQUFDO0lBQ0gsQ0FBQyxDQUFDO0FBQ0gsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaW5qZWN0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHtcclxuXHRIdHRwQ29udGV4dFRva2VuLFxyXG5cdEh0dHBFdmVudCxcclxuXHRIdHRwSW50ZXJjZXB0b3JGbixcclxuXHRIdHRwUmVzcG9uc2UsXHJcbn0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vbi9odHRwXCI7XHJcbmltcG9ydCB7IGZpbmFsaXplLCBPYnNlcnZhYmxlLCB0YXAgfSBmcm9tIFwicnhqc1wiO1xyXG5pbXBvcnQgeyBMaXZlVXBkYXRlU2VydmljZSB9IGZyb20gXCIuLi8uLi9zZXJ2aWNlcy9saXZlLXVwZGF0ZS5zZXJ2aWNlXCI7XHJcbmltcG9ydCB7IFhTUkZDT09LSUVOQU1FLCBYU1JGSEVBREVSTkFNRSB9IGZyb20gXCIuLi9wcm92aWRlcnMveHNyZi1wcm92aWRlclwiO1xyXG5cclxuZXhwb3J0IGNvbnN0IFhzcmZJbnRlcmNlcHRvcjogSHR0cEludGVyY2VwdG9yRm4gPSAocmVxLCBuZXh0KSA9PiB7XHJcblx0Y29uc3QgaGVhZGVyTmFtZTogc3RyaW5nID0gaW5qZWN0KFhTUkZIRUFERVJOQU1FKTtcclxuXHJcblx0Y29uc3QgY3NyZlRva2VuID0gbG9jYWxTdG9yYWdlLmdldEl0ZW0oaGVhZGVyTmFtZSk7XHJcblx0Y29uc3QgbGl2ZVVwZGF0ZVNlcnZpY2U6IExpdmVVcGRhdGVTZXJ2aWNlID0gaW5qZWN0KExpdmVVcGRhdGVTZXJ2aWNlKTtcclxuXHJcblx0Y29uc3QgaGFzQ3NyZlRva2VuID0gY3NyZlRva2VuICE9PSBudWxsICYmIGNzcmZUb2tlbiAhPT0gdW5kZWZpbmVkO1xyXG5cdGNvbnN0IHNob3VsZEludGVyY2VwdCA9IFtcIlBVVFwiLCBcIlBPU1RcIiwgXCJERUxFVEVcIl0uaW5jbHVkZXMocmVxLm1ldGhvZCk7XHJcblx0Y29uc3QgaXNXZWJTb2NrZXQgPSByZXEudXJsLmluY2x1ZGVzKGxpdmVVcGRhdGVTZXJ2aWNlLmdldEh1YlVybCgpKTtcclxuXHJcblx0aWYgKGhhc0NzcmZUb2tlbiAmJiBzaG91bGRJbnRlcmNlcHQgJiYgIWlzV2ViU29ja2V0KSB7XHJcblx0XHRjb25zdCBjbG9uZWQgPSByZXEuY2xvbmUoe1xyXG5cdFx0XHRoZWFkZXJzOiByZXEuaGVhZGVycy5zZXQoaGVhZGVyTmFtZSwgY3NyZlRva2VuKSxcclxuXHRcdH0pO1xyXG5cclxuXHRcdGxpdmVVcGRhdGVTZXJ2aWNlLmluaXRDb25uZWN0aW9uKCkuc3Vic2NyaWJlKCk7XHJcblx0XHRyZXR1cm4gbmV4dChjbG9uZWQpLnBpcGUoXHJcblx0XHRcdFdhaXRBbmRTdG9yZVhzcmZUb2tlbihoZWFkZXJOYW1lKSxcclxuXHRcdFx0ZmluYWxpemUoKCkgPT4gbGl2ZVVwZGF0ZVNlcnZpY2UuY2xvc2VDb25uZWN0aW9uKCkuc3Vic2NyaWJlKCkpXHJcblx0XHQpO1xyXG5cdH0gZWxzZSB7XHJcblx0XHRyZXR1cm4gbmV4dChyZXEpLnBpcGUoV2FpdEFuZFN0b3JlWHNyZlRva2VuKGhlYWRlck5hbWUpKTtcclxuXHR9XHJcbn07XHJcblxyXG5leHBvcnQgY29uc3QgV2FpdEFuZFN0b3JlWHNyZlRva2VuID0gKGhlYWRlcm5hbWU6IHN0cmluZykgPT4ge1xyXG5cdHJldHVybiAoc291cmNlOiBPYnNlcnZhYmxlPEh0dHBFdmVudDxhbnk+PikgPT4ge1xyXG5cdFx0cmV0dXJuIHNvdXJjZS5waXBlKFxyXG5cdFx0XHR0YXAoKGV2ZW50KSA9PiB7XHJcblx0XHRcdFx0aWYgKGV2ZW50IGluc3RhbmNlb2YgSHR0cFJlc3BvbnNlKSB7XHJcblx0XHRcdFx0XHRjb25zdCB4c3JmVG9rZW4gPSBldmVudC5oZWFkZXJzLmdldChoZWFkZXJuYW1lKTtcclxuXHRcdFx0XHRcdGlmICh4c3JmVG9rZW4pIHtcclxuXHRcdFx0XHRcdFx0bG9jYWxTdG9yYWdlLnNldEl0ZW0oaGVhZGVybmFtZSwgeHNyZlRva2VuKTtcclxuXHRcdFx0XHRcdH1cclxuXHRcdFx0XHR9XHJcblx0XHRcdFx0cmV0dXJuIGV2ZW50O1xyXG5cdFx0XHR9KVxyXG5cdFx0KTtcclxuXHR9O1xyXG59O1xyXG4iXX0=
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiWHNyZkludGVyY2VwdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2hydi1jb21wb25lbnRzL3NyYy9saWIvY29uZmlnL2ludGVyY2VwdG9ycy9Yc3JmSW50ZXJjZXB0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN2QyxPQUFPLEVBSU4sWUFBWSxHQUNaLE1BQU0sc0JBQXNCLENBQUM7QUFDOUIsT0FBTyxFQUFFLFFBQVEsRUFBYyxHQUFHLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDakQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDdkUsT0FBTyxFQUFrQixjQUFjLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUM1RSxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFFMUQsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUFzQixDQUFDLEdBQUcsRUFBRSxJQUFJLEVBQUUsRUFBRTtJQUMvRCxNQUFNLFVBQVUsR0FBVyxNQUFNLENBQUMsY0FBYyxDQUFDLENBQUM7SUFFbEQsTUFBTSxpQkFBaUIsR0FBc0IsTUFBTSxDQUFDLGlCQUFpQixDQUFDLENBQUM7SUFDdkUsTUFBTSxXQUFXLEdBQWdCLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUVyRCxNQUFNLFNBQVMsR0FBRyxXQUFXLENBQUMsT0FBTyxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBRWxELE1BQU0sWUFBWSxHQUFHLFNBQVMsS0FBSyxJQUFJLElBQUksU0FBUyxLQUFLLFNBQVMsQ0FBQztJQUNuRSxNQUFNLGVBQWUsR0FBRyxDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUUsUUFBUSxDQUFDLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUN2RSxNQUFNLFdBQVcsR0FBRyxHQUFHLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxpQkFBaUIsQ0FBQyxTQUFTLEVBQUUsQ0FBQyxDQUFDO0lBRXBFLElBQUksWUFBWSxJQUFJLGVBQWUsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBQ3JELE1BQU0sTUFBTSxHQUFHLEdBQUcsQ0FBQyxLQUFLLENBQUM7WUFDeEIsT0FBTyxFQUFFLEdBQUcsQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLFVBQVUsRUFBRSxTQUFTLENBQUM7U0FDL0MsQ0FBQyxDQUFDO1FBRUgsaUJBQWlCLENBQUMsY0FBYyxFQUFFLENBQUMsU0FBUyxFQUFFLENBQUM7UUFDL0MsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsSUFBSSxDQUN2QixxQkFBcUIsQ0FBQyxVQUFVLEVBQUUsV0FBVyxDQUFDLEVBQzlDLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQyxlQUFlLEVBQUUsQ0FBQyxTQUFTLEVBQUUsQ0FBQyxDQUMvRCxDQUFDO0lBQ0gsQ0FBQztTQUFNLENBQUM7UUFDUCxPQUFPLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMscUJBQXFCLENBQUMsVUFBVSxFQUFFLFdBQVcsQ0FBQyxDQUFDLENBQUM7SUFDdkUsQ0FBQztBQUNGLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLHFCQUFxQixHQUFHLENBQ3BDLFVBQWtCLEVBQ2xCLFdBQXdCLEVBQ3ZCLEVBQUU7SUFDSCxPQUFPLENBQUMsTUFBa0MsRUFBRSxFQUFFO1FBQzdDLE9BQU8sTUFBTSxDQUFDLElBQUksQ0FDakIsR0FBRyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUU7WUFDYixJQUFJLEtBQUssWUFBWSxZQUFZLEVBQUUsQ0FBQztnQkFDbkMsTUFBTSxTQUFTLEdBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLENBQUM7Z0JBQ2hELElBQUksU0FBUyxFQUFFLENBQUM7b0JBQ2YsV0FBVyxDQUFDLEdBQUcsQ0FBQyxVQUFVLEVBQUUsU0FBUyxDQUFDLENBQUM7Z0JBQ3hDLENBQUM7WUFDRixDQUFDO1lBQ0QsT0FBTyxLQUFLLENBQUM7UUFDZCxDQUFDLENBQUMsQ0FDRixDQUFDO0lBQ0gsQ0FBQyxDQUFDO0FBQ0gsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaW5qZWN0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHtcclxuXHRIdHRwQ29udGV4dFRva2VuLFxyXG5cdEh0dHBFdmVudCxcclxuXHRIdHRwSW50ZXJjZXB0b3JGbixcclxuXHRIdHRwUmVzcG9uc2UsXHJcbn0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vbi9odHRwXCI7XHJcbmltcG9ydCB7IGZpbmFsaXplLCBPYnNlcnZhYmxlLCB0YXAgfSBmcm9tIFwicnhqc1wiO1xyXG5pbXBvcnQgeyBMaXZlVXBkYXRlU2VydmljZSB9IGZyb20gXCIuLi8uLi9zZXJ2aWNlcy9saXZlLXVwZGF0ZS5zZXJ2aWNlXCI7XHJcbmltcG9ydCB7IFhTUkZDT09LSUVOQU1FLCBYU1JGSEVBREVSTkFNRSB9IGZyb20gXCIuLi9wcm92aWRlcnMveHNyZi1wcm92aWRlclwiO1xyXG5pbXBvcnQgeyBEYXRhU2VydmljZSB9IGZyb20gXCIuLi8uLi9zZXJ2aWNlcy9kYXRhLnNlcnZpY2VcIjtcclxuXHJcbmV4cG9ydCBjb25zdCBYc3JmSW50ZXJjZXB0b3I6IEh0dHBJbnRlcmNlcHRvckZuID0gKHJlcSwgbmV4dCkgPT4ge1xyXG5cdGNvbnN0IGhlYWRlck5hbWU6IHN0cmluZyA9IGluamVjdChYU1JGSEVBREVSTkFNRSk7XHJcblxyXG5cdGNvbnN0IGxpdmVVcGRhdGVTZXJ2aWNlOiBMaXZlVXBkYXRlU2VydmljZSA9IGluamVjdChMaXZlVXBkYXRlU2VydmljZSk7XHJcblx0Y29uc3QgZGF0YVNlcnZpY2U6IERhdGFTZXJ2aWNlID0gaW5qZWN0KERhdGFTZXJ2aWNlKTtcclxuXHJcblx0Y29uc3QgY3NyZlRva2VuID0gZGF0YVNlcnZpY2UuZ2V0U3luYyhoZWFkZXJOYW1lKTtcclxuXHJcblx0Y29uc3QgaGFzQ3NyZlRva2VuID0gY3NyZlRva2VuICE9PSBudWxsICYmIGNzcmZUb2tlbiAhPT0gdW5kZWZpbmVkO1xyXG5cdGNvbnN0IHNob3VsZEludGVyY2VwdCA9IFtcIlBVVFwiLCBcIlBPU1RcIiwgXCJERUxFVEVcIl0uaW5jbHVkZXMocmVxLm1ldGhvZCk7XHJcblx0Y29uc3QgaXNXZWJTb2NrZXQgPSByZXEudXJsLmluY2x1ZGVzKGxpdmVVcGRhdGVTZXJ2aWNlLmdldEh1YlVybCgpKTtcclxuXHJcblx0aWYgKGhhc0NzcmZUb2tlbiAmJiBzaG91bGRJbnRlcmNlcHQgJiYgIWlzV2ViU29ja2V0KSB7XHJcblx0XHRjb25zdCBjbG9uZWQgPSByZXEuY2xvbmUoe1xyXG5cdFx0XHRoZWFkZXJzOiByZXEuaGVhZGVycy5zZXQoaGVhZGVyTmFtZSwgY3NyZlRva2VuKSxcclxuXHRcdH0pO1xyXG5cclxuXHRcdGxpdmVVcGRhdGVTZXJ2aWNlLmluaXRDb25uZWN0aW9uKCkuc3Vic2NyaWJlKCk7XHJcblx0XHRyZXR1cm4gbmV4dChjbG9uZWQpLnBpcGUoXHJcblx0XHRcdFdhaXRBbmRTdG9yZVhzcmZUb2tlbihoZWFkZXJOYW1lLCBkYXRhU2VydmljZSksXHJcblx0XHRcdGZpbmFsaXplKCgpID0+IGxpdmVVcGRhdGVTZXJ2aWNlLmNsb3NlQ29ubmVjdGlvbigpLnN1YnNjcmliZSgpKVxyXG5cdFx0KTtcclxuXHR9IGVsc2Uge1xyXG5cdFx0cmV0dXJuIG5leHQocmVxKS5waXBlKFdhaXRBbmRTdG9yZVhzcmZUb2tlbihoZWFkZXJOYW1lLCBkYXRhU2VydmljZSkpO1xyXG5cdH1cclxufTtcclxuXHJcbmV4cG9ydCBjb25zdCBXYWl0QW5kU3RvcmVYc3JmVG9rZW4gPSAoXHJcblx0aGVhZGVybmFtZTogc3RyaW5nLFxyXG5cdGRhdGFTZXJ2aWNlOiBEYXRhU2VydmljZVxyXG4pID0+IHtcclxuXHRyZXR1cm4gKHNvdXJjZTogT2JzZXJ2YWJsZTxIdHRwRXZlbnQ8YW55Pj4pID0+IHtcclxuXHRcdHJldHVybiBzb3VyY2UucGlwZShcclxuXHRcdFx0dGFwKChldmVudCkgPT4ge1xyXG5cdFx0XHRcdGlmIChldmVudCBpbnN0YW5jZW9mIEh0dHBSZXNwb25zZSkge1xyXG5cdFx0XHRcdFx0Y29uc3QgeHNyZlRva2VuID0gZXZlbnQuaGVhZGVycy5nZXQoaGVhZGVybmFtZSk7XHJcblx0XHRcdFx0XHRpZiAoeHNyZlRva2VuKSB7XHJcblx0XHRcdFx0XHRcdGRhdGFTZXJ2aWNlLnNldChoZWFkZXJuYW1lLCB4c3JmVG9rZW4pO1xyXG5cdFx0XHRcdFx0fVxyXG5cdFx0XHRcdH1cclxuXHRcdFx0XHRyZXR1cm4gZXZlbnQ7XHJcblx0XHRcdH0pXHJcblx0XHQpO1xyXG5cdH07XHJcbn07XHJcbiJdfQ==
@@ -4,12 +4,14 @@ import * as i0 from "@angular/core";
4
4
  export class DataService {
5
5
  constructor() {
6
6
  this.data = new Map();
7
+ this.syncData = {};
7
8
  this.set = (key, value) => {
8
9
  const data = this.data.get(key);
9
10
  if (!data)
10
11
  this.data.set(key, new BehaviorSubject(value));
11
12
  else
12
13
  data.next(value);
14
+ this.syncData[key] = value;
13
15
  };
14
16
  this.get = (key) => {
15
17
  const data = this.data.get(key);
@@ -17,6 +19,9 @@ export class DataService {
17
19
  this.data.set(key, new BehaviorSubject(null));
18
20
  return this.data.get(key);
19
21
  };
22
+ this.getSync = (key) => {
23
+ return this.syncData[key];
24
+ };
20
25
  this.clear = (key) => {
21
26
  return this.data.get(key)?.next(null);
22
27
  };
@@ -33,4 +38,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.6", ngImpor
33
38
  providedIn: "root",
34
39
  }]
35
40
  }], ctorParameters: () => [] });
36
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2hydi1jb21wb25lbnRzL3NyYy9saWIvc2VydmljZXMvZGF0YS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFnQyxlQUFlLEVBQUUsTUFBTSxNQUFNLENBQUM7O0FBS3JFLE1BQU0sT0FBTyxXQUFXO0lBRXZCO1FBRFEsU0FBSSxHQUFHLElBQUksR0FBRyxFQUFnQyxDQUFDO1FBR3ZELFFBQUcsR0FBRyxDQUFDLEdBQVcsRUFBRSxLQUFVLEVBQVEsRUFBRTtZQUN2QyxNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUNoQyxJQUFJLENBQUMsSUFBSTtnQkFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsSUFBSSxlQUFlLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQzs7Z0JBQ3JELElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDdkIsQ0FBQyxDQUFDO1FBRUYsUUFBRyxHQUFHLENBQUMsR0FBVyxFQUFtQixFQUFFO1lBQ3RDLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQ2hDLElBQUksQ0FBQyxJQUFJO2dCQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxJQUFJLGVBQWUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO1lBQ3pELE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFFLENBQUM7UUFDNUIsQ0FBQyxDQUFDO1FBRUYsVUFBSyxHQUFHLENBQUMsR0FBVyxFQUFRLEVBQUU7WUFDN0IsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDdkMsQ0FBQyxDQUFDO1FBRUYsV0FBTSxHQUFHLENBQUMsR0FBVyxFQUFXLEVBQUU7WUFDakMsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUM5QixDQUFDLENBQUM7SUFwQmEsQ0FBQzs4R0FGSixXQUFXO2tIQUFYLFdBQVcsY0FGWCxNQUFNOzsyRkFFTixXQUFXO2tCQUh2QixVQUFVO21CQUFDO29CQUNYLFVBQVUsRUFBRSxNQUFNO2lCQUNsQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBPYnNlcnZhYmxlLCBvZiwgdGFwLCBTdWJqZWN0LCBCZWhhdmlvclN1YmplY3QgfSBmcm9tIFwicnhqc1wiO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG5cdHByb3ZpZGVkSW46IFwicm9vdFwiLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRGF0YVNlcnZpY2Uge1xyXG5cdHByaXZhdGUgZGF0YSA9IG5ldyBNYXA8c3RyaW5nLCBCZWhhdmlvclN1YmplY3Q8YW55Pj4oKTtcclxuXHRjb25zdHJ1Y3RvcigpIHt9XHJcblxyXG5cdHNldCA9IChrZXk6IHN0cmluZywgdmFsdWU6IGFueSk6IHZvaWQgPT4ge1xyXG5cdFx0Y29uc3QgZGF0YSA9IHRoaXMuZGF0YS5nZXQoa2V5KTtcclxuXHRcdGlmICghZGF0YSkgdGhpcy5kYXRhLnNldChrZXksIG5ldyBCZWhhdmlvclN1YmplY3QodmFsdWUpKTtcclxuXHRcdGVsc2UgZGF0YS5uZXh0KHZhbHVlKTtcclxuXHR9O1xyXG5cclxuXHRnZXQgPSAoa2V5OiBzdHJpbmcpOiBPYnNlcnZhYmxlPGFueT4gPT4ge1xyXG5cdFx0Y29uc3QgZGF0YSA9IHRoaXMuZGF0YS5nZXQoa2V5KTtcclxuXHRcdGlmICghZGF0YSkgdGhpcy5kYXRhLnNldChrZXksIG5ldyBCZWhhdmlvclN1YmplY3QobnVsbCkpO1xyXG5cdFx0cmV0dXJuIHRoaXMuZGF0YS5nZXQoa2V5KSE7XHJcblx0fTtcclxuXHJcblx0Y2xlYXIgPSAoa2V5OiBzdHJpbmcpOiB2b2lkID0+IHtcclxuXHRcdHJldHVybiB0aGlzLmRhdGEuZ2V0KGtleSk/Lm5leHQobnVsbCk7XHJcblx0fTtcclxuXHJcblx0cmVtb3ZlID0gKGtleTogc3RyaW5nKTogYm9vbGVhbiA9PiB7XHJcblx0XHRyZXR1cm4gdGhpcy5kYXRhLmRlbGV0ZShrZXkpO1xyXG5cdH07XHJcbn1cclxuIl19
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2hydi1jb21wb25lbnRzL3NyYy9saWIvc2VydmljZXMvZGF0YS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFnQyxlQUFlLEVBQUUsTUFBTSxNQUFNLENBQUM7O0FBS3JFLE1BQU0sT0FBTyxXQUFXO0lBR3ZCO1FBRlEsU0FBSSxHQUFHLElBQUksR0FBRyxFQUFnQyxDQUFDO1FBQy9DLGFBQVEsR0FBMkIsRUFBRSxDQUFDO1FBRzlDLFFBQUcsR0FBRyxDQUFDLEdBQVcsRUFBRSxLQUFVLEVBQVEsRUFBRTtZQUN2QyxNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUNoQyxJQUFJLENBQUMsSUFBSTtnQkFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsSUFBSSxlQUFlLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQzs7Z0JBQ3JELElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7WUFFdEIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsR0FBRyxLQUFLLENBQUM7UUFDNUIsQ0FBQyxDQUFDO1FBRUYsUUFBRyxHQUFHLENBQUMsR0FBVyxFQUFtQixFQUFFO1lBQ3RDLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQ2hDLElBQUksQ0FBQyxJQUFJO2dCQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxJQUFJLGVBQWUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO1lBQ3pELE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFFLENBQUM7UUFDNUIsQ0FBQyxDQUFDO1FBRUYsWUFBTyxHQUFHLENBQUMsR0FBVyxFQUFPLEVBQUU7WUFDOUIsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQzNCLENBQUMsQ0FBQztRQUVGLFVBQUssR0FBRyxDQUFDLEdBQVcsRUFBUSxFQUFFO1lBQzdCLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3ZDLENBQUMsQ0FBQztRQUVGLFdBQU0sR0FBRyxDQUFDLEdBQVcsRUFBVyxFQUFFO1lBQ2pDLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDOUIsQ0FBQyxDQUFDO0lBMUJhLENBQUM7OEdBSEosV0FBVztrSEFBWCxXQUFXLGNBRlgsTUFBTTs7MkZBRU4sV0FBVztrQkFIdkIsVUFBVTttQkFBQztvQkFDWCxVQUFVLEVBQUUsTUFBTTtpQkFDbEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgb2YsIHRhcCwgU3ViamVjdCwgQmVoYXZpb3JTdWJqZWN0IH0gZnJvbSBcInJ4anNcIjtcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuXHRwcm92aWRlZEluOiBcInJvb3RcIixcclxufSlcclxuZXhwb3J0IGNsYXNzIERhdGFTZXJ2aWNlIHtcclxuXHRwcml2YXRlIGRhdGEgPSBuZXcgTWFwPHN0cmluZywgQmVoYXZpb3JTdWJqZWN0PGFueT4+KCk7XHJcblx0cHJpdmF0ZSBzeW5jRGF0YTogeyBba2V5OiBzdHJpbmddOiBhbnkgfSA9IHt9O1xyXG5cdGNvbnN0cnVjdG9yKCkge31cclxuXHJcblx0c2V0ID0gKGtleTogc3RyaW5nLCB2YWx1ZTogYW55KTogdm9pZCA9PiB7XHJcblx0XHRjb25zdCBkYXRhID0gdGhpcy5kYXRhLmdldChrZXkpO1xyXG5cdFx0aWYgKCFkYXRhKSB0aGlzLmRhdGEuc2V0KGtleSwgbmV3IEJlaGF2aW9yU3ViamVjdCh2YWx1ZSkpO1xyXG5cdFx0ZWxzZSBkYXRhLm5leHQodmFsdWUpO1xyXG5cclxuXHRcdHRoaXMuc3luY0RhdGFba2V5XSA9IHZhbHVlO1xyXG5cdH07XHJcblxyXG5cdGdldCA9IChrZXk6IHN0cmluZyk6IE9ic2VydmFibGU8YW55PiA9PiB7XHJcblx0XHRjb25zdCBkYXRhID0gdGhpcy5kYXRhLmdldChrZXkpO1xyXG5cdFx0aWYgKCFkYXRhKSB0aGlzLmRhdGEuc2V0KGtleSwgbmV3IEJlaGF2aW9yU3ViamVjdChudWxsKSk7XHJcblx0XHRyZXR1cm4gdGhpcy5kYXRhLmdldChrZXkpITtcclxuXHR9O1xyXG5cclxuXHRnZXRTeW5jID0gKGtleTogc3RyaW5nKTogYW55ID0+IHtcclxuXHRcdHJldHVybiB0aGlzLnN5bmNEYXRhW2tleV07XHJcblx0fTtcclxuXHJcblx0Y2xlYXIgPSAoa2V5OiBzdHJpbmcpOiB2b2lkID0+IHtcclxuXHRcdHJldHVybiB0aGlzLmRhdGEuZ2V0KGtleSk/Lm5leHQobnVsbCk7XHJcblx0fTtcclxuXHJcblx0cmVtb3ZlID0gKGtleTogc3RyaW5nKTogYm9vbGVhbiA9PiB7XHJcblx0XHRyZXR1cm4gdGhpcy5kYXRhLmRlbGV0ZShrZXkpO1xyXG5cdH07XHJcbn1cclxuIl19
@@ -716,10 +716,6 @@ class ChrFormComponent {
716
716
  this.values = {};
717
717
  this.controlTypes = {};
718
718
  this.flattenedControls = [];
719
- this.updateValueAndValidity = () => {
720
- this.form.markAsDirty();
721
- this.form.updateValueAndValidity({ emitEvent: true });
722
- };
723
719
  this.initialized = false;
724
720
  this.initModel = () => {
725
721
  if (this.model == null)
@@ -743,9 +739,9 @@ class ChrFormComponent {
743
739
  this.controlTypes[control.name] = control.type;
744
740
  }
745
741
  this.form = this.builder.group(formControls);
742
+ this.valid = this.form.valid;
746
743
  };
747
744
  this.initListeners = () => {
748
- // Listen for changes and update the model
749
745
  this.form.valueChanges.subscribe((values) => {
750
746
  for (const key in values) {
751
747
  if (values.hasOwnProperty(key)) {
@@ -778,6 +774,7 @@ class ChrFormComponent {
778
774
  this.setValue(key, value);
779
775
  else
780
776
  this.setValue(key, this.datePipe.transform(value, dateFormat));
777
+ this.form.get(key)?.updateValueAndValidity();
781
778
  this.detectChanges();
782
779
  };
783
780
  this.patch = (model, dateFormat = null) => {
@@ -786,6 +783,17 @@ class ChrFormComponent {
786
783
  }
787
784
  this.detectChanges();
788
785
  };
786
+ this.checkValidity = () => {
787
+ for (const control of this.flattenedControls) {
788
+ this.form.get(control.name)?.updateValueAndValidity();
789
+ }
790
+ this.valid = this.form.valid;
791
+ this.detectChanges();
792
+ };
793
+ this.updateValueAndValidity = () => {
794
+ this.form.markAsDirty();
795
+ this.form.updateValueAndValidity({ emitEvent: true });
796
+ };
789
797
  this.setValue = (key, value) => {
790
798
  this.form.get(key)?.patchValue(value);
791
799
  this.values[key] = value;
@@ -807,10 +815,6 @@ class ChrFormComponent {
807
815
  this.transformDate = (value, format) => {
808
816
  return this.datePipe.transform(value, format);
809
817
  };
810
- this.reset = () => {
811
- this.form.reset();
812
- this.detectChanges();
813
- };
814
818
  this.resize = (textArea) => {
815
819
  const initialHeight = textArea.style.height;
816
820
  textArea.style.height = initialHeight;
@@ -1358,10 +1362,49 @@ const SpinnerInterceptor = (req, next) => {
1358
1362
  }));
1359
1363
  };
1360
1364
 
1365
+ class DataService {
1366
+ constructor() {
1367
+ this.data = new Map();
1368
+ this.syncData = {};
1369
+ this.set = (key, value) => {
1370
+ const data = this.data.get(key);
1371
+ if (!data)
1372
+ this.data.set(key, new BehaviorSubject(value));
1373
+ else
1374
+ data.next(value);
1375
+ this.syncData[key] = value;
1376
+ };
1377
+ this.get = (key) => {
1378
+ const data = this.data.get(key);
1379
+ if (!data)
1380
+ this.data.set(key, new BehaviorSubject(null));
1381
+ return this.data.get(key);
1382
+ };
1383
+ this.getSync = (key) => {
1384
+ return this.syncData[key];
1385
+ };
1386
+ this.clear = (key) => {
1387
+ return this.data.get(key)?.next(null);
1388
+ };
1389
+ this.remove = (key) => {
1390
+ return this.data.delete(key);
1391
+ };
1392
+ }
1393
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: DataService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
1394
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: DataService, providedIn: "root" }); }
1395
+ }
1396
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: DataService, decorators: [{
1397
+ type: Injectable,
1398
+ args: [{
1399
+ providedIn: "root",
1400
+ }]
1401
+ }], ctorParameters: () => [] });
1402
+
1361
1403
  const XsrfInterceptor = (req, next) => {
1362
1404
  const headerName = inject(XSRFHEADERNAME);
1363
- const csrfToken = localStorage.getItem(headerName);
1364
1405
  const liveUpdateService = inject(LiveUpdateService);
1406
+ const dataService = inject(DataService);
1407
+ const csrfToken = dataService.getSync(headerName);
1365
1408
  const hasCsrfToken = csrfToken !== null && csrfToken !== undefined;
1366
1409
  const shouldIntercept = ["PUT", "POST", "DELETE"].includes(req.method);
1367
1410
  const isWebSocket = req.url.includes(liveUpdateService.getHubUrl());
@@ -1370,19 +1413,19 @@ const XsrfInterceptor = (req, next) => {
1370
1413
  headers: req.headers.set(headerName, csrfToken),
1371
1414
  });
1372
1415
  liveUpdateService.initConnection().subscribe();
1373
- return next(cloned).pipe(WaitAndStoreXsrfToken(headerName), finalize$1(() => liveUpdateService.closeConnection().subscribe()));
1416
+ return next(cloned).pipe(WaitAndStoreXsrfToken(headerName, dataService), finalize$1(() => liveUpdateService.closeConnection().subscribe()));
1374
1417
  }
1375
1418
  else {
1376
- return next(req).pipe(WaitAndStoreXsrfToken(headerName));
1419
+ return next(req).pipe(WaitAndStoreXsrfToken(headerName, dataService));
1377
1420
  }
1378
1421
  };
1379
- const WaitAndStoreXsrfToken = (headername) => {
1422
+ const WaitAndStoreXsrfToken = (headername, dataService) => {
1380
1423
  return (source) => {
1381
1424
  return source.pipe(tap((event) => {
1382
1425
  if (event instanceof HttpResponse) {
1383
1426
  const xsrfToken = event.headers.get(headername);
1384
1427
  if (xsrfToken) {
1385
- localStorage.setItem(headername, xsrfToken);
1428
+ dataService.set(headername, xsrfToken);
1386
1429
  }
1387
1430
  }
1388
1431
  return event;
@@ -1635,39 +1678,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.6", ngImpor
1635
1678
  }]
1636
1679
  }], ctorParameters: () => [{ type: i1$1.MatDialog }] });
1637
1680
 
1638
- class DataService {
1639
- constructor() {
1640
- this.data = new Map();
1641
- this.set = (key, value) => {
1642
- const data = this.data.get(key);
1643
- if (!data)
1644
- this.data.set(key, new BehaviorSubject(value));
1645
- else
1646
- data.next(value);
1647
- };
1648
- this.get = (key) => {
1649
- const data = this.data.get(key);
1650
- if (!data)
1651
- this.data.set(key, new BehaviorSubject(null));
1652
- return this.data.get(key);
1653
- };
1654
- this.clear = (key) => {
1655
- return this.data.get(key)?.next(null);
1656
- };
1657
- this.remove = (key) => {
1658
- return this.data.delete(key);
1659
- };
1660
- }
1661
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: DataService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
1662
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: DataService, providedIn: "root" }); }
1663
- }
1664
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.6", ngImport: i0, type: DataService, decorators: [{
1665
- type: Injectable,
1666
- args: [{
1667
- providedIn: "root",
1668
- }]
1669
- }], ctorParameters: () => [] });
1670
-
1671
1681
  /*
1672
1682
  * Public API Surface of chr-components
1673
1683
  */