@muraai/mnl-form 0.0.1-alpha-db495b1 → 0.0.1-alpha-11e96eb

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (61) hide show
  1. package/fesm2022/muraai-mnl-form.mjs +150 -143
  2. package/fesm2022/muraai-mnl-form.mjs.map +1 -1
  3. package/lib/types/upload-file.d.ts +1 -1
  4. package/lib/workflow-status/ workflow-status.module.d.ts +8 -8
  5. package/lib/workflow-status/workflow-status.component.d.ts +1 -1
  6. package/package.json +4 -5
  7. package/esm2022/lib/confirmation-dialog/confirmation-dialog.component.mjs +0 -34
  8. package/esm2022/lib/mnl-form/mnl-form-standalone.module.mjs +0 -155
  9. package/esm2022/lib/mnl-form/mnl-form.component.mjs +0 -199
  10. package/esm2022/lib/models/custom-form-field.model.mjs +0 -2
  11. package/esm2022/lib/models/workflow-status.model.mjs +0 -2
  12. package/esm2022/lib/services/graphql.service.mjs +0 -30
  13. package/esm2022/lib/services/scoring.service.mjs +0 -103
  14. package/esm2022/lib/types/action-button-renderer.component.mjs +0 -59
  15. package/esm2022/lib/types/autocomplete-type.component.mjs +0 -68
  16. package/esm2022/lib/types/button.type.mjs +0 -72
  17. package/esm2022/lib/types/comments.type.mjs +0 -102
  18. package/esm2022/lib/types/country-code-input.type.mjs +0 -181
  19. package/esm2022/lib/types/custom-date.type.mjs +0 -20
  20. package/esm2022/lib/types/custom-input.component.mjs +0 -62
  21. package/esm2022/lib/types/date-format.type.mjs +0 -196
  22. package/esm2022/lib/types/expansion-panel.types.mjs +0 -85
  23. package/esm2022/lib/types/formly-field-panel.type.mjs +0 -70
  24. package/esm2022/lib/types/grid-actionable.type.mjs +0 -197
  25. package/esm2022/lib/types/grid-formly-cell.component.mjs +0 -42
  26. package/esm2022/lib/types/grid.type.mjs +0 -125
  27. package/esm2022/lib/types/input.type.mjs +0 -43
  28. package/esm2022/lib/types/mu-helper-text.type.mjs +0 -331
  29. package/esm2022/lib/types/multi-select-autocomplete.mjs +0 -139
  30. package/esm2022/lib/types/multi-select-checkbox.component.mjs +0 -247
  31. package/esm2022/lib/types/radio.type.mjs +0 -71
  32. package/esm2022/lib/types/scrollable-tabs.types.mjs +0 -220
  33. package/esm2022/lib/types/select-api-auto-complete.component.mjs +0 -111
  34. package/esm2022/lib/types/select-autocomplete-redefined.component.mjs +0 -142
  35. package/esm2022/lib/types/select-autocomplete.type.mjs +0 -254
  36. package/esm2022/lib/types/stepper.type.mjs +0 -268
  37. package/esm2022/lib/types/table.types.mjs +0 -79
  38. package/esm2022/lib/types/tabs.types.mjs +0 -293
  39. package/esm2022/lib/types/tabular-form-dialog.component.mjs +0 -331
  40. package/esm2022/lib/types/tabular-form.type.mjs +0 -641
  41. package/esm2022/lib/types/upload-file.mjs +0 -524
  42. package/esm2022/lib/types/view-file-dialog.component.mjs +0 -90
  43. package/esm2022/lib/utils/formly.utils.mjs +0 -105
  44. package/esm2022/lib/validators/custom-email-validator.mjs +0 -18
  45. package/esm2022/lib/validators/ein-validators.mjs +0 -11
  46. package/esm2022/lib/validators/gst-validator.mjs +0 -11
  47. package/esm2022/lib/validators/normal-email-validator.mjs +0 -17
  48. package/esm2022/lib/validators/npi-validator.mjs +0 -11
  49. package/esm2022/lib/validators/pan-validator.mjs +0 -11
  50. package/esm2022/lib/validators/phone-number-validator.mjs +0 -22
  51. package/esm2022/lib/validators/select-validator.mjs +0 -7
  52. package/esm2022/lib/validators/tinSsn-validator.mjs +0 -12
  53. package/esm2022/lib/workflow-status/ workflow-status.module.mjs +0 -52
  54. package/esm2022/lib/workflow-status/workflow-status.component.mjs +0 -70
  55. package/esm2022/lib/wrappers/form-field-description-wrapper.component.mjs +0 -44
  56. package/esm2022/lib/wrappers/form-field-wrapper.component.mjs +0 -34
  57. package/esm2022/lib/wrappers/formly-wrapper-with-old-value.component.mjs +0 -140
  58. package/esm2022/lib/wrappers/prefix-suffix-wrapper.component.mjs +0 -95
  59. package/esm2022/lib/wrappers/prefix-sufix-extension.component.mjs +0 -9
  60. package/esm2022/muraai-mnl-form.mjs +0 -5
  61. package/esm2022/public-api.mjs +0 -12
