@muraai/mnl-form 0.0.1-alpha-f274a13 → 0.0.1-alpha-53c07ff

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.
@@ -2,7 +2,7 @@ import { CommonModule } from '@angular/common';
2
2
  import { Component, EventEmitter, Input, Output } from '@angular/core';
3
3
  import { FormsModule, ReactiveFormsModule } from '@angular/forms';
4
4
  import { CommonsModule } from '@muraai/mnl-commons';
5
- import { FormlyModule, } from '@ngx-formly/core';
5
+ import { FormlyModule } from '@ngx-formly/core';
6
6
  import { FormlyMatCheckboxModule } from '@ngx-formly/material/checkbox';
7
7
  import { FormlyMatInputModule } from '@ngx-formly/material/input';
8
8
  import { FormlyMatTextAreaModule } from '@ngx-formly/material/textarea';
@@ -37,6 +37,7 @@ export class MnlFormLibComponent {
37
37
  ...this.options.formState,
38
38
  showOldValues: this.showOldValues,
39
39
  oldValues: this.oldValues,
40
+ helperModel: this.helperModel,
40
41
  },
41
42
  };
42
43
  }
@@ -142,7 +143,7 @@ export class MnlFormLibComponent {
142
143
  });
143
144
  }
144
145
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: MnlFormLibComponent, deps: [{ token: i1.TranslateService }, { token: i2.ScoringService }], target: i0.ɵɵFactoryTarget.Component }); }
145
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: MnlFormLibComponent, isStandalone: true, selector: "mnl-form", inputs: { readonly: "readonly", form: "form", fields: "fields", model: "model", options: "options", userRoles: "userRoles", userCountries: "userCountries", oldValues: "oldValues", showOldValues: "showOldValues" }, outputs: { noOfTabs: "noOfTabs", scoreChange: "scoreChange" }, ngImport: i0, template: "@if(formPrepared) {\n<formly-form\n [form]=\"form\"\n [fields]=\"fields\"\n [model]=\"model\"\n [options]=\"options\"\n (modelChange)=\"onModelChange($event)\"\n class=\"mnl-formly-form\"\n></formly-form>\n}\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: CommonsModule }, { kind: "ngmodule", type: FormlyModule }, { kind: "component", type: i3.FormlyForm, selector: "formly-form", inputs: ["form", "model", "fields", "options"], outputs: ["modelChange"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: TranslateModule }, { kind: "ngmodule", type: FormlyMatTextAreaModule }, { kind: "ngmodule", type: FormlyMatInputModule }, { kind: "ngmodule", type: FormlyMatCheckboxModule }, { kind: "ngmodule", type: FormlyMatRadioModule }] }); }
146
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: MnlFormLibComponent, isStandalone: true, selector: "mnl-form", inputs: { readonly: "readonly", form: "form", fields: "fields", model: "model", helperModel: "helperModel", options: "options", userRoles: "userRoles", userCountries: "userCountries", oldValues: "oldValues", showOldValues: "showOldValues" }, outputs: { noOfTabs: "noOfTabs", scoreChange: "scoreChange" }, ngImport: i0, template: "@if(formPrepared) {\n<formly-form\n [form]=\"form\"\n [fields]=\"fields\"\n [model]=\"model\"\n [options]=\"options\"\n (modelChange)=\"onModelChange($event)\"\n class=\"mnl-formly-form\"\n></formly-form>\n}\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: CommonsModule }, { kind: "ngmodule", type: FormlyModule }, { kind: "component", type: i3.FormlyForm, selector: "formly-form", inputs: ["form", "model", "fields", "options"], outputs: ["modelChange"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: TranslateModule }, { kind: "ngmodule", type: FormlyMatTextAreaModule }, { kind: "ngmodule", type: FormlyMatInputModule }, { kind: "ngmodule", type: FormlyMatCheckboxModule }, { kind: "ngmodule", type: FormlyMatRadioModule }] }); }
146
147
  }
147
148
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: MnlFormLibComponent, decorators: [{
148
149
  type: Component,
@@ -166,6 +167,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
166
167
  type: Input
167
168
  }], model: [{
168
169
  type: Input
170
+ }], helperModel: [{
171
+ type: Input
169
172
  }], options: [{
170
173
  type: Input
171
174
  }], userRoles: [{
@@ -181,4 +184,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
181
184
  }], scoreChange: [{
182
185
  type: Output
183
186
  }] } });
