@muraai/mnl-form 0.0.1-alpha-32ca3fa → 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.
- package/README.md +5 -5
- package/fesm2022/muraai-mnl-form.mjs +152 -145
- package/fesm2022/muraai-mnl-form.mjs.map +1 -1
- package/lib/{formly-lib/formly-lib.component.d.ts → mnl-form/mnl-form.component.d.ts} +3 -3
- package/lib/types/upload-file.d.ts +1 -1
- package/lib/workflow-status/ workflow-status.module.d.ts +8 -8
- package/lib/workflow-status/workflow-status.component.d.ts +1 -1
- package/package.json +4 -5
- package/public-api.d.ts +2 -2
- package/esm2022/lib/confirmation-dialog/confirmation-dialog.component.mjs +0 -34
- package/esm2022/lib/formly-lib/formly-lib.component.mjs +0 -199
- package/esm2022/lib/formly-lib/formly-standalone.module.mjs +0 -155
- package/esm2022/lib/models/custom-form-field.model.mjs +0 -2
- package/esm2022/lib/models/workflow-status.model.mjs +0 -2
- package/esm2022/lib/services/graphql.service.mjs +0 -30
- package/esm2022/lib/services/scoring.service.mjs +0 -103
- package/esm2022/lib/types/action-button-renderer.component.mjs +0 -59
- package/esm2022/lib/types/autocomplete-type.component.mjs +0 -68
- package/esm2022/lib/types/button.type.mjs +0 -72
- package/esm2022/lib/types/comments.type.mjs +0 -102
- package/esm2022/lib/types/country-code-input.type.mjs +0 -181
- package/esm2022/lib/types/custom-date.type.mjs +0 -20
- package/esm2022/lib/types/custom-input.component.mjs +0 -62
- package/esm2022/lib/types/date-format.type.mjs +0 -196
- package/esm2022/lib/types/expansion-panel.types.mjs +0 -85
- package/esm2022/lib/types/formly-field-panel.type.mjs +0 -70
- package/esm2022/lib/types/grid-actionable.type.mjs +0 -197
- package/esm2022/lib/types/grid-formly-cell.component.mjs +0 -42
- package/esm2022/lib/types/grid.type.mjs +0 -125
- package/esm2022/lib/types/input.type.mjs +0 -43
- package/esm2022/lib/types/mu-helper-text.type.mjs +0 -331
- package/esm2022/lib/types/multi-select-autocomplete.mjs +0 -139
- package/esm2022/lib/types/multi-select-checkbox.component.mjs +0 -247
- package/esm2022/lib/types/radio.type.mjs +0 -71
- package/esm2022/lib/types/scrollable-tabs.types.mjs +0 -220
- package/esm2022/lib/types/select-api-auto-complete.component.mjs +0 -111
- package/esm2022/lib/types/select-autocomplete-redefined.component.mjs +0 -142
- package/esm2022/lib/types/select-autocomplete.type.mjs +0 -254
- package/esm2022/lib/types/stepper.type.mjs +0 -268
- package/esm2022/lib/types/table.types.mjs +0 -79
- package/esm2022/lib/types/tabs.types.mjs +0 -293
- package/esm2022/lib/types/tabular-form-dialog.component.mjs +0 -331
- package/esm2022/lib/types/tabular-form.type.mjs +0 -641
- package/esm2022/lib/types/upload-file.mjs +0 -524
- package/esm2022/lib/types/view-file-dialog.component.mjs +0 -90
- package/esm2022/lib/utils/formly.utils.mjs +0 -105
- package/esm2022/lib/validators/custom-email-validator.mjs +0 -18
- package/esm2022/lib/validators/ein-validators.mjs +0 -11
- package/esm2022/lib/validators/gst-validator.mjs +0 -11
- package/esm2022/lib/validators/normal-email-validator.mjs +0 -17
- package/esm2022/lib/validators/npi-validator.mjs +0 -11
- package/esm2022/lib/validators/pan-validator.mjs +0 -11
- package/esm2022/lib/validators/phone-number-validator.mjs +0 -22
- package/esm2022/lib/validators/select-validator.mjs +0 -7
- package/esm2022/lib/validators/tinSsn-validator.mjs +0 -12
- package/esm2022/lib/workflow-status/ workflow-status.module.mjs +0 -52
- package/esm2022/lib/workflow-status/workflow-status.component.mjs +0 -70
- package/esm2022/lib/wrappers/form-field-description-wrapper.component.mjs +0 -44
- package/esm2022/lib/wrappers/form-field-wrapper.component.mjs +0 -34
- package/esm2022/lib/wrappers/formly-wrapper-with-old-value.component.mjs +0 -140
- package/esm2022/lib/wrappers/prefix-suffix-wrapper.component.mjs +0 -95
- package/esm2022/lib/wrappers/prefix-sufix-extension.component.mjs +0 -9
- package/esm2022/muraai-mnl-form.mjs +0 -5
- package/esm2022/public-api.mjs +0 -12
- /package/lib/{formly-lib/formly-standalone.module.d.ts → mnl-form/mnl-form-standalone.module.d.ts} +0 -0
|
@@ -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":["../../../../../../projects/form-lib/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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFkaW8udHlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Zvcm0tbGliL3NyYy9saWIvdHlwZXMvcmFkaW8udHlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUNsRCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDN0MsT0FBTyxFQUFFLFlBQVksRUFBbUIsTUFBTSxrQkFBa0IsQ0FBQztBQUNqRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUM1RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sOEJBQThCLENBQUM7Ozs7Ozs7QUFpQ2xFLE1BQU0sT0FBTywwQkFBMkIsU0FBUSxTQUEwQjsrR0FBN0QsMEJBQTBCO21HQUExQiwwQkFBMEIsMkZBcEJ6Qjs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBa0JYLDJEQXpCSyxZQUFZLCtQQUNaLFlBQVkscUpBQ1osb0JBQW9CLDhCQUNwQixtQkFBbUIseVRBQ25CLGNBQWMsb2xCQUNkLGtCQUFrQjs7NEZBc0JiLDBCQUEwQjtrQkEvQnRDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLFVBQVU7b0JBQ3BCLFVBQVUsRUFBRSxJQUFJO29CQUNoQixPQUFPLEVBQUU7d0JBQ0wsWUFBWTt3QkFDWixZQUFZO3dCQUNaLG9CQUFvQjt3QkFDcEIsbUJBQW1CO3dCQUNuQixjQUFjO3dCQUNkLGtCQUFrQjtxQkFDckI7b0JBQ0QsUUFBUSxFQUFFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FrQlg7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZpZWxkVHlwZSB9IGZyb20gJ0BuZ3gtZm9ybWx5L2NvcmUnO1xuaW1wb3J0IHsgRm9ybWx5TW9kdWxlLCBGaWVsZFR5cGVDb25maWcgfSBmcm9tICdAbmd4LWZvcm1seS9jb3JlJztcbmltcG9ydCB7IEZvcm1seU1hdGVyaWFsTW9kdWxlIH0gZnJvbSAnQG5neC1mb3JtbHkvbWF0ZXJpYWwnO1xuaW1wb3J0IHsgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IE1hdFJhZGlvTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvcmFkaW8nO1xuaW1wb3J0IHsgTWF0Rm9ybUZpZWxkTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZm9ybS1maWVsZCc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnbXUtcmFkaW8nLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsXG4gICAgICAgIEZvcm1seU1vZHVsZSxcbiAgICAgICAgRm9ybWx5TWF0ZXJpYWxNb2R1bGUsXG4gICAgICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXG4gICAgICAgIE1hdFJhZGlvTW9kdWxlLFxuICAgICAgICBNYXRGb3JtRmllbGRNb2R1bGVcbiAgICBdLFxuICAgIHRlbXBsYXRlOiBgXG4gICA8bWF0LXJhZGlvLWdyb3VwIFtmb3JtQ29udHJvbF09XCJmb3JtQ29udHJvbFwiIFtmb3JtbHlBdHRyaWJ1dGVzXT1cImZpZWxkXCI+XG4gICAgPGRpdiBjbGFzcz1cImZsZXgtY29sXCI+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJmbGV4IGp1c3RpZnktYmV0d2VlblwiPlxuICAgICAgICAgICAgPGxhYmVsICpuZ0lmPVwidG8ubGFiZWxcIiAgW2NsYXNzLnRleHQtcmVkLTYwMF09XCJ0by5yZXF1aXJlZCAmJiBmb3JtQ29udHJvbC50b3VjaGVkICYmIGZvcm1Db250cm9sLmludmFsaWRcIj57eyB0by5sYWJlbCB9fVxuICAgICAgICAgICAgPHNwYW4gKm5nSWY9XCJ0by5yZXF1aXJlZFwiPio8L3NwYW4+PC9sYWJlbD5cbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJmbGV4IHNwYWNlLXgtNFwiPlxuICAgICAgICAgICAgICAgIDxtYXQtcmFkaW8tYnV0dG9uICpuZ0Zvcj1cImxldCBvcHRpb24gb2YgdG9bJ3JhZGlvT3B0aW9ucyddXCIgW3ZhbHVlXT1cIm9wdGlvbi52YWx1ZVwiIFtkaXNhYmxlZF09XCJ0by5kaXNhYmxlZFwiPlxuICAgICAgICAgICAgICAgIHt7IG9wdGlvbi5sYWJlbCB9fVxuICAgICAgICAgICAgICAgIDwvbWF0LXJhZGlvLWJ1dHRvbj5cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICA8L2Rpdj5cbiAgICAgICAgPG1hdC1lcnJvciAqbmdJZj1cImZvcm1Db250cm9sLmludmFsaWQgJiYgZm9ybUNvbnRyb2wudG91Y2hlZFwiPlxuICAgICAgICAgICAge3sgZmllbGQudmFsaWRhdGlvbj8ubWVzc2FnZXM/LlsncmVxdWlyZWQnXSB9fVxuICAgICAgICA8L21hdC1lcnJvcj5cbiAgICA8L2Rpdj5cbiAgICBcbiAgICA8L21hdC1yYWRpby1ncm91cD5cbiAgYCxcbn0pXG5leHBvcnQgY2xhc3MgQ3VzdG9tRm9ybWx5UmFkaW9Db21wb25lbnQgZXh0ZW5kcyBGaWVsZFR5cGU8RmllbGRUeXBlQ29uZmlnPiB7XG59Il19
|
|
@@ -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":["../../../../../../projects/form-lib/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"]}
|