@@ -1,247 +0,0 @@
1
- import { CommonModule } from '@angular/common';
2
- import { ChangeDetectionStrategy, Component, ViewChild, } from '@angular/core';
3
- import { FormControl, ReactiveFormsModule } from '@angular/forms';
4
- import { MatAutocompleteModule, MatAutocompleteTrigger, } from '@angular/material/autocomplete';
5
- import { MatButtonModule } from '@angular/material/button';
6
- import { MatCheckboxModule } from '@angular/material/checkbox';
7
- import { MatChipsModule } from '@angular/material/chips';
8
- import { MatFormFieldModule } from '@angular/material/form-field';
9
- import { MatIconModule } from '@angular/material/icon';
10
- import { MatInputModule } from '@angular/material/input';
11
- import { MatTooltipModule } from '@angular/material/tooltip';
12
- import { CommonsModule } from '@muraai/mnl-commons';
13
- import { FieldType, FormlyModule } from '@ngx-formly/core';
14
- import { TranslateModule } from '@ngx-translate/core';
15
- import { combineLatest, of } from 'rxjs';
16
- import { catchError, debounceTime, distinctUntilChanged, map, startWith, switchMap, take } from 'rxjs/operators';
17
- import * as i0 from "@angular/core";
18
- import * as i1 from "@angular/common";
19
- import * as i2 from "@angular/material/chips";
20
- import * as i3 from "@angular/material/icon";
21
- import * as i4 from "@angular/material/form-field";
22
- import * as i5 from "@angular/material/autocomplete";
23
- import * as i6 from "@angular/material/core";
24
- import * as i7 from "@angular/material/checkbox";
25
- import * as i8 from "@ngx-formly/core";
26
- import * as i9 from "@angular/forms";
27
- import * as i10 from "@angular/material/tooltip";
28
- export class FormlyMultiSelectCheckboxAutocompleteComponent extends FieldType {
29
- constructor() {
30
- super(...arguments);
31
- this.searchControl = new FormControl();
32
- this.optionsList = [];
33
- }
34
- ngOnInit() {
35
- const debounce = this.field.props.debounceTime || 300;
36
- const fetchOnce = this.field.props.fetchOnce === undefined ? true : this.field.props.fetchOnce;
37
- if (this.field.props.apiFunction && typeof this.field.props.apiFunction === 'function') {
38
- if (fetchOnce) {
39
- this.field.props
40
- .apiFunction('')
41
- .pipe(catchError((error) => {
42
- console.error('API Error:', error);
43
- return of([]);
44
- }))
45
- .subscribe((results) => {
46
- this.optionsList = results || [];
47
- this.filteredOptions = this.searchControl.valueChanges.pipe(startWith(''), debounceTime(debounce), distinctUntilChanged(), map((searchTerm) => this.filterOptions(searchTerm)));
48
- });
49
- }
50
- else {
51
- this.filteredOptions = this.searchControl.valueChanges.pipe(startWith(''), debounceTime(debounce), distinctUntilChanged(), switchMap((searchTerm) => {
52
- return this.field.props.apiFunction(searchTerm).pipe(map((results) => {
53
- this.optionsList = results || [];
54
- return results || [];
55
- }), catchError((error) => {
56
- console.error('API Error:', error);
57
- return of([]);
58
- }));
59
- }));
60
- }
61
- }
62
- else if (Array.isArray(this.field.props.options)) {
63
- this.optionsList = this.field.props.options;
64
- this.filteredOptions = this.searchControl.valueChanges.pipe(startWith(''), debounceTime(debounce), map((searchTerm) => this.filterOptions(searchTerm)));
65
- }
66
- else {
67
- const options$ = this.field.props.options;
68
- options$.pipe(take(1)).subscribe((opts) => {
69
- this.optionsList = opts || [];
70
- });
71
- options$.subscribe((opts) => (this.optionsList = opts || []));
72
- this.filteredOptions = combineLatest([
73
- this.searchControl.valueChanges.pipe(startWith(''), debounceTime(debounce)),
74
- options$,
75
- ]).pipe(map(([searchTerm, options]) => this.filterOptions(searchTerm)));
76
- }
77
- }
78
- onKeydown(event) {
79
- if (event.key === 'Enter') {
80
- event.preventDefault();
81
- }
82
- }
83
- filterOptions(searchTerm) {
84
- const list = this.optionsList || [];
85
- const term = (searchTerm || '').toLowerCase();
86
- return list.filter(option => (option.label || '').toLowerCase().includes(term));
87
- }
88
- onCheckboxChange(event, value) {
89
- const currentValue = this.formControl.value || [];
90
- if (event.checked) {
91
- this.formControl.setValue([...currentValue, value]);
92
- }
93
- else {
94
- this.formControl.setValue(currentValue.filter((v) => v !== value));
95
- }
96
- this.trigger.openPanel();
97
- }
98
- toggleSelection(event, value) {
99
- if (this.isSelected(value)) {
100
- this.removeOption(value);
101
- }
102
- else {
103
- this.formControl.setValue([...this.formControl.value, value]);
104
- }
105
- this.searchControl.setValue('');
106
- this.trigger.openPanel();
107
- }
108
- isSelected(value) {
109
- return ((this.formControl.value && this.formControl.value.includes(value)) ||
110
- false);
111
- }
112
- removeOption(value) {
113
- const values = this.formControl.value;
114
- const opts = values.filter((val) => val !== value);
115
- this.formControl.setValue(opts);
116
- }
117
- removeChip(chipIndex) {
118
- const value = this.formControl.value;
119
- this.formControl.setValue([
120
- ...value.slice(0, chipIndex),
121
- ...value.slice(chipIndex + 1, value.length),
122
- ]);
123
- this.formControl.markAsTouched();
124
- }
125
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FormlyMultiSelectCheckboxAutocompleteComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
126
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: FormlyMultiSelectCheckboxAutocompleteComponent, isStandalone: true, selector: "mu-multi-checkbox-autocomplete", providers: [MatAutocompleteTrigger], viewQueries: [{ propertyName: "trigger", first: true, predicate: MatAutocompleteTrigger, descendants: true }], usesInheritance: true, ngImport: i0, template: `
127
- <mat-form-field class="w-full" appearance="outline">
128
- <mat-label
129
- >{{ field.props.label }}
130
- <span *ngIf="field.props.required">*</span>
131
- </mat-label>
132
- <mat-chip-grid
133
- #chipGrid
134
- [formControl]="formControl"
135
- [formlyAttributes]="field"
136
- >
137
- @for (chip of formControl.value; track $index; let chipIndex= $index) {
138
- <mat-chip-row (removed)="removeChip(chipIndex)"
139
- [matTooltip]="chip">
140
- {{ chip }}
141
- <button matChipRemove [attr.aria-label]="'remove ' + chip">
142
- <mat-icon>cancel</mat-icon>
143
- </button>
144
- </mat-chip-row>
145
- }
146
- </mat-chip-grid>
147
- <input
148
- [formControl]="searchControl"
149
- [matChipInputFor]="chipGrid"
150
- [matAutocomplete]="auto"
151
- [readonly]="field.props.readonly"
152
- [required]="field.props.required || false"
153
- (keydown)="onKeydown($event)"
154
- (focus)="trigger.openPanel()"
155
- />
156
- <mat-autocomplete #auto="matAutocomplete">
157
- <mat-option
158
- *ngFor="let option of filteredOptions | async"
159
- [value]="option.label"
160
- (click)="toggleSelection($event, option.label)"
161
- >
162
- <mat-checkbox
163
- (click)="$event.stopPropagation()"
164
- (change)="onCheckboxChange($event, option.label)"
165
- [checked]="isSelected(option.label)"
166
- >
167
- {{ option.label }}
168
- </mat-checkbox>
169
- </mat-option>
170
- </mat-autocomplete>
171
- <mat-error *ngIf="formControl.invalid && formControl.touched">
172
- {{ field.validation?.messages?.['required'] }}
173
- </mat-error>
174
- </mat-form-field>
175
- `, isInline: true, styles: [".selected-chips{margin-top:10px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "ngmodule", type: CommonsModule }, { kind: "ngmodule", type: MatChipsModule }, { kind: "component", type: i2.MatChipGrid, selector: "mat-chip-grid", inputs: ["disabled", "placeholder", "required", "value", "errorStateMatcher"], outputs: ["change", "valueChange"] }, { kind: "directive", type: i2.MatChipInput, selector: "input[matChipInputFor]", inputs: ["matChipInputFor", "matChipInputAddOnBlur", "matChipInputSeparatorKeyCodes", "placeholder", "id", "disabled"], outputs: ["matChipInputTokenEnd"], exportAs: ["matChipInput", "matChipInputFor"] }, { kind: "directive", type: i2.MatChipRemove, selector: "[matChipRemove]" }, { kind: "component", type: i2.MatChipRow, selector: "mat-chip-row, [mat-chip-row], mat-basic-chip-row, [mat-basic-chip-row]", inputs: ["editable"], outputs: ["edited"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLabel, selector: "mat-label" }, { kind: "directive", type: i4.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "ngmodule", type: MatAutocompleteModule }, { kind: "component", type: i5.MatAutocomplete, selector: "mat-autocomplete", inputs: ["aria-label", "aria-labelledby", "displayWith", "autoActiveFirstOption", "autoSelectActiveOption", "requireSelection", "panelWidth", "disableRipple", "class", "hideSingleSelectionIndicator"], outputs: ["optionSelected", "opened", "closed", "optionActivated"], exportAs: ["matAutocomplete"] }, { kind: "component", type: i6.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "directive", type: i5.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", inputs: ["matAutocomplete", "matAutocompletePosition", "matAutocompleteConnectedTo", "autocomplete", "matAutocompleteDisabled"], exportAs: ["matAutocompleteTrigger"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "ngmodule", type: MatCheckboxModule }, { kind: "component", type: i7.MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "disabledInteractive", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "ngmodule", type: FormlyModule }, { kind: "directive", type: i8.ɵFormlyAttributes, selector: "[formlyAttributes]", inputs: ["formlyAttributes", "id"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i9.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: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i9.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i9.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i10.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
176
- }
177
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FormlyMultiSelectCheckboxAutocompleteComponent, decorators: [{
178
- type: Component,
179
- args: [{ selector: 'mu-multi-checkbox-autocomplete', standalone: true, imports: [
180
- CommonModule,
181
- CommonsModule,
182
- MatChipsModule,
183
- MatButtonModule,
184
- MatIconModule,
185
- MatInputModule,
186
- MatAutocompleteModule,
187
- TranslateModule,
188
- MatCheckboxModule,
189
- FormlyModule,
190
- ReactiveFormsModule,
191
- MatFormFieldModule,
192
- MatTooltipModule
193
- ], providers: [MatAutocompleteTrigger], template: `
194
- <mat-form-field class="w-full" appearance="outline">
195
- <mat-label
196
- >{{ field.props.label }}
197
- <span *ngIf="field.props.required">*</span>
198
- </mat-label>
199
- <mat-chip-grid
200
- #chipGrid
201
- [formControl]="formControl"
202
- [formlyAttributes]="field"
203
- >
204
- @for (chip of formControl.value; track $index; let chipIndex= $index) {
205
- <mat-chip-row (removed)="removeChip(chipIndex)"
206
- [matTooltip]="chip">
207
- {{ chip }}
208
- <button matChipRemove [attr.aria-label]="'remove ' + chip">
209
- <mat-icon>cancel</mat-icon>
210
- </button>
211
- </mat-chip-row>
212
- }
213
- </mat-chip-grid>
214
- <input
215
- [formControl]="searchControl"
216
- [matChipInputFor]="chipGrid"
217
- [matAutocomplete]="auto"
218
- [readonly]="field.props.readonly"
219
- [required]="field.props.required || false"
220
- (keydown)="onKeydown($event)"
221
- (focus)="trigger.openPanel()"
222
- />
223
- <mat-autocomplete #auto="matAutocomplete">
224
- <mat-option
225
- *ngFor="let option of filteredOptions | async"
226
- [value]="option.label"
227
- (click)="toggleSelection($event, option.label)"
228
- >
229
- <mat-checkbox
230
- (click)="$event.stopPropagation()"
231
- (change)="onCheckboxChange($event, option.label)"
232
- [checked]="isSelected(option.label)"
233
- >
234
- {{ option.label }}
235
- </mat-checkbox>
236
- </mat-option>
237
- </mat-autocomplete>
238
- <mat-error *ngIf="formControl.invalid && formControl.touched">
239
- {{ field.validation?.messages?.['required'] }}
240
- </mat-error>
241
- </mat-form-field>
242
- `, changeDetection: ChangeDetectionStrategy.OnPush, styles: [".selected-chips{margin-top:10px}\n"] }]
243
- }], propDecorators: { trigger: [{
244
- type: ViewChild,
245
- args: [MatAutocompleteTrigger]
246
- }] } });
247
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-select-checkbox.component.js","sourceRoot":"","sources":["../../../../../../libs/form/src/lib/types/multi-select-checkbox.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  OnInit,\n  ViewChild,\n} from '@angular/core';\nimport { FormControl, ReactiveFormsModule } from '@angular/forms';\nimport {\n  MatAutocompleteModule,\n  MatAutocompleteTrigger,\n} from '@angular/material/autocomplete';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatCheckboxModule } from '@angular/material/checkbox';\nimport { MatChipsModule } from '@angular/material/chips';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { CommonsModule } from '@muraai/mnl-commons';\nimport { FieldType, FieldTypeConfig, FormlyModule } from '@ngx-formly/core';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { combineLatest, Observable, of } from 'rxjs';\nimport { catchError, debounceTime, distinctUntilChanged, map, startWith, switchMap, take } from 'rxjs/operators';\n\n@Component({\n  selector: 'mu-multi-checkbox-autocomplete',\n  standalone: true,\n  imports: [\n    CommonModule,\n    CommonsModule,\n    MatChipsModule,\n    MatButtonModule,\n    MatIconModule,\n    MatInputModule,\n    MatAutocompleteModule,\n    TranslateModule,\n    MatCheckboxModule,\n    FormlyModule,\n    ReactiveFormsModule,\n    MatFormFieldModule,\n    MatTooltipModule\n  ],\n  providers: [MatAutocompleteTrigger],\n  template: `\n    <mat-form-field class=\"w-full\" appearance=\"outline\">\n      <mat-label\n        >{{ field.props.label }}\n        <span *ngIf=\"field.props.required\">*</span>\n      </mat-label>\n      <mat-chip-grid\n        #chipGrid\n        [formControl]=\"formControl\"\n        [formlyAttributes]=\"field\"\n      >\n        @for (chip of formControl.value; track $index; let chipIndex= $index) {\n        <mat-chip-row (removed)=\"removeChip(chipIndex)\"\n        [matTooltip]=\"chip\">\n          {{ chip }}\n          <button matChipRemove [attr.aria-label]=\"'remove ' + chip\">\n            <mat-icon>cancel</mat-icon>\n          </button>\n        </mat-chip-row>\n        }\n      </mat-chip-grid>\n      <input\n        [formControl]=\"searchControl\"\n        [matChipInputFor]=\"chipGrid\"\n        [matAutocomplete]=\"auto\"\n        [readonly]=\"field.props.readonly\"\n        [required]=\"field.props.required || false\"\n        (keydown)=\"onKeydown($event)\"\n        (focus)=\"trigger.openPanel()\"\n      />\n      <mat-autocomplete #auto=\"matAutocomplete\">\n        <mat-option\n          *ngFor=\"let option of filteredOptions | async\"\n          [value]=\"option.label\"\n          (click)=\"toggleSelection($event, option.label)\"\n        >\n          <mat-checkbox\n            (click)=\"$event.stopPropagation()\"\n            (change)=\"onCheckboxChange($event, option.label)\"\n            [checked]=\"isSelected(option.label)\"\n          >\n            {{ option.label }}\n          </mat-checkbox>\n        </mat-option>\n      </mat-autocomplete>\n      <mat-error *ngIf=\"formControl.invalid && formControl.touched\">\n        {{ field.validation?.messages?.['required'] }}\n      </mat-error>\n    </mat-form-field>\n  `,\n  styles: `\n    .selected-chips {\n        margin-top: 10px;\n    }\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class FormlyMultiSelectCheckboxAutocompleteComponent\n  extends FieldType<FieldTypeConfig>\n  implements OnInit\n{\n  searchControl = new FormControl();\n  filteredOptions!: Observable<any>;\n  protected optionsList: any[] = [];\n\n  @ViewChild(MatAutocompleteTrigger) trigger!: MatAutocompleteTrigger;\n\n  ngOnInit() {\n    const debounce = this.field.props.debounceTime || 300;\n    const fetchOnce =\n      this.field.props.fetchOnce === undefined ? true : this.field.props.fetchOnce;\n\n    if (this.field.props.apiFunction && typeof this.field.props.apiFunction === 'function') {\n      if (fetchOnce) {\n       this.field.props\n    .apiFunction('')\n    .pipe(\n      catchError((error) => {\n        console.error('API Error:', error);\n        return of([]);\n      })\n    )\n    .subscribe((results: any[]) => {\n      this.optionsList = results || [];\n\n      this.filteredOptions = this.searchControl.valueChanges.pipe(\n        startWith(''),\n        debounceTime(debounce),\n        distinctUntilChanged(),\n        map((searchTerm: string) => this.filterOptions(searchTerm))\n      );      \n    });\n      } else {\n        this.filteredOptions = this.searchControl.valueChanges.pipe(\n          startWith(''),\n          debounceTime(debounce),\n          distinctUntilChanged(),\n          switchMap((searchTerm: any) => {\n            return this.field.props.apiFunction(searchTerm).pipe(\n              map((results: any[]) => {\n                this.optionsList = results || [];\n                return results || [];\n              }),\n              catchError((error) => {\n                console.error('API Error:', error);\n                return of([]);\n              })\n            );\n          })\n        );\n      }\n    }\n    else if (Array.isArray(this.field.props.options)) {\n      this.optionsList = this.field.props.options;\n      this.filteredOptions = this.searchControl.valueChanges.pipe(\n        startWith(''),\n        debounceTime(debounce),\n        map((searchTerm) => this.filterOptions(searchTerm))\n      );\n    }\n    else {\n      const options$ = this.field.props.options as Observable<any[]>;\n\n      options$.pipe(take(1)).subscribe((opts) => {\n        this.optionsList = opts || [];\n      });\n\n      options$.subscribe((opts) => (this.optionsList = opts || []));\n\n      this.filteredOptions = combineLatest([\n        this.searchControl.valueChanges.pipe(\n          startWith(''),\n          debounceTime(debounce)\n        ),\n        options$,\n      ]).pipe(\n        map(([searchTerm, options]: [string, any[]]) =>\n          this.filterOptions(searchTerm)\n        )\n      );\n    }\n  }\n\n  onKeydown(event: KeyboardEvent) {\n    if (event.key === 'Enter') {\n      event.preventDefault();\n    }\n  }\n\n  private filterOptions(searchTerm: string) {\n  const list = this.optionsList || [];\n  const term = (searchTerm || '').toLowerCase();\n\n  return list.filter(option =>\n    (option.label || '').toLowerCase().includes(term)\n  );\n}\n\n  onCheckboxChange(event: any, value: any) {\n    const currentValue = this.formControl.value || [];\n    if (event.checked) {\n      this.formControl.setValue([...currentValue, value]);\n    } else {\n      this.formControl.setValue(currentValue.filter((v: any) => v !== value));\n    }\n    this.trigger.openPanel();\n  }\n\n  toggleSelection(event: any, value: any) {\n    if (this.isSelected(value)) {\n      this.removeOption(value);\n    } else {\n      this.formControl.setValue([...this.formControl.value, value]);\n    }\n    this.searchControl.setValue('');\n    this.trigger.openPanel();\n  }\n\n  isSelected(value: any): boolean {\n    return (\n      (this.formControl.value && this.formControl.value.includes(value)) ||\n      false\n    );\n  }\n\n  removeOption(value: any) {\n    const values = this.formControl.value;\n    const opts = values.filter((val: any) => val !== value);\n    this.formControl.setValue(opts);\n  }\n\n  removeChip(chipIndex: number): void {\n    const value = this.formControl.value;\n    this.formControl.setValue([\n      ...value.slice(0, chipIndex),\n      ...value.slice(chipIndex + 1, value.length),\n    ]);\n    this.formControl.markAsTouched();\n  }\n}\n"]}
@@ -1,71 +0,0 @@
1
- import { CommonModule } from '@angular/common';
2
- import { Component } from '@angular/core';
3
- import { FieldType } from '@ngx-formly/core';
4
- import { FormlyModule } from '@ngx-formly/core';
5
- import { FormlyMaterialModule } from '@ngx-formly/material';
6
- import { ReactiveFormsModule } from '@angular/forms';
7
- import { MatRadioModule } from '@angular/material/radio';
8
- import { MatFormFieldModule } from '@angular/material/form-field';
9
- import * as i0 from "@angular/core";
10
- import * as i1 from "@angular/common";
11
- import * as i2 from "@ngx-formly/core";
12
- import * as i3 from "@angular/forms";
13
- import * as i4 from "@angular/material/radio";
14
- import * as i5 from "@angular/material/form-field";
15
- export class CustomFormlyRadioComponent extends FieldType {
16
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CustomFormlyRadioComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
17
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: CustomFormlyRadioComponent, isStandalone: true, selector: "mu-radio", usesInheritance: true, ngImport: i0, template: `
18
- <mat-radio-group [formControl]="formControl" [formlyAttributes]="field">
19
- <div class="flex-col">
20
- <div class="flex justify-between">
21
- <label *ngIf="to.label" [class.text-red-600]="to.required && formControl.touched && formControl.invalid">{{ to.label }}
22
- <span *ngIf="to.required">*</span></label>
23
- <div class="flex space-x-4">
24
- <mat-radio-button *ngFor="let option of to['radioOptions']" [value]="option.value" [disabled]="to.disabled">
25
- {{ option.label }}
26
- </mat-radio-button>
27
- </div>
28
- </div>
29
- <mat-error *ngIf="formControl.invalid && formControl.touched">
30
- {{ field.validation?.messages?.['required'] }}
31
- </mat-error>
32
- </div>
33
-
34
- </mat-radio-group>
35
- `, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: FormlyModule }, { kind: "directive", type: i2.ɵFormlyAttributes, selector: "[formlyAttributes]", inputs: ["formlyAttributes", "id"] }, { kind: "ngmodule", type: FormlyMaterialModule }, { kind: "ngmodule", type: ReactiveFormsModule }, { 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: MatRadioModule }, { kind: "directive", type: i4.MatRadioGroup, selector: "mat-radio-group", inputs: ["color", "name", "labelPosition", "value", "selected", "disabled", "required", "disabledInteractive"], outputs: ["change"], exportAs: ["matRadioGroup"] }, { kind: "component", type: i4.MatRadioButton, selector: "mat-radio-button", inputs: ["id", "name", "aria-label", "aria-labelledby", "aria-describedby", "disableRipple", "tabIndex", "checked", "value", "labelPosition", "disabled", "required", "color", "disabledInteractive"], outputs: ["change"], exportAs: ["matRadioButton"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "directive", type: i5.MatError, selector: "mat-error, [matError]", inputs: ["id"] }] }); }
36
- }
37
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CustomFormlyRadioComponent, decorators: [{
38
- type: Component,
39
- args: [{
40
- selector: 'mu-radio',
41
- standalone: true,
42
- imports: [
43
- CommonModule,
44
- FormlyModule,
45
- FormlyMaterialModule,
46
- ReactiveFormsModule,
47
- MatRadioModule,
48
- MatFormFieldModule
49
- ],
50
- template: `
51
- <mat-radio-group [formControl]="formControl" [formlyAttributes]="field">
52
- <div class="flex-col">
53
- <div class="flex justify-between">
54
- <label *ngIf="to.label" [class.text-red-600]="to.required && formControl.touched && formControl.invalid">{{ to.label }}
55
- <span *ngIf="to.required">*</span></label>
56
- <div class="flex space-x-4">
57
- <mat-radio-button *ngFor="let option of to['radioOptions']" [value]="option.value" [disabled]="to.disabled">
58
- {{ option.label }}
59
- </mat-radio-button>
60
- </div>
61
- </div>
62
- <mat-error *ngIf="formControl.invalid && formControl.touched">
63
- {{ field.validation?.messages?.['required'] }}
64
- </mat-error>
65
- </div>
66
-
67
- </mat-radio-group>
68
- `,
69
- }]
70
- }] });
71
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFkaW8udHlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvZm9ybS9zcmMvbGliL3R5cGVzL3JhZGlvLnR5cGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFDbEQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxZQUFZLEVBQW1CLE1BQU0sa0JBQWtCLENBQUM7QUFDakUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDNUQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDckQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDhCQUE4QixDQUFDOzs7Ozs7O0FBaUNsRSxNQUFNLE9BQU8sMEJBQTJCLFNBQVEsU0FBMEI7K0dBQTdELDBCQUEwQjttR0FBMUIsMEJBQTBCLDJGQXBCekI7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQWtCWCwyREF6QkssWUFBWSwrUEFDWixZQUFZLHFKQUNaLG9CQUFvQiw4QkFDcEIsbUJBQW1CLHlUQUNuQixjQUFjLG9sQkFDZCxrQkFBa0I7OzRGQXNCYiwwQkFBMEI7a0JBL0J0QyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxVQUFVO29CQUNwQixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsT0FBTyxFQUFFO3dCQUNMLFlBQVk7d0JBQ1osWUFBWTt3QkFDWixvQkFBb0I7d0JBQ3BCLG1CQUFtQjt3QkFDbkIsY0FBYzt3QkFDZCxrQkFBa0I7cUJBQ3JCO29CQUNELFFBQVEsRUFBRTs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBa0JYO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGaWVsZFR5cGUgfSBmcm9tICdAbmd4LWZvcm1seS9jb3JlJztcbmltcG9ydCB7IEZvcm1seU1vZHVsZSwgRmllbGRUeXBlQ29uZmlnIH0gZnJvbSAnQG5neC1mb3JtbHkvY29yZSc7XG5pbXBvcnQgeyBGb3JtbHlNYXRlcmlhbE1vZHVsZSB9IGZyb20gJ0BuZ3gtZm9ybWx5L21hdGVyaWFsJztcbmltcG9ydCB7IFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBNYXRSYWRpb01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3JhZGlvJztcbmltcG9ydCB7IE1hdEZvcm1GaWVsZE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGQnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ211LXJhZGlvJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxuICAgICAgICBGb3JtbHlNb2R1bGUsXG4gICAgICAgIEZvcm1seU1hdGVyaWFsTW9kdWxlLFxuICAgICAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxuICAgICAgICBNYXRSYWRpb01vZHVsZSxcbiAgICAgICAgTWF0Rm9ybUZpZWxkTW9kdWxlXG4gICAgXSxcbiAgICB0ZW1wbGF0ZTogYFxuICAgPG1hdC1yYWRpby1ncm91cCBbZm9ybUNvbnRyb2xdPVwiZm9ybUNvbnRyb2xcIiBbZm9ybWx5QXR0cmlidXRlc109XCJmaWVsZFwiPlxuICAgIDxkaXYgY2xhc3M9XCJmbGV4LWNvbFwiPlxuICAgICAgICA8ZGl2IGNsYXNzPVwiZmxleCBqdXN0aWZ5LWJldHdlZW5cIj5cbiAgICAgICAgICAgIDxsYWJlbCAqbmdJZj1cInRvLmxhYmVsXCIgIFtjbGFzcy50ZXh0LXJlZC02MDBdPVwidG8ucmVxdWlyZWQgJiYgZm9ybUNvbnRyb2wudG91Y2hlZCAmJiBmb3JtQ29udHJvbC5pbnZhbGlkXCI+e3sgdG8ubGFiZWwgfX1cbiAgICAgICAgICAgIDxzcGFuICpuZ0lmPVwidG8ucmVxdWlyZWRcIj4qPC9zcGFuPjwvbGFiZWw+XG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwiZmxleCBzcGFjZS14LTRcIj5cbiAgICAgICAgICAgICAgICA8bWF0LXJhZGlvLWJ1dHRvbiAqbmdGb3I9XCJsZXQgb3B0aW9uIG9mIHRvWydyYWRpb09wdGlvbnMnXVwiIFt2YWx1ZV09XCJvcHRpb24udmFsdWVcIiBbZGlzYWJsZWRdPVwidG8uZGlzYWJsZWRcIj5cbiAgICAgICAgICAgICAgICB7eyBvcHRpb24ubGFiZWwgfX1cbiAgICAgICAgICAgICAgICA8L21hdC1yYWRpby1idXR0b24+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxtYXQtZXJyb3IgKm5nSWY9XCJmb3JtQ29udHJvbC5pbnZhbGlkICYmIGZvcm1Db250cm9sLnRvdWNoZWRcIj5cbiAgICAgICAgICAgIHt7IGZpZWxkLnZhbGlkYXRpb24/Lm1lc3NhZ2VzPy5bJ3JlcXVpcmVkJ10gfX1cbiAgICAgICAgPC9tYXQtZXJyb3I+XG4gICAgPC9kaXY+XG4gICAgXG4gICAgPC9tYXQtcmFkaW8tZ3JvdXA+XG4gIGAsXG59KVxuZXhwb3J0IGNsYXNzIEN1c3RvbUZvcm1seVJhZGlvQ29tcG9uZW50IGV4dGVuZHMgRmllbGRUeXBlPEZpZWxkVHlwZUNvbmZpZz4ge1xufSJdfQ==
@@ -1,220 +0,0 @@
1
- import { CommonModule } from '@angular/common';
2
- import { Component, inject, ViewChild, } from '@angular/core';
3
- import { ReactiveFormsModule } from '@angular/forms';
4
- import { MatButtonModule } from '@angular/material/button';
5
- import { MatIconModule } from '@angular/material/icon';
6
- import { MatTabsModule, } from '@angular/material/tabs';
7
- import { MatTooltipModule } from '@angular/material/tooltip';
8
- import { Router } from '@angular/router';
9
- import { FieldType, } from '@ngx-formly/core';
10
- import { FormlyModule } from '@ngx-formly/core';
11
- import { TranslateModule } from '@ngx-translate/core';
12
- import * as i0 from "@angular/core";
13
- import * as i1 from "@angular/material/tabs";
14
- import * as i2 from "@ngx-formly/core";
15
- import * as i3 from "@angular/common";
16
- import * as i4 from "@ngx-translate/core";
17
- import * as i5 from "@angular/material/icon";
18
- import * as i6 from "@angular/material/tooltip";
19
- export class FormlyFieldScrollableTabsComponent extends FieldType {
20
- constructor(ngZone) {
21
- super();
22
- this.ngZone = ngZone;
23
- this.router = inject(Router);
24
- this.selectedIndex = 0;
25
- }
26
- nextTab(tabGroup) {
27
- if (tabGroup && tabGroup.selectedIndex != null) {
28
- const currentIndex = tabGroup.selectedIndex;
29
- if (currentIndex < (tabGroup._tabs?.length || 0) - 1) {
30
- tabGroup.selectedIndex = currentIndex + 1;
31
- }
32
- }
33
- }
34
- previousTab(tabGroup) {
35
- if (tabGroup && tabGroup.selectedIndex != null) {
36
- const currentIndex = tabGroup.selectedIndex;
37
- if (currentIndex > 0) {
38
- tabGroup.selectedIndex = currentIndex - 1;
39
- }
40
- }
41
- }
42
- isFirstTab(tabGroup) {
43
- return tabGroup && tabGroup.selectedIndex === 0;
44
- }
45
- isLastTab(tabGroup) {
46
- return (tabGroup && tabGroup.selectedIndex === (tabGroup._tabs?.length || 0) - 1);
47
- }
48
- ngOnInit() {
49
- this.user = JSON.parse(localStorage.getItem('loggedInUser') || '{}');
50
- }
51
- isValid(field) {
52
- if (field.key) {
53
- if (field.props?.excludeValidation)
54
- return true;
55
- return field?.formControl?.valid || false;
56
- }
57
- return field.fieldGroup
58
- ? field.fieldGroup.every((f) => this.isValid(f))
59
- : true;
60
- }
61
- onTabChange(event) {
62
- this.selectedIndex = event.index;
63
- console.log('Selected tab index:', this.selectedIndex);
64
- if (this.field && this.field.props?.['tabChange']) {
65
- this.field.props?.['tabChange'](event, this.field);
66
- }
67
- }
68
- onTabIndexChange(index) {
69
- const targetElement = document.getElementById(`tab-${index}`);
70
- if (targetElement) {
71
- targetElement.scrollIntoView({ behavior: 'smooth', block: 'start' });
72
- }
73
- }
74
- onScroll(event) {
75
- clearTimeout(this.debounceTimeout);
76
- this.debounceTimeout = setTimeout(() => {
77
- const scrollContainer = event.target;
78
- const scrollTop = scrollContainer.scrollTop;
79
- this.ngZone.run(() => {
80
- if (this.field.fieldGroup) {
81
- for (let index = 0; index < this.field.fieldGroup?.length; index++) {
82
- const tabElement = document.getElementById(`tab-${index}`);
83
- if (tabElement) {
84
- const tabTop = tabElement.offsetTop - scrollContainer.offsetTop;
85
- const tabHeight = tabElement.offsetHeight;
86
- if (scrollTop >= tabTop && scrollTop < tabTop + tabHeight) {
87
- if (this.selectedIndex !== index) {
88
- this.selectedIndex = index;
89
- }
90
- break;
91
- }
92
- }
93
- }
94
- }
95
- });
96
- }, 100);
97
- }
98
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FormlyFieldScrollableTabsComponent, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
99
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: FormlyFieldScrollableTabsComponent, isStandalone: true, selector: "mu-formly-field-tabs1", viewQueries: [{ propertyName: "tabGroup", first: true, predicate: ["tabGroup"], descendants: true }, { propertyName: "tabContent", first: true, predicate: ["tabContent"], descendants: true }], usesInheritance: true, ngImport: i0, template: `
100
- <div class="tabs-container">
101
- <mat-tab-group
102
- class="sticky-tabs"
103
- [(selectedIndex)]="selectedIndex"
104
- (selectedIndexChange)="onTabIndexChange($event)"
105
- (selectedTabChange)="onTabChange($event)"
106
- >
107
- @for(tab of field.fieldGroup; track tab; let i = $index; let last =
108
- $last){
109
- <mat-tab>
110
- <ng-template mat-tab-label>
111
- <span
112
- [ngStyle]="{
113
- color:
114
- !isValid(field.fieldGroup ? field.fieldGroup[i] : {}) &&
115
- options.formState?.showValidationError
116
- ? 'red'
117
- : 'black'
118
- }"
119
- >
120
- {{ tab?.props?.label || '' }}
121
- </span>
122
- <mat-icon
123
- matTooltip="{{ 'MANDATORY_FIELDS_TOOLTIP' | translate }}"
124
- *ngIf="
125
- !isValid(field.fieldGroup ? field.fieldGroup[i] : {}) &&
126
- options.formState?.showValidationError
127
- "
128
- class="error-step"
129
- >error</mat-icon
130
- >
131
- </ng-template>
132
- </mat-tab>
133
- }
134
- </mat-tab-group>
135
-
136
- <div class="tab-content" (scroll)="onScroll($event)">
137
- <div
138
- *ngFor="let tab of field.fieldGroup; let i = index"
139
- [id]="'tab-' + i"
140
- class="tab-section"
141
- >
142
- <h2 class="tab-title" *ngIf="tab?.props?.label">
143
- {{ tab?.props?.label || '' }}
144
- </h2>
145
- <formly-field [field]="tab"></formly-field>
146
- </div>
147
- </div>
148
- </div>
149
- `, isInline: true, styles: [".tab-title{color:#00ae4d}.error-step{color:#d32f2f!important}.tabs-container{display:flex;flex-direction:column;height:100%;.sticky-tabs{position:sticky;z-index:1}.tab-content{flex:1;overflow-y:auto;padding:16px;.tab-section{margin-bottom:45px;border-bottom:2px solid #00ae4d;h2{margin:0 0 8px}.spacer{height:400px}}}}\n"], dependencies: [{ kind: "ngmodule", type: MatTabsModule }, { kind: "directive", type: i1.MatTabLabel, selector: "[mat-tab-label], [matTabLabel]" }, { kind: "component", type: i1.MatTab, selector: "mat-tab", inputs: ["disabled", "label", "aria-label", "aria-labelledby", "labelClass", "bodyClass"], exportAs: ["matTab"] }, { kind: "component", type: i1.MatTabGroup, selector: "mat-tab-group", inputs: ["color", "fitInkBarToContent", "mat-stretch-tabs", "dynamicHeight", "selectedIndex", "headerPosition", "animationDuration", "contentTabIndex", "disablePagination", "disableRipple", "preserveContent", "backgroundColor", "aria-label", "aria-labelledby"], outputs: ["selectedIndexChange", "focusChange", "animationDone", "selectedTabChange"], exportAs: ["matTabGroup"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "ngmodule", type: FormlyModule }, { kind: "component", type: i2.FormlyField, selector: "formly-field", inputs: ["field"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i4.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i6.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }] }); }
150
- }
151
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FormlyFieldScrollableTabsComponent, decorators: [{
152
- type: Component,
153
- args: [{ selector: 'mu-formly-field-tabs1', standalone: true, imports: [
154
- MatTabsModule,
155
- ReactiveFormsModule,
156
- FormlyModule,
157
- MatButtonModule,
158
- CommonModule,
159
- TranslateModule,
160
- MatIconModule,
161
- MatTooltipModule,
162
- ], template: `
163
- <div class="tabs-container">
164
- <mat-tab-group
165
- class="sticky-tabs"
166
- [(selectedIndex)]="selectedIndex"
167
- (selectedIndexChange)="onTabIndexChange($event)"
168
- (selectedTabChange)="onTabChange($event)"
169
- >
170
- @for(tab of field.fieldGroup; track tab; let i = $index; let last =
171
- $last){
172
- <mat-tab>
173
- <ng-template mat-tab-label>
174
- <span
175
- [ngStyle]="{
176
- color:
177
- !isValid(field.fieldGroup ? field.fieldGroup[i] : {}) &&
178
- options.formState?.showValidationError
179
- ? 'red'
180
- : 'black'
181
- }"
182
- >
183
- {{ tab?.props?.label || '' }}
184
- </span>
185
- <mat-icon
186
- matTooltip="{{ 'MANDATORY_FIELDS_TOOLTIP' | translate }}"
187
- *ngIf="
188
- !isValid(field.fieldGroup ? field.fieldGroup[i] : {}) &&
189
- options.formState?.showValidationError
190
- "
191
- class="error-step"
192
- >error</mat-icon
193
- >
194
- </ng-template>
195
- </mat-tab>
196
- }
197
- </mat-tab-group>
198
-
199
- <div class="tab-content" (scroll)="onScroll($event)">
200
- <div
201
- *ngFor="let tab of field.fieldGroup; let i = index"
202
- [id]="'tab-' + i"
203
- class="tab-section"
204
- >
205
- <h2 class="tab-title" *ngIf="tab?.props?.label">
206
- {{ tab?.props?.label || '' }}
207
- </h2>
208
- <formly-field [field]="tab"></formly-field>
209
- </div>
210
- </div>
211
- </div>
212
- `, styles: [".tab-title{color:#00ae4d}.error-step{color:#d32f2f!important}.tabs-container{display:flex;flex-direction:column;height:100%;.sticky-tabs{position:sticky;z-index:1}.tab-content{flex:1;overflow-y:auto;padding:16px;.tab-section{margin-bottom:45px;border-bottom:2px solid #00ae4d;h2{margin:0 0 8px}.spacer{height:400px}}}}\n"] }]
213
- }], ctorParameters: () => [{ type: i0.NgZone }], propDecorators: { tabGroup: [{
214
- type: ViewChild,
215
- args: ['tabGroup']
216
- }], tabContent: [{
217
- type: ViewChild,
218
- args: ['tabContent', { static: false }]
219
- }] } });
220
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scrollable-tabs.types.js","sourceRoot":"","sources":["../../../../../../libs/form/src/lib/types/scrollable-tabs.types.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  Component,\n  ElementRef,\n  inject,\n  NgZone,\n  OnInit,\n  ViewChild,\n} from '@angular/core';\nimport { ReactiveFormsModule } from '@angular/forms';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatIconModule } from '@angular/material/icon';\nimport {\n  MatTabChangeEvent,\n  MatTabGroup,\n  MatTabsModule,\n} from '@angular/material/tabs';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { Router } from '@angular/router';\nimport {\n  FieldType,\n  FieldTypeConfig,\n} from '@ngx-formly/core';\nimport { FormlyModule } from '@ngx-formly/core';\nimport { TranslateModule } from '@ngx-translate/core';\n\n@Component({\n  selector: 'mu-formly-field-tabs1',\n  standalone: true,\n  imports: [\n    MatTabsModule,\n    ReactiveFormsModule,\n    FormlyModule,\n    MatButtonModule,\n    CommonModule,\n    TranslateModule,\n    MatIconModule,\n    MatTooltipModule,\n  ],\n  template: `\n    <div class=\"tabs-container\">\n      <mat-tab-group\n        class=\"sticky-tabs\"\n        [(selectedIndex)]=\"selectedIndex\"\n        (selectedIndexChange)=\"onTabIndexChange($event)\"\n        (selectedTabChange)=\"onTabChange($event)\"\n      >\n        @for(tab of field.fieldGroup; track tab; let i = $index; let last =\n        $last){\n        <mat-tab>\n          <ng-template mat-tab-label>\n            <span\n              [ngStyle]=\"{\n                color:\n                  !isValid(field.fieldGroup ? field.fieldGroup[i] : {}) &&\n                  options.formState?.showValidationError\n                    ? 'red'\n                    : 'black'\n              }\"\n            >\n              {{ tab?.props?.label || '' }}\n            </span>\n            <mat-icon\n              matTooltip=\"{{ 'MANDATORY_FIELDS_TOOLTIP' | translate }}\"\n              *ngIf=\"\n                !isValid(field.fieldGroup ? field.fieldGroup[i] : {}) &&\n                options.formState?.showValidationError\n              \"\n              class=\"error-step\"\n              >error</mat-icon\n            >\n          </ng-template>\n        </mat-tab>\n        }\n      </mat-tab-group>\n\n      <div class=\"tab-content\" (scroll)=\"onScroll($event)\">\n        <div\n          *ngFor=\"let tab of field.fieldGroup; let i = index\"\n          [id]=\"'tab-' + i\"\n          class=\"tab-section\"\n        >\n          <h2 class=\"tab-title\" *ngIf=\"tab?.props?.label\">\n            {{ tab?.props?.label || '' }}\n          </h2>\n          <formly-field [field]=\"tab\"></formly-field>\n        </div>\n      </div>\n    </div>\n  `,\n  styles: [\n    `\n      .tab-title {\n        color: #00ae4d;\n      }\n      .error-step {\n        color: #d32f2f !important;\n      }\n      .tabs-container {\n        display: flex;\n        flex-direction: column;\n        height: 100%;\n\n        .sticky-tabs {\n          position: sticky;\n          z-index: 1;\n        }\n\n        .tab-content {\n          flex: 1;\n          overflow-y: auto;\n          padding: 16px;\n\n          .tab-section {\n            margin-bottom: 45px;\n            border-bottom: 2px solid #00ae4d;\n\n            h2 {\n              margin: 0 0 8px;\n            }\n\n            .spacer {\n              height: 400px;\n            }\n          }\n        }\n      }\n    `,\n  ],\n})\nexport class FormlyFieldScrollableTabsComponent\n  extends FieldType<FieldTypeConfig>\n  implements OnInit\n{\n  submittedData!: any[];\n\n  router = inject(Router);\n  user: any;\n  @ViewChild('tabGroup') tabGroup!: MatTabGroup;\n\n  selectedIndex = 0;\n  @ViewChild('tabContent', { static: false }) tabContent!: ElementRef;\n\n  private debounceTimeout: any;\n\n  constructor(private ngZone: NgZone) {\n    super();\n  }\n\n  nextTab(tabGroup: MatTabGroup) {\n    if (tabGroup && tabGroup.selectedIndex != null) {\n      const currentIndex = tabGroup.selectedIndex;\n      if (currentIndex < (tabGroup._tabs?.length || 0) - 1) {\n        tabGroup.selectedIndex = currentIndex + 1;\n      }\n    }\n  }\n\n  previousTab(tabGroup: MatTabGroup) {\n    if (tabGroup && tabGroup.selectedIndex != null) {\n      const currentIndex = tabGroup.selectedIndex;\n      if (currentIndex > 0) {\n        tabGroup.selectedIndex = currentIndex - 1;\n      }\n    }\n  }\n\n  isFirstTab(tabGroup: MatTabGroup): boolean {\n    return tabGroup && tabGroup.selectedIndex === 0;\n  }\n\n  isLastTab(tabGroup: MatTabGroup): boolean {\n    return (\n      tabGroup && tabGroup.selectedIndex === (tabGroup._tabs?.length || 0) - 1\n    );\n  }\n\n  ngOnInit(): void {\n    this.user = JSON.parse(localStorage.getItem('loggedInUser') || '{}');\n  }\n\n  isValid(field: any): boolean {\n    if (field.key) {\n      if (field.props?.excludeValidation) return true;\n      return field?.formControl?.valid || false;\n    }\n\n    return field.fieldGroup\n      ? field.fieldGroup.every((f: any) => this.isValid(f))\n      : true;\n  }\n\n  onTabChange(event: MatTabChangeEvent): void {\n    this.selectedIndex = event.index;\n    console.log('Selected tab index:', this.selectedIndex);\n    if (this.field && this.field.props?.['tabChange']) {\n      this.field.props?.['tabChange'](event, this.field);\n    }\n  }\n\n  onTabIndexChange(index: number) {\n    const targetElement = document.getElementById(`tab-${index}`);\n    if (targetElement) {\n      targetElement.scrollIntoView({ behavior: 'smooth', block: 'start' });\n    }\n  }\n\n  onScroll(event: Event): void {\n    clearTimeout(this.debounceTimeout);\n\n    this.debounceTimeout = setTimeout(() => {\n      const scrollContainer = event.target as HTMLElement;\n      const scrollTop = scrollContainer.scrollTop;\n\n      this.ngZone.run(() => {\n        if (this.field.fieldGroup) {\n          for (let index = 0; index < this.field.fieldGroup?.length; index++) {\n            const tabElement = document.getElementById(`tab-${index}`);\n            if (tabElement) {\n              const tabTop = tabElement.offsetTop - scrollContainer.offsetTop;\n\n              const tabHeight = tabElement.offsetHeight;\n\n              if (scrollTop >= tabTop && scrollTop < tabTop + tabHeight) {\n                if (this.selectedIndex !== index) {\n                  this.selectedIndex = index;\n                }\n                break;\n              }\n            }\n          }\n        }\n      });\n    }, 100);\n  }\n}\n"]}