184
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly-lib.component.js","sourceRoot":"","sources":["../../../../../../projects/form-lib/src/lib/formly-lib/formly-lib.component.ts","../../../../../../projects/form-lib/src/lib/formly-lib/formly-lib.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { FormGroup, FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { CommonsModule } from '@muraai/mnl-commons';\nimport {\n  FormlyFormOptions,\n  FormlyModule,\n} from '@ngx-formly/core';\nimport { FormlyMatCheckboxModule } from '@ngx-formly/material/checkbox';\nimport { FormlyMatInputModule } from '@ngx-formly/material/input';\nimport { FormlyMatTextAreaModule } from '@ngx-formly/material/textarea';\nimport { TranslateModule, TranslateService } from '@ngx-translate/core';\nimport { of } from 'rxjs';\nimport { CustomFormlyFieldConfig } from '../models/custom-form-field.model';\nimport { FormlyMatRadioModule } from '@ngx-formly/material/radio';\nimport { ScoringService } from '../services/scoring.service';\n\n@Component({\n  selector: 'mnl-form',\n  standalone: true,\n  imports: [\n    CommonModule,\n    CommonsModule,\n    FormlyModule,\n    ReactiveFormsModule,\n    FormsModule,\n    TranslateModule,\n    FormlyMatTextAreaModule,\n    FormlyMatInputModule,\n    FormlyMatCheckboxModule,\n    FormlyMatRadioModule,\n  ],\n  templateUrl: './formly-lib.component.html',\n  styleUrl: './formly-lib.component.scss',\n})\nexport class MnlFormLibComponent implements OnInit {\n  @Input()\n  readonly = false;\n\n  @Input()\n  form!: FormGroup;\n\n  @Input()\n  fields!: CustomFormlyFieldConfig[];\n\n  @Input()\n  model: any;\n\n  @Input()\n  options!: FormlyFormOptions;\n\n  @Input()\n  userRoles!: string[];\n\n  @Input()\n  userCountries!: string[];\n\n  @Output()\n  noOfTabs = new EventEmitter();\n\n  @Input()\n  oldValues: any;\n\n  @Input()\n  showOldValues!: boolean;\n\n  @Output() \n  scoreChange = new EventEmitter<any>();\n\n  formPrepared = false;\n  totalTabs = 0;\n  constructor(\n    private translateService: TranslateService,\n    private scoring: ScoringService\n  ) {\n    this.translateService.setDefaultLang('en');\n  }\n  ngOnInit(): void {\n    if (this.fields) {\n      this.applyReadonlyToFields(this.fields);\n      this.filterFieldGroupsByRolesAndCountries(this.fields);\n      this.form.updateValueAndValidity();\n      this.formPrepared = true;\n      this.getNumberOfActiveTabs(this.fields);\n      this.setAutocompleteSingleOptionByDefault(this.fields);\n      this.options = {\n        formState: {\n          ...this.options.formState,\n          showOldValues: this.showOldValues,\n          oldValues: this.oldValues,\n        },\n      };\n    }\n  }\n\n  onModelChange(model: any) {\n    const result = this.scoring.updateScore(model, this.fields);\n    this.scoreChange.emit(result);\n  }\n\n  setAutocompleteSingleOptionByDefault(fields: any) {\n    fields.forEach((field: any) => {\n      if (field.type === 'mu-select-autocomplete') {\n        field.hooks = {\n          onInit: (field: any) => {\n            const formControl = field.formControl;\n            const options = field.props?.options || [];\n\n            if (Array.isArray(options)) {\n              this.setOptionByDefault(formControl, field, options);\n            } else {\n              (options || of([])).subscribe((options: any) => {\n                this.setOptionByDefault(formControl, field, options);\n              });\n            }\n          },\n        };\n      }\n      if (field.fieldGroup) {\n        this.setAutocompleteSingleOptionByDefault(field.fieldGroup);\n      }\n    });\n  }\n\n  setOptionByDefault(formControl: any, field: any, options: any) {\n    if (formControl && field.props && field.props.options) {\n      if (options.length === 1) {\n        formControl.setValue(options[0].value);\n      }\n\n      field.props.optionsChange?.subscribe((updatedOptions: any[]) => {\n        if (updatedOptions.length === 1 && formControl) {\n          formControl.setValue(updatedOptions[0].value);\n        }\n      });\n    }\n  }\n  getNumberOfActiveTabs(fields: any) {\n    fields.forEach((field: any) => {\n      if (field.type === 'mu-tabs') {\n        this.totalTabs = field.fieldGroup?.length || 0;\n        this.noOfTabs.emit(this.totalTabs);\n      }\n      if (field.fieldGroup) {\n        this.getNumberOfActiveTabs(field.fieldGroup);\n      }\n    });\n  }\n\n  applyReadonlyToFields(\n    fields: CustomFormlyFieldConfig[]\n  ): CustomFormlyFieldConfig[] {\n    return fields.map((field) => {\n      if (field.fieldGroup) {\n        this.applyReadonlyToFields(field.fieldGroup);\n      } else {\n        field.props = {\n          ...(field.props || {}),\n          readonly: this.readonly,\n        };\n      }\n      return field;\n    });\n  }\n\n  filterFieldGroupsByRolesAndCountries(fields: CustomFormlyFieldConfig[]) {\n    return fields\n      .map((field: any) => {\n        if (field.fieldGroup && !field.vissibleCountries) {\n          field.fieldGroup = this.filterFieldGroupsByRolesAndCountries(\n            field.fieldGroup\n          );\n        }\n        // const hasValidRole = field.vissibleRoles\n        //   ? field.vissibleRoles.some((role: any) => this.userRoles?.includes(role))\n        //   : true;\n        // const hasValidCountry = field.vissibleCountries\n        //   ? field.vissibleCountries.some((country: any) => this.userCountries?.includes(country))\n        //   : true;\n\n        const validGroup = field;\n        if (validGroup && field.fieldGroup) {\n          field.fieldGroup = this.filterFieldGroupsByRolesAndCountries(\n            field.fieldGroup\n          );\n        }\n        if (validGroup == null) {\n          this.removeValidationsForFilteredFields(field);\n        }\n        if (!validGroup && field.props?.required) {\n          field.props.required = false;\n        }\n        return validGroup;\n      })\n      .filter((field: any) => field !== null);\n  }\n\n  removeValidationsForFilteredFields(fields: any) {\n    fields?.fieldGroup?.forEach((field: any) => {\n      if (field.fieldGroup) {\n        this.removeValidationsForFilteredFields(field);\n      }\n      if (this.form.get(field.key)) {\n        this.form.removeControl(field.key);\n      }\n    });\n  }\n}\n","@if(formPrepared) {\n<formly-form\n  [form]=\"form\"\n  [fields]=\"fields\"\n  [model]=\"model\"\n  [options]=\"options\"\n  (modelChange)=\"onModelChange($event)\"\n  class=\"mnl-formly-form\"\n></formly-form>\n}\n"]}
187
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly-lib.component.js","sourceRoot":"","sources":["../../../../../../projects/form-lib/src/lib/formly-lib/formly-lib.component.ts","../../../../../../projects/form-lib/src/lib/formly-lib/formly-lib.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { FormGroup, FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { CommonsModule } from '@muraai/mnl-commons';\nimport { FormlyFormOptions, FormlyModule } from '@ngx-formly/core';\nimport { FormlyMatCheckboxModule } from '@ngx-formly/material/checkbox';\nimport { FormlyMatInputModule } from '@ngx-formly/material/input';\nimport { FormlyMatTextAreaModule } from '@ngx-formly/material/textarea';\nimport { TranslateModule, TranslateService } from '@ngx-translate/core';\nimport { of } from 'rxjs';\nimport { CustomFormlyFieldConfig } from '../models/custom-form-field.model';\nimport { FormlyMatRadioModule } from '@ngx-formly/material/radio';\nimport { ScoringService } from '../services/scoring.service';\n\n@Component({\n  selector: 'mnl-form',\n  standalone: true,\n  imports: [\n    CommonModule,\n    CommonsModule,\n    FormlyModule,\n    ReactiveFormsModule,\n    FormsModule,\n    TranslateModule,\n    FormlyMatTextAreaModule,\n    FormlyMatInputModule,\n    FormlyMatCheckboxModule,\n    FormlyMatRadioModule,\n  ],\n  templateUrl: './formly-lib.component.html',\n  styleUrl: './formly-lib.component.scss',\n})\nexport class MnlFormLibComponent implements OnInit {\n  @Input()\n  readonly = false;\n\n  @Input()\n  form!: FormGroup;\n\n  @Input()\n  fields!: CustomFormlyFieldConfig[];\n\n  @Input()\n  model: any;\n\n  @Input()\n  helperModel: any;\n\n  @Input()\n  options!: FormlyFormOptions;\n\n  @Input()\n  userRoles!: string[];\n\n  @Input()\n  userCountries!: string[];\n\n  @Output()\n  noOfTabs = new EventEmitter();\n\n  @Input()\n  oldValues: any;\n\n  @Input()\n  showOldValues!: boolean;\n\n  @Output()\n  scoreChange = new EventEmitter<any>();\n\n  formPrepared = false;\n  totalTabs = 0;\n  constructor(\n    private translateService: TranslateService,\n    private scoring: ScoringService\n  ) {\n    this.translateService.setDefaultLang('en');\n  }\n  ngOnInit(): void {\n    if (this.fields) {\n      this.applyReadonlyToFields(this.fields);\n      this.filterFieldGroupsByRolesAndCountries(this.fields);\n      this.form.updateValueAndValidity();\n      this.formPrepared = true;\n      this.getNumberOfActiveTabs(this.fields);\n      this.setAutocompleteSingleOptionByDefault(this.fields);\n      this.options = {\n        formState: {\n          ...this.options.formState,\n          showOldValues: this.showOldValues,\n          oldValues: this.oldValues,\n          helperModel: this.helperModel,\n        },\n      };\n    }\n  }\n\n  onModelChange(model: any) {\n    const result = this.scoring.updateScore(model, this.fields);\n    this.scoreChange.emit(result);\n  }\n\n  setAutocompleteSingleOptionByDefault(fields: any) {\n    fields.forEach((field: any) => {\n      if (field.type === 'mu-select-autocomplete') {\n        field.hooks = {\n          onInit: (field: any) => {\n            const formControl = field.formControl;\n            const options = field.props?.options || [];\n\n            if (Array.isArray(options)) {\n              this.setOptionByDefault(formControl, field, options);\n            } else {\n              (options || of([])).subscribe((options: any) => {\n                this.setOptionByDefault(formControl, field, options);\n              });\n            }\n          },\n        };\n      }\n      if (field.fieldGroup) {\n        this.setAutocompleteSingleOptionByDefault(field.fieldGroup);\n      }\n    });\n  }\n\n  setOptionByDefault(formControl: any, field: any, options: any) {\n    if (formControl && field.props && field.props.options) {\n      if (options.length === 1) {\n        formControl.setValue(options[0].value);\n      }\n\n      field.props.optionsChange?.subscribe((updatedOptions: any[]) => {\n        if (updatedOptions.length === 1 && formControl) {\n          formControl.setValue(updatedOptions[0].value);\n        }\n      });\n    }\n  }\n  getNumberOfActiveTabs(fields: any) {\n    fields.forEach((field: any) => {\n      if (field.type === 'mu-tabs') {\n        this.totalTabs = field.fieldGroup?.length || 0;\n        this.noOfTabs.emit(this.totalTabs);\n      }\n      if (field.fieldGroup) {\n        this.getNumberOfActiveTabs(field.fieldGroup);\n      }\n    });\n  }\n\n  applyReadonlyToFields(\n    fields: CustomFormlyFieldConfig[]\n  ): CustomFormlyFieldConfig[] {\n    return fields.map((field) => {\n      if (field.fieldGroup) {\n        this.applyReadonlyToFields(field.fieldGroup);\n      } else {\n        field.props = {\n          ...(field.props || {}),\n          readonly: this.readonly,\n        };\n      }\n      return field;\n    });\n  }\n\n  filterFieldGroupsByRolesAndCountries(fields: CustomFormlyFieldConfig[]) {\n    return fields\n      .map((field: any) => {\n        if (field.fieldGroup && !field.vissibleCountries) {\n          field.fieldGroup = this.filterFieldGroupsByRolesAndCountries(\n            field.fieldGroup\n          );\n        }\n        // const hasValidRole = field.vissibleRoles\n        //   ? field.vissibleRoles.some((role: any) => this.userRoles?.includes(role))\n        //   : true;\n        // const hasValidCountry = field.vissibleCountries\n        //   ? field.vissibleCountries.some((country: any) => this.userCountries?.includes(country))\n        //   : true;\n\n        const validGroup = field;\n        if (validGroup && field.fieldGroup) {\n          field.fieldGroup = this.filterFieldGroupsByRolesAndCountries(\n            field.fieldGroup\n          );\n        }\n        if (validGroup == null) {\n          this.removeValidationsForFilteredFields(field);\n        }\n        if (!validGroup && field.props?.required) {\n          field.props.required = false;\n        }\n        return validGroup;\n      })\n      .filter((field: any) => field !== null);\n  }\n\n  removeValidationsForFilteredFields(fields: any) {\n    fields?.fieldGroup?.forEach((field: any) => {\n      if (field.fieldGroup) {\n        this.removeValidationsForFilteredFields(field);\n      }\n      if (this.form.get(field.key)) {\n        this.form.removeControl(field.key);\n      }\n    });\n  }\n}\n","@if(formPrepared) {\n<formly-form\n  [form]=\"form\"\n  [fields]=\"fields\"\n  [model]=\"model\"\n  [options]=\"options\"\n  (modelChange)=\"onModelChange($event)\"\n  class=\"mnl-formly-form\"\n></formly-form>\n}\n"]}
@@ -1,6 +1,6 @@
1
1
  import { CommonModule } from '@angular/common';
2
2
  import { Component } from '@angular/core';
3
- import { FormsModule, ReactiveFormsModule } from '@angular/forms';
3
+ import { FormControl, FormsModule, ReactiveFormsModule } from '@angular/forms';
4
4
  import { MatNativeDateModule } from '@angular/material/core';
5
5
  import { MatDatepickerModule } from '@angular/material/datepicker';
6
6
  import { MatFormFieldModule } from '@angular/material/form-field';
@@ -23,27 +23,63 @@ export class MnlFormHelperTextInputComponent extends FieldType {
23
23
  get defaultHelperText() {
24
24
  return this.to['helperProps']?.['defaultHelperText'] || '';
25
25
  }
26
- get currentValue() {
26
+ // Get value from primary model (answers)
27
+ get originalValue() {
27
28
  const fieldKey = this.field.key;
28
29
  return this.field.model?.[fieldKey];
29
30
  }
31
+ // Get/Set value from secondary model (helper)
32
+ get helperModel() {
33
+ return (this.to['helperModel'] ||
34
+ this.props['helperModel'] ||
35
+ this.options?.formState?.['helperModel']);
36
+ }
37
+ get helperKey() {
38
+ return this.to['helperKey'] || this.field.key;
39
+ }
40
+ get currentHelperValue() {
41
+ if (this.helperModel && this.helperKey) {
42
+ return this.helperModel[this.helperKey];
43
+ }
44
+ return '';
45
+ }
46
+ set currentHelperValue(value) {
47
+ if (this.helperModel && this.helperKey) {
48
+ this.helperModel[this.helperKey] = value;
49
+ }
50
+ }
30
51
  constructor(cdr) {
31
52
  super();
32
53
  this.cdr = cdr;
33
54
  this.checked = false;
34
55
  }
35
56
  ngOnInit() {
36
- this.originalValue = this.currentValue;
57
+ // Initialize helper form control with value from helper model
58
+ this.helperFormControl = new FormControl(this.currentHelperValue || '');
59
+ // Subscribe to changes in helper form control and update helper model
60
+ this.helperFormControl.valueChanges.subscribe((value) => {
61
+ this.currentHelperValue = value;
62
+ });
37
63
  this.setupDefaultField();
38
64
  if (this.to['enableHelper']) {
39
65
  this.setCorrectValue();
40
66
  this.determineInitialState();
41
67
  }
68
+ if (this.currentHelperValue && this.currentHelperValue.trim() !== '') {
69
+ this.checked = true;
70
+ }
42
71
  }
43
72
  toggleSlide() {
44
73
  this.checked = !this.checked;
45
74
  if (this.checked) {
46
- this.formControl?.setValue(this.defaultHelperText);
75
+ // When toggle is opened, check if helper field is empty
76
+ const currenthelper = this.helperFormControl.value;
77
+ if (!currenthelper || currenthelper.trim() === '') {
78
+ this.helperFormControl.setValue(this.defaultHelperText);
79
+ }
80
+ }
81
+ else {
82
+ this.helperFormControl.setValue('');
47
83
  }
48
84
  this.cdr.detectChanges();
49
85
  }
@@ -54,7 +90,6 @@ export class MnlFormHelperTextInputComponent extends FieldType {
54
90
  ...fieldConfig,
55
91
  key: this.field.key || fieldConfig.key || 'defaultKey',
56
92
  formControl: this.formControl,
57
- // Add required properties that formly expects
58
93
  modelOptions: fieldConfig.modelOptions || this.field.modelOptions || {},
59
94
  validators: fieldConfig.validators || this.field.validators || {},
60
95
  asyncValidators: fieldConfig.asyncValidators || this.field.asyncValidators || {},
@@ -65,7 +100,6 @@ export class MnlFormHelperTextInputComponent extends FieldType {
65
100
  fieldGroupClassName: fieldConfig.fieldGroupClassName ||
66
101
  this.field.fieldGroupClassName ||
67
102
  '',
68
- // Inherit parent field's form and model
69
103
  parent: this.field.parent,
70
104
  options: this.field.options,
71
105
  model: this.field.model,
@@ -78,12 +112,12 @@ export class MnlFormHelperTextInputComponent extends FieldType {
78
112
  switch (this.to['scoring']?.['criteria']) {
79
113
  case 'exactMatch':
80
114
  if (Array.isArray(this.to['scoring']?.['answer']) &&
81
- !this.to['scoring']?.['answer'].includes(this.currentValue)) {
115
+ !this.to['scoring']?.['answer'].includes(this.originalValue)) {
82
116
  this.checked = true;
83
117
  }
84
118
  break;
85
119
  case 'range':
86
- const answer = this.currentValue;
120
+ const answer = this.originalValue;
87
121
  const num = typeof answer === 'number' ? answer : Number(answer);
88
122
  const correct = Number.isFinite(num) &&
89
123
  num >= this.to['scoring']?.['answer'].min &&
@@ -95,24 +129,41 @@ export class MnlFormHelperTextInputComponent extends FieldType {
95
129
  }
96
130
  }
97
131
  setCorrectValue() {
132
+ const currentHelperValue = this.currentHelperValue;
133
+ // If helper already has a value (user edited), don't override
134
+ if (currentHelperValue && currentHelperValue.trim() !== '') {
135
+ return;
136
+ }
98
137
  switch (this.to['scoring']?.['criteria']) {
99
138
  case 'attempted':
100
- this.formControl?.setValue(this.defaultHelperText);
139
+ // For attempted, set defaultHelperText
140
+ this.helperFormControl.setValue('');
101
141
  break;
102
142
  case 'exactMatch':
103
- if (Array.isArray(this.to['scoring']?.['answer']) &&
104
- !this.to['scoring']?.['answer'].includes(this.originalValue)) {
105
- this.formControl?.setValue(this.defaultHelperText);
143
+ if (Array.isArray(this.to['scoring']?.['answer'])) {
144
+ if (this.to['scoring']?.['answer'].includes(this.originalValue)) {
145
+ // Answer is correct - set empty value in helper
146
+ this.helperFormControl.setValue('');
147
+ }
148
+ else {
149
+ // Answer is incorrect - set defaultHelperText in helper
150
+ this.helperFormControl.setValue(this.defaultHelperText);
151
+ }
106
152
  }
107
153
  break;
108
154
  case 'range':
109
- const answer = this.currentValue;
155
+ const answer = this.originalValue;
110
156
  const num = typeof answer === 'number' ? answer : Number(answer);
111
157
  const correct = Number.isFinite(num) &&
112
158
  num >= this.to['scoring']?.['answer'].min &&
113
159
  num <= this.to['scoring']?.['answer'].max;
114
- if (!correct) {
115
- this.formControl?.setValue(this.defaultHelperText);
160
+ if (correct) {
161
+ // Answer is correct - set empty value in helper
162
+ this.helperFormControl.setValue('');
163
+ }
164
+ else {
165
+ // Answer is incorrect - set defaultHelperText in helper
166
+ this.helperFormControl.setValue(this.defaultHelperText);
116
167
  }
117
168
  break;
118
169
  default:
@@ -137,8 +188,7 @@ export class MnlFormHelperTextInputComponent extends FieldType {
137
188
  <mat-form-field class="textarea" appearance="outline" *ngIf="checked">
138
189
  <textarea
139
190
  matInput
140
- [formControl]="formControl"
141
- [formlyAttributes]="field"
191
+ [formControl]="helperFormControl"
142
192
  [readonly]="to['readonly']"
143
193
  >
144
194
  </textarea>
@@ -151,7 +201,7 @@ export class MnlFormHelperTextInputComponent extends FieldType {
151
201
  </formly-field>
152
202
  </div>
153
203
  </div>
154
- `, isInline: true, styles: [".helper-text-container{display:flex;flex-direction:column}.answer{font-size:12px}.textarea{margin:0!important;width:100%}.flex-row{display:flex;flex-direction:row;justify-content:space-between}.w-full{width:100%}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i2.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "ngmodule", type: FormlyModule }, { kind: "component", type: i4.FormlyField, selector: "formly-field", inputs: ["field"] }, { kind: "directive", type: i4.ɵFormlyAttributes, selector: "[formlyAttributes]", inputs: ["formlyAttributes", "id"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: MatSlideToggleModule }, { kind: "component", type: i6.MatSlideToggle, selector: "mat-slide-toggle", inputs: ["name", "id", "labelPosition", "aria-label", "aria-labelledby", "aria-describedby", "required", "color", "disabled", "disableRipple", "tabIndex", "checked", "hideIcon", "disabledInteractive"], outputs: ["change", "toggleChange"], exportAs: ["matSlideToggle"] }, { kind: "ngmodule", type: MatSelectModule }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "ngmodule", type: MatNativeDateModule }] }); }
204
+ `, isInline: true, styles: [".helper-text-container{display:flex;flex-direction:column}.answer{font-size:12px}.textarea{margin:0!important;width:100%}.flex-row{display:flex;flex-direction:row;justify-content:space-between}.w-full{width:100%}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i2.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "ngmodule", type: FormlyModule }, { kind: "component", type: i4.FormlyField, selector: "formly-field", inputs: ["field"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: MatSlideToggleModule }, { kind: "component", type: i6.MatSlideToggle, selector: "mat-slide-toggle", inputs: ["name", "id", "labelPosition", "aria-label", "aria-labelledby", "aria-describedby", "required", "color", "disabled", "disableRipple", "tabIndex", "checked", "hideIcon", "disabledInteractive"], outputs: ["change", "toggleChange"], exportAs: ["matSlideToggle"] }, { kind: "ngmodule", type: MatSelectModule }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "ngmodule", type: MatNativeDateModule }] }); }
155
205
  }
156
206
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: MnlFormHelperTextInputComponent, decorators: [{
157
207
  type: Component,
@@ -183,8 +233,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
183
233
  <mat-form-field class="textarea" appearance="outline" *ngIf="checked">
184
234
  <textarea
185
235
  matInput
186
- [formControl]="formControl"
187
- [formlyAttributes]="field"
236
+ [formControl]="helperFormControl"
188
237
  [readonly]="to['readonly']"
189
238
  >
190
239
  </textarea>
@@ -199,4 +248,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
199
248
  </div>
200
249
  `, styles: [".helper-text-container{display:flex;flex-direction:column}.answer{font-size:12px}.textarea{margin:0!important;width:100%}.flex-row{display:flex;flex-direction:row;justify-content:space-between}.w-full{width:100%}\n"] }]
201
250
  }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }] });
202
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mu-helper-text.type.js","sourceRoot":"","sources":["../../../../../../projects/form-lib/src/lib/types/mu-helper-text.type.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { ChangeDetectorRef, Component, OnInit } from '@angular/core';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { MatNativeDateModule } from '@angular/material/core';\nimport { MatDatepickerModule } from '@angular/material/datepicker';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatSelectModule } from '@angular/material/select';\nimport { MatSlideToggleModule } from '@angular/material/slide-toggle';\nimport {\n  FieldTypeConfig,\n  FormlyFieldConfig,\n  FormlyModule,\n} from '@ngx-formly/core';\nimport { FieldType } from '@ngx-formly/material';\n\n@Component({\n  selector: 'mu-helper-text',\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatInputModule,\n    FormlyModule,\n    ReactiveFormsModule,\n    FormsModule,\n    MatFormFieldModule,\n    MatSlideToggleModule,\n    MatSelectModule,\n    MatDatepickerModule,\n    MatNativeDateModule,\n  ],\n  template: `\n    <div class=\"helper-text-container\">\n      <!-- Helper Mode - Show toggle and conditional content -->\n      <div *ngIf=\"to['enableHelper']\">\n        <mat-label>{{ to.label }}</mat-label>\n        <div *ngIf=\"originalValue\" class=\"flex-row\">\n          <span class=\"answer\">{{ originalValue }}</span>\n          <mat-slide-toggle\n            [(ngModel)]=\"checked\"\n            (toggleChange)=\"toggleSlide()\"\n            >{{ helperLabel }}</mat-slide-toggle\n          >\n        </div>\n\n        <mat-form-field class=\"textarea\" appearance=\"outline\" *ngIf=\"checked\">\n          <textarea\n            matInput\n            [formControl]=\"formControl\"\n            [formlyAttributes]=\"field\"\n            [readonly]=\"to['readonly']\"\n          >\n          </textarea>\n        </mat-form-field>\n      </div>\n\n      <!-- Default Mode - Show field directly -->\n      <div *ngIf=\"!to['enableHelper']\">\n        <formly-field *ngIf=\"defaultFieldConfig\" [field]=\"defaultFieldConfig\">\n        </formly-field>\n      </div>\n    </div>\n  `,\n  styles: `\n     .helper-text-container{\n      display: flex;\n      flex-direction: column;\n     }\n     .answer{\n      font-size: 12px;\n     }\n      .textarea{\n      margin: 0px !important;\n      width: 100%;\n     }\n     .flex-row{\n      display: flex;\n      flex-direction: row;\n      justify-content: space-between;\n     }\n     .w-full{\n      width: 100%;\n     }\n  `,\n})\nexport class MnlFormHelperTextInputComponent\n  extends FieldType<FieldTypeConfig>\n  implements OnInit\n{\n  checked = false;\n  get helperLabel() {\n    return this.to['helperProps']?.['helperLabel'] || 'Need help?';\n  }\n  get defaultHelperText() {\n    return this.to['helperProps']?.['defaultHelperText'] || '';\n  }\n  get currentValue() {\n    const fieldKey = this.field.key as string;\n    return this.field.model?.[fieldKey];\n  }\n  originalValue: any;\n  defaultFieldConfig?: FormlyFieldConfig;\n\n  constructor(private cdr: ChangeDetectorRef) {\n    super();\n  }\n\n  ngOnInit() {\n    this.originalValue = this.currentValue;    \n    this.setupDefaultField();\n    if (this.to['enableHelper']) {\n      this.setCorrectValue();\n      this.determineInitialState();\n    }\n  }\n\n  toggleSlide() {\n    this.checked = !this.checked;\n    if(this.checked) {\n      this.formControl?.setValue(this.defaultHelperText);\n    }\n    this.cdr.detectChanges();\n  }\n\n  setupDefaultField() {\n    const fieldConfig = this.to['defaultFieldConfig'];\n    if (fieldConfig) {\n      this.defaultFieldConfig = {\n        ...fieldConfig,\n        key: this.field.key || fieldConfig.key || 'defaultKey',\n        formControl: this.formControl,\n        // Add required properties that formly expects\n        modelOptions: fieldConfig.modelOptions || this.field.modelOptions || {},\n        validators: fieldConfig.validators || this.field.validators || {},\n        asyncValidators:\n          fieldConfig.asyncValidators || this.field.asyncValidators || {},\n        hooks: fieldConfig.hooks || this.field.hooks || {},\n        expressions: fieldConfig.expressions || this.field.expressions || {},\n        hide: fieldConfig.hide !== undefined ? fieldConfig.hide : false,\n        className: fieldConfig.className || this.field.className || '',\n        fieldGroupClassName:\n          fieldConfig.fieldGroupClassName ||\n          this.field.fieldGroupClassName ||\n          '',\n        // Inherit parent field's form and model\n        parent: this.field.parent,\n        options: this.field.options,\n        model: this.field.model,\n        form: this.field.form,\n      };\n    }\n  }\n\n  determineInitialState() {\n    // Auto-open helper based on scoring criteria\n    switch (this.to['scoring']?.['criteria']) {\n      case 'exactMatch':\n        if (\n          Array.isArray(this.to['scoring']?.['answer']) &&\n          !this.to['scoring']?.['answer'].includes(this.currentValue)\n        ) {\n          this.checked = true;\n        }\n        break;\n\n      case 'range':\n        const answer = this.currentValue;\n        const num = typeof answer === 'number' ? answer : Number(answer);\n\n        const correct =\n          Number.isFinite(num) &&\n          num >= this.to['scoring']?.['answer'].min &&\n          num <= this.to['scoring']?.['answer'].max;\n\n        if (!correct) {\n          this.checked = true;\n        }\n        break;\n    }\n  }\n\n  setCorrectValue() {\n    switch (this.to['scoring']?.['criteria']) {\n      case 'attempted':\n        this.formControl?.setValue(this.defaultHelperText);\n        break;\n\n      case 'exactMatch':\n        if (\n          Array.isArray(this.to['scoring']?.['answer']) &&\n          !this.to['scoring']?.['answer'].includes(this.originalValue)\n        ) {\n          this.formControl?.setValue(this.defaultHelperText);\n        }\n        break;\n\n      case 'range':\n        const answer = this.currentValue;\n        const num = typeof answer === 'number' ? answer : Number(answer);\n\n        const correct =\n          Number.isFinite(num) &&\n          num >= this.to['scoring']?.['answer'].min &&\n          num <= this.to['scoring']?.['answer'].max;\n\n        if (!correct) {\n          this.formControl?.setValue(this.defaultHelperText);\n        }\n        break;\n\n      default:\n        break;\n    }\n  }\n}\n"]}
251
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mu-helper-text.type.js","sourceRoot":"","sources":["../../../../../../projects/form-lib/src/lib/types/mu-helper-text.type.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { ChangeDetectorRef, Component, OnInit } from '@angular/core';\nimport { FormControl, FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { MatNativeDateModule } from '@angular/material/core';\nimport { MatDatepickerModule } from '@angular/material/datepicker';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatSelectModule } from '@angular/material/select';\nimport { MatSlideToggleModule } from '@angular/material/slide-toggle';\nimport {\n  FieldTypeConfig,\n  FormlyFieldConfig,\n  FormlyModule,\n} from '@ngx-formly/core';\nimport { FieldType } from '@ngx-formly/material';\n\n@Component({\n  selector: 'mu-helper-text',\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatInputModule,\n    FormlyModule,\n    ReactiveFormsModule,\n    FormsModule,\n    MatFormFieldModule,\n    MatSlideToggleModule,\n    MatSelectModule,\n    MatDatepickerModule,\n    MatNativeDateModule,\n  ],\n  template: `\n    <div class=\"helper-text-container\">\n      <!-- Helper Mode - Show toggle and conditional content -->\n      <div *ngIf=\"to['enableHelper']\">\n        <mat-label>{{ to.label }}</mat-label>\n        <div *ngIf=\"originalValue\" class=\"flex-row\">\n          <span class=\"answer\">{{ originalValue }}</span>\n          <mat-slide-toggle\n            [(ngModel)]=\"checked\"\n            (toggleChange)=\"toggleSlide()\"\n            >{{ helperLabel }}</mat-slide-toggle\n          >\n        </div>\n\n        <mat-form-field class=\"textarea\" appearance=\"outline\" *ngIf=\"checked\">\n          <textarea\n            matInput\n            [formControl]=\"helperFormControl\"\n            [readonly]=\"to['readonly']\"\n          >\n          </textarea>\n        </mat-form-field>\n      </div>\n\n      <!-- Default Mode - Show field directly -->\n      <div *ngIf=\"!to['enableHelper']\">\n        <formly-field *ngIf=\"defaultFieldConfig\" [field]=\"defaultFieldConfig\">\n        </formly-field>\n      </div>\n    </div>\n  `,\n  styles: `\n     .helper-text-container{\n      display: flex;\n      flex-direction: column;\n     }\n     .answer{\n      font-size: 12px;\n     }\n      .textarea{\n      margin: 0px !important;\n      width: 100%;\n     }\n     .flex-row{\n      display: flex;\n      flex-direction: row;\n      justify-content: space-between;\n     }\n     .w-full{\n      width: 100%;\n     }\n  `,\n})\nexport class MnlFormHelperTextInputComponent\n  extends FieldType<FieldTypeConfig>\n  implements OnInit\n{\n  checked = false;\n  helperFormControl!: FormControl; // Separate form control for helper model\n\n  get helperLabel() {\n    return this.to['helperProps']?.['helperLabel'] || 'Need help?';\n  }\n  get defaultHelperText() {\n    return this.to['helperProps']?.['defaultHelperText'] || '';\n  }\n\n  // Get value from primary model (answers)\n  get originalValue() {\n    const fieldKey = this.field.key as string;\n    return this.field.model?.[fieldKey];\n  }\n\n  // Get/Set value from secondary model (helper)\n  get helperModel() {\n    return (\n      this.to['helperModel'] ||\n      this.props['helperModel'] ||\n      this.options?.formState?.['helperModel']\n    );\n  }\n\n  get helperKey() {\n    return this.to['helperKey'] || this.field.key;\n  }\n\n  get currentHelperValue() {\n    if (this.helperModel && this.helperKey) {\n      return this.helperModel[this.helperKey as string];\n    }\n    return '';\n  }\n\n  set currentHelperValue(value: any) {\n    if (this.helperModel && this.helperKey) {\n      this.helperModel[this.helperKey as string] = value;\n    }\n  }\n\n  defaultFieldConfig?: FormlyFieldConfig;\n\n  constructor(private cdr: ChangeDetectorRef) {\n    super();\n  }\n\n  ngOnInit() {\n    // Initialize helper form control with value from helper model\n    this.helperFormControl = new FormControl(this.currentHelperValue || '');\n\n    // Subscribe to changes in helper form control and update helper model\n    this.helperFormControl.valueChanges.subscribe((value) => {\n      this.currentHelperValue = value;\n    });\n\n    this.setupDefaultField();\n\n    if (this.to['enableHelper']) {\n      this.setCorrectValue();\n      this.determineInitialState();\n    }\n    if (this.currentHelperValue && this.currentHelperValue.trim() !== '') {\n      this.checked = true;\n    }\n  }\n\n  toggleSlide() {\n    this.checked = !this.checked;\n    if (this.checked) {\n      // When toggle is opened, check if helper field is empty\n      const currenthelper = this.helperFormControl.value;\n      if (!currenthelper || currenthelper.trim() === '') {\n        this.helperFormControl.setValue(this.defaultHelperText);\n      }\n    } else {\n      this.helperFormControl.setValue('');\n    }\n    this.cdr.detectChanges();\n  }\n\n  setupDefaultField() {\n    const fieldConfig = this.to['defaultFieldConfig'];\n    if (fieldConfig) {\n      this.defaultFieldConfig = {\n        ...fieldConfig,\n        key: this.field.key || fieldConfig.key || 'defaultKey',\n        formControl: this.formControl,\n        modelOptions: fieldConfig.modelOptions || this.field.modelOptions || {},\n        validators: fieldConfig.validators || this.field.validators || {},\n        asyncValidators:\n          fieldConfig.asyncValidators || this.field.asyncValidators || {},\n        hooks: fieldConfig.hooks || this.field.hooks || {},\n        expressions: fieldConfig.expressions || this.field.expressions || {},\n        hide: fieldConfig.hide !== undefined ? fieldConfig.hide : false,\n        className: fieldConfig.className || this.field.className || '',\n        fieldGroupClassName:\n          fieldConfig.fieldGroupClassName ||\n          this.field.fieldGroupClassName ||\n          '',\n        parent: this.field.parent,\n        options: this.field.options,\n        model: this.field.model,\n        form: this.field.form,\n      };\n    }\n  }\n\n  determineInitialState() {\n    // Auto-open helper based on scoring criteria\n    switch (this.to['scoring']?.['criteria']) {\n      case 'exactMatch':\n        if (\n          Array.isArray(this.to['scoring']?.['answer']) &&\n          !this.to['scoring']?.['answer'].includes(this.originalValue)\n        ) {\n          this.checked = true;\n        }\n        break;\n\n      case 'range':\n        const answer = this.originalValue;\n        const num = typeof answer === 'number' ? answer : Number(answer);\n\n        const correct =\n          Number.isFinite(num) &&\n          num >= this.to['scoring']?.['answer'].min &&\n          num <= this.to['scoring']?.['answer'].max;\n\n        if (!correct) {\n          this.checked = true;\n        }\n        break;\n    }\n  }\n\n  setCorrectValue() {\n    const currentHelperValue = this.currentHelperValue;\n\n    // If helper already has a value (user edited), don't override\n    if (currentHelperValue && currentHelperValue.trim() !== '') {\n      return;\n    }\n\n    switch (this.to['scoring']?.['criteria']) {\n      case 'attempted':\n        // For attempted, set defaultHelperText\n        this.helperFormControl.setValue('');\n        break;\n\n      case 'exactMatch':\n        if (Array.isArray(this.to['scoring']?.['answer'])) {\n          if (this.to['scoring']?.['answer'].includes(this.originalValue)) {\n            // Answer is correct - set empty value in helper\n            this.helperFormControl.setValue('');\n          } else {\n            // Answer is incorrect - set defaultHelperText in helper\n            this.helperFormControl.setValue(this.defaultHelperText);\n          }\n        }\n        break;\n\n      case 'range':\n        const answer = this.originalValue;\n        const num = typeof answer === 'number' ? answer : Number(answer);\n\n        const correct =\n          Number.isFinite(num) &&\n          num >= this.to['scoring']?.['answer'].min &&\n          num <= this.to['scoring']?.['answer'].max;\n\n        if (correct) {\n          // Answer is correct - set empty value in helper\n          this.helperFormControl.setValue('');\n        } else {\n          // Answer is incorrect - set defaultHelperText in helper\n          this.helperFormControl.setValue(this.defaultHelperText);\n        }\n        break;\n\n      default:\n        break;\n    }\n  }\n}\n"]}
@@ -4524,27 +4524,63 @@ class MnlFormHelperTextInputComponent extends FieldType$1 {
4524
4524
  get defaultHelperText() {
4525
4525
  return this.to['helperProps']?.['defaultHelperText'] || '';
4526
4526
  }
4527
- get currentValue() {
4527
+ // Get value from primary model (answers)
4528
+ get originalValue() {
4528
4529
  const fieldKey = this.field.key;
4529
4530
  return this.field.model?.[fieldKey];
4530
4531
  }
4532
+ // Get/Set value from secondary model (helper)
4533
+ get helperModel() {
4534
+ return (this.to['helperModel'] ||
4535
+ this.props['helperModel'] ||
4536
+ this.options?.formState?.['helperModel']);
4537
+ }
4538
+ get helperKey() {
4539
+ return this.to['helperKey'] || this.field.key;
4540
+ }
4541
+ get currentHelperValue() {
4542
+ if (this.helperModel && this.helperKey) {
4543
+ return this.helperModel[this.helperKey];
4544
+ }
4545
+ return '';
4546
+ }
4547
+ set currentHelperValue(value) {
4548
+ if (this.helperModel && this.helperKey) {
4549
+ this.helperModel[this.helperKey] = value;
4550
+ }
4551
+ }
4531
4552
  constructor(cdr) {
4532
4553
  super();
4533
4554
  this.cdr = cdr;
4534
4555
  this.checked = false;
4535
4556
  }
4536
4557
  ngOnInit() {
4537
- this.originalValue = this.currentValue;
4558
+ // Initialize helper form control with value from helper model
4559
+ this.helperFormControl = new FormControl(this.currentHelperValue || '');
4560
+ // Subscribe to changes in helper form control and update helper model
4561
+ this.helperFormControl.valueChanges.subscribe((value) => {
4562
+ this.currentHelperValue = value;
4563
+ });
4538
4564
  this.setupDefaultField();
4539
4565
  if (this.to['enableHelper']) {
4540
4566
  this.setCorrectValue();
4541
4567
  this.determineInitialState();
4542
4568
  }
4569
+ if (this.currentHelperValue && this.currentHelperValue.trim() !== '') {
4570
+ this.checked = true;
4571
+ }
4543
4572
  }
4544
4573
  toggleSlide() {
4545
4574
  this.checked = !this.checked;
4546
4575
  if (this.checked) {
4547
- this.formControl?.setValue(this.defaultHelperText);
4576
+ // When toggle is opened, check if helper field is empty
4577
+ const currenthelper = this.helperFormControl.value;
4578
+ if (!currenthelper || currenthelper.trim() === '') {
4579
+ this.helperFormControl.setValue(this.defaultHelperText);
4580
+ }
4581
+ }
4582
+ else {
4583
+ this.helperFormControl.setValue('');
4548
4584
  }
4549
4585
  this.cdr.detectChanges();
4550
4586
  }
@@ -4555,7 +4591,6 @@ class MnlFormHelperTextInputComponent extends FieldType$1 {
4555
4591
  ...fieldConfig,
4556
4592
  key: this.field.key || fieldConfig.key || 'defaultKey',
4557
4593
  formControl: this.formControl,
4558
- // Add required properties that formly expects
4559
4594
  modelOptions: fieldConfig.modelOptions || this.field.modelOptions || {},
4560
4595
  validators: fieldConfig.validators || this.field.validators || {},
4561
4596
  asyncValidators: fieldConfig.asyncValidators || this.field.asyncValidators || {},
@@ -4566,7 +4601,6 @@ class MnlFormHelperTextInputComponent extends FieldType$1 {
4566
4601
  fieldGroupClassName: fieldConfig.fieldGroupClassName ||
4567
4602
  this.field.fieldGroupClassName ||
4568
4603
  '',
4569
- // Inherit parent field's form and model
4570
4604
  parent: this.field.parent,
4571
4605
  options: this.field.options,
4572
4606
  model: this.field.model,
@@ -4579,12 +4613,12 @@ class MnlFormHelperTextInputComponent extends FieldType$1 {
4579
4613
  switch (this.to['scoring']?.['criteria']) {
4580
4614
  case 'exactMatch':
4581
4615
  if (Array.isArray(this.to['scoring']?.['answer']) &&
4582
- !this.to['scoring']?.['answer'].includes(this.currentValue)) {
4616
+ !this.to['scoring']?.['answer'].includes(this.originalValue)) {
4583
4617
  this.checked = true;
4584
4618
  }
4585
4619
  break;
4586
4620
  case 'range':
4587
- const answer = this.currentValue;
4621
+ const answer = this.originalValue;
4588
4622
  const num = typeof answer === 'number' ? answer : Number(answer);
4589
4623
  const correct = Number.isFinite(num) &&
4590
4624
  num >= this.to['scoring']?.['answer'].min &&
@@ -4596,24 +4630,41 @@ class MnlFormHelperTextInputComponent extends FieldType$1 {
4596
4630
  }
4597
4631
  }
4598
4632
  setCorrectValue() {
4633
+ const currentHelperValue = this.currentHelperValue;
4634
+ // If helper already has a value (user edited), don't override
4635
+ if (currentHelperValue && currentHelperValue.trim() !== '') {
4636
+ return;
4637
+ }
4599
4638
  switch (this.to['scoring']?.['criteria']) {
4600
4639
  case 'attempted':
4601
- this.formControl?.setValue(this.defaultHelperText);
4640
+ // For attempted, set defaultHelperText
4641
+ this.helperFormControl.setValue('');
4602
4642
  break;
4603
4643
  case 'exactMatch':
4604
- if (Array.isArray(this.to['scoring']?.['answer']) &&
4605
- !this.to['scoring']?.['answer'].includes(this.originalValue)) {
4606
- this.formControl?.setValue(this.defaultHelperText);
4644
+ if (Array.isArray(this.to['scoring']?.['answer'])) {
4645
+ if (this.to['scoring']?.['answer'].includes(this.originalValue)) {
4646
+ // Answer is correct - set empty value in helper
4647
+ this.helperFormControl.setValue('');
4648
+ }
4649
+ else {
4650
+ // Answer is incorrect - set defaultHelperText in helper
4651
+ this.helperFormControl.setValue(this.defaultHelperText);
4652
+ }
4607
4653
  }
4608
4654
  break;
4609
4655
  case 'range':
4610
- const answer = this.currentValue;
4656
+ const answer = this.originalValue;
4611
4657
  const num = typeof answer === 'number' ? answer : Number(answer);
4612
4658
  const correct = Number.isFinite(num) &&
4613
4659
  num >= this.to['scoring']?.['answer'].min &&
4614
4660
  num <= this.to['scoring']?.['answer'].max;
4615
- if (!correct) {
4616
- this.formControl?.setValue(this.defaultHelperText);
4661
+ if (correct) {
4662
+ // Answer is correct - set empty value in helper
4663
+ this.helperFormControl.setValue('');
4664
+ }
4665
+ else {
4666
+ // Answer is incorrect - set defaultHelperText in helper
4667
+ this.helperFormControl.setValue(this.defaultHelperText);
4617
4668
  }
4618
4669
  break;
4619
4670
  default:
@@ -4638,8 +4689,7 @@ class MnlFormHelperTextInputComponent extends FieldType$1 {
4638
4689
  <mat-form-field class="textarea" appearance="outline" *ngIf="checked">
4639
4690
  <textarea
4640
4691
  matInput
4641
- [formControl]="formControl"
4642
- [formlyAttributes]="field"
4692
+ [formControl]="helperFormControl"
4643
4693
  [readonly]="to['readonly']"
4644
4694
  >
4645
4695
  </textarea>
@@ -4652,7 +4702,7 @@ class MnlFormHelperTextInputComponent extends FieldType$1 {
4652
4702
  </formly-field>
4653
4703
  </div>
4654
4704
  </div>
4655
- `, isInline: true, styles: [".helper-text-container{display:flex;flex-direction:column}.answer{font-size:12px}.textarea{margin:0!important;width:100%}.flex-row{display:flex;flex-direction:row;justify-content:space-between}.w-full{width:100%}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i2.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i3$3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3$3.MatLabel, selector: "mat-label" }, { kind: "ngmodule", type: FormlyModule }, { kind: "component", type: i2$1.FormlyField, selector: "formly-field", inputs: ["field"] }, { kind: "directive", type: i2$1.ɵFormlyAttributes, selector: "[formlyAttributes]", inputs: ["formlyAttributes", "id"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: MatSlideToggleModule }, { kind: "component", type: i6$3.MatSlideToggle, selector: "mat-slide-toggle", inputs: ["name", "id", "labelPosition", "aria-label", "aria-labelledby", "aria-describedby", "required", "color", "disabled", "disableRipple", "tabIndex", "checked", "hideIcon", "disabledInteractive"], outputs: ["change", "toggleChange"], exportAs: ["matSlideToggle"] }, { kind: "ngmodule", type: MatSelectModule }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "ngmodule", type: MatNativeDateModule }] }); }
4705
+ `, isInline: true, styles: [".helper-text-container{display:flex;flex-direction:column}.answer{font-size:12px}.textarea{margin:0!important;width:100%}.flex-row{display:flex;flex-direction:row;justify-content:space-between}.w-full{width:100%}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i2.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i3$3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3$3.MatLabel, selector: "mat-label" }, { kind: "ngmodule", type: FormlyModule }, { kind: "component", type: i2$1.FormlyField, selector: "formly-field", inputs: ["field"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: MatSlideToggleModule }, { kind: "component", type: i6$3.MatSlideToggle, selector: "mat-slide-toggle", inputs: ["name", "id", "labelPosition", "aria-label", "aria-labelledby", "aria-describedby", "required", "color", "disabled", "disableRipple", "tabIndex", "checked", "hideIcon", "disabledInteractive"], outputs: ["change", "toggleChange"], exportAs: ["matSlideToggle"] }, { kind: "ngmodule", type: MatSelectModule }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "ngmodule", type: MatNativeDateModule }] }); }
4656
4706
  }
4657
4707
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: MnlFormHelperTextInputComponent, decorators: [{
4658
4708
  type: Component,
@@ -4684,8 +4734,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
4684
4734
  <mat-form-field class="textarea" appearance="outline" *ngIf="checked">
4685
4735
  <textarea
4686
4736
  matInput
4687
- [formControl]="formControl"
4688
- [formlyAttributes]="field"
4737
+ [formControl]="helperFormControl"
4689
4738
  [readonly]="to['readonly']"
4690
4739
  >
4691
4740
  </textarea>
@@ -4918,6 +4967,7 @@ class MnlFormLibComponent {
4918
4967
  ...this.options.formState,
4919
4968
  showOldValues: this.showOldValues,
4920
4969
  oldValues: this.oldValues,
4970
+ helperModel: this.helperModel,
4921
4971
  },
4922
4972
  };
4923
4973
  }
@@ -5023,7 +5073,7 @@ class MnlFormLibComponent {
5023
5073
  });
5024
5074
  }
5025
5075
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: MnlFormLibComponent, deps: [{ token: i1$2.TranslateService }, { token: ScoringService }], target: i0.ɵɵFactoryTarget.Component }); }
5026
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: MnlFormLibComponent, isStandalone: true, selector: "mnl-form", inputs: { readonly: "readonly", form: "form", fields: "fields", model: "model", options: "options", userRoles: "userRoles", userCountries: "userCountries", oldValues: "oldValues", showOldValues: "showOldValues" }, outputs: { noOfTabs: "noOfTabs", scoreChange: "scoreChange" }, ngImport: i0, template: "@if(formPrepared) {\n<formly-form\n [form]=\"form\"\n [fields]=\"fields\"\n [model]=\"model\"\n [options]=\"options\"\n (modelChange)=\"onModelChange($event)\"\n class=\"mnl-formly-form\"\n></formly-form>\n}\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: CommonsModule }, { kind: "ngmodule", type: FormlyModule }, { kind: "component", type: i2$1.FormlyForm, selector: "formly-form", inputs: ["form", "model", "fields", "options"], outputs: ["modelChange"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: TranslateModule }, { kind: "ngmodule", type: FormlyMatTextAreaModule }, { kind: "ngmodule", type: FormlyMatInputModule }, { kind: "ngmodule", type: FormlyMatCheckboxModule }, { kind: "ngmodule", type: FormlyMatRadioModule }] }); }
5076
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: MnlFormLibComponent, isStandalone: true, selector: "mnl-form", inputs: { readonly: "readonly", form: "form", fields: "fields", model: "model", helperModel: "helperModel", options: "options", userRoles: "userRoles", userCountries: "userCountries", oldValues: "oldValues", showOldValues: "showOldValues" }, outputs: { noOfTabs: "noOfTabs", scoreChange: "scoreChange" }, ngImport: i0, template: "@if(formPrepared) {\n<formly-form\n [form]=\"form\"\n [fields]=\"fields\"\n [model]=\"model\"\n [options]=\"options\"\n (modelChange)=\"onModelChange($event)\"\n class=\"mnl-formly-form\"\n></formly-form>\n}\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: CommonsModule }, { kind: "ngmodule", type: FormlyModule }, { kind: "component", type: i2$1.FormlyForm, selector: "formly-form", inputs: ["form", "model", "fields", "options"], outputs: ["modelChange"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: TranslateModule }, { kind: "ngmodule", type: FormlyMatTextAreaModule }, { kind: "ngmodule", type: FormlyMatInputModule }, { kind: "ngmodule", type: FormlyMatCheckboxModule }, { kind: "ngmodule", type: FormlyMatRadioModule }] }); }
5027
5077
  }
5028
5078
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: MnlFormLibComponent, decorators: [{
5029
5079
  type: Component,
@@ -5047,6 +5097,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
5047
5097
  type: Input
5048
5098
  }], model: [{
5049
5099
  type: Input
5100
+ }], helperModel: [{
5101
+ type: Input
5050
5102
  }], options: [{
5051
5103
  type: Input
5052
5104
  }], userRoles: [{