@tekus/design-system 2.0.1 → 4.0.0
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/assets/styles/_index.scss +1 -0
- package/assets/styles/_variables.scss +284 -0
- package/components/{search-bar → forms}/index.d.ts +1 -1
- package/components/forms/public-api.d.ts +3 -0
- package/components/forms/tk-form-autocomplete-field/index.d.ts +5 -0
- package/components/forms/tk-form-autocomplete-field/models/option.model.d.ts +4 -0
- package/components/forms/tk-form-autocomplete-field/public-api.d.ts +1 -0
- package/components/forms/tk-form-autocomplete-field/tk-form-autocomplete-field.component.d.ts +158 -0
- package/components/forms/tk-form-chips-autocomplete-field/index.d.ts +5 -0
- package/components/forms/tk-form-chips-autocomplete-field/models/option.model.d.ts +4 -0
- package/components/forms/tk-form-chips-autocomplete-field/public-api.d.ts +1 -0
- package/components/forms/tk-form-chips-autocomplete-field/tk-form-chips-autocomplete-field.component.d.ts +114 -0
- package/components/forms/tk-form-input-field/index.d.ts +5 -0
- package/components/forms/tk-form-input-field/models/validator-with-message.model.d.ts +5 -0
- package/components/forms/tk-form-input-field/public-api.d.ts +1 -0
- package/components/forms/tk-form-input-field/tk-form-input-field.component.d.ts +132 -0
- package/components/tk-dropdown-list/index.d.ts +5 -0
- package/components/tk-dropdown-list/public-api.d.ts +1 -0
- package/components/{dropdown-list/dropdown-list.component.d.ts → tk-dropdown-list/tk-dropdown-list.component.d.ts} +3 -3
- package/components/{dropdown-list → tk-search-bar}/index.d.ts +1 -1
- package/components/tk-search-bar/public-api.d.ts +1 -0
- package/components/{search-bar/search-bar.component.d.ts → tk-search-bar/tk-search-bar.component.d.ts} +3 -3
- package/components/tk-typography/index.d.ts +5 -0
- package/components/tk-typography/public-api.d.ts +1 -0
- package/components/tk-typography/tk-typography.component.d.ts +10 -0
- package/esm2022/components/forms/public-api.mjs +4 -0
- package/esm2022/components/forms/tekus-design-system-components-forms.mjs +5 -0
- package/esm2022/components/forms/tk-form-autocomplete-field/models/option.model.mjs +2 -0
- package/esm2022/components/forms/tk-form-autocomplete-field/public-api.mjs +2 -0
- package/esm2022/components/forms/tk-form-autocomplete-field/tekus-design-system-components-forms-tk-form-autocomplete-field.mjs +5 -0
- package/esm2022/components/forms/tk-form-autocomplete-field/tk-form-autocomplete-field.component.mjs +238 -0
- package/esm2022/components/forms/tk-form-chips-autocomplete-field/models/option.model.mjs +2 -0
- package/esm2022/components/forms/tk-form-chips-autocomplete-field/public-api.mjs +2 -0
- package/esm2022/components/forms/tk-form-chips-autocomplete-field/tekus-design-system-components-forms-tk-form-chips-autocomplete-field.mjs +5 -0
- package/esm2022/components/forms/tk-form-chips-autocomplete-field/tk-form-chips-autocomplete-field.component.mjs +167 -0
- package/esm2022/components/forms/tk-form-input-field/models/validator-with-message.model.mjs +2 -0
- package/esm2022/components/forms/tk-form-input-field/public-api.mjs +2 -0
- package/esm2022/components/forms/tk-form-input-field/tekus-design-system-components-forms-tk-form-input-field.mjs +5 -0
- package/esm2022/components/forms/tk-form-input-field/tk-form-input-field.component.mjs +199 -0
- package/esm2022/components/tk-dropdown-list/models/dropdown-list-item.model.mjs +2 -0
- package/esm2022/components/tk-dropdown-list/public-api.mjs +2 -0
- package/esm2022/components/tk-dropdown-list/tekus-design-system-components-tk-dropdown-list.mjs +5 -0
- package/esm2022/components/tk-dropdown-list/tk-dropdown-list.component.mjs +137 -0
- package/esm2022/components/tk-search-bar/public-api.mjs +2 -0
- package/esm2022/components/tk-search-bar/tekus-design-system-components-tk-search-bar.mjs +5 -0
- package/esm2022/components/tk-search-bar/tk-search-bar.component.mjs +49 -0
- package/esm2022/components/tk-typography/public-api.mjs +2 -0
- package/esm2022/components/tk-typography/tekus-design-system-components-tk-typography.mjs +5 -0
- package/esm2022/components/tk-typography/tk-typography.component.mjs +29 -0
- package/esm2022/services/typography/models/typographyStyles.model.mjs +2 -0
- package/esm2022/services/typography/public-api.mjs +2 -0
- package/esm2022/services/typography/tekus-design-system-services-typography.mjs +5 -0
- package/esm2022/services/typography/typography.service.mjs +84 -0
- package/fesm2022/tekus-design-system-components-forms-tk-form-autocomplete-field.mjs +245 -0
- package/fesm2022/tekus-design-system-components-forms-tk-form-autocomplete-field.mjs.map +1 -0
- package/fesm2022/tekus-design-system-components-forms-tk-form-chips-autocomplete-field.mjs +174 -0
- package/fesm2022/tekus-design-system-components-forms-tk-form-chips-autocomplete-field.mjs.map +1 -0
- package/fesm2022/tekus-design-system-components-forms-tk-form-input-field.mjs +206 -0
- package/fesm2022/tekus-design-system-components-forms-tk-form-input-field.mjs.map +1 -0
- package/fesm2022/tekus-design-system-components-forms.mjs +590 -0
- package/fesm2022/tekus-design-system-components-forms.mjs.map +1 -0
- package/fesm2022/{tekus-design-system-components-dropdown-list.mjs → tekus-design-system-components-tk-dropdown-list.mjs} +7 -7
- package/fesm2022/tekus-design-system-components-tk-dropdown-list.mjs.map +1 -0
- package/fesm2022/tekus-design-system-components-tk-search-bar.mjs +56 -0
- package/fesm2022/tekus-design-system-components-tk-search-bar.mjs.map +1 -0
- package/fesm2022/tekus-design-system-components-tk-typography.mjs +36 -0
- package/fesm2022/tekus-design-system-components-tk-typography.mjs.map +1 -0
- package/fesm2022/tekus-design-system-services-typography.mjs +91 -0
- package/fesm2022/tekus-design-system-services-typography.mjs.map +1 -0
- package/package.json +55 -15
- package/services/typography/index.d.ts +5 -0
- package/services/typography/models/typographyStyles.model.d.ts +36 -0
- package/services/typography/public-api.d.ts +1 -0
- package/services/typography/typography.service.d.ts +8 -0
- package/components/dropdown-list/public-api.d.ts +0 -2
- package/components/search-bar/public-api.d.ts +0 -1
- package/esm2022/components/dropdown-list/dropdown-list.component.mjs +0 -137
- package/esm2022/components/dropdown-list/models/dropdown-list-item.model.mjs +0 -2
- package/esm2022/components/dropdown-list/public-api.mjs +0 -3
- package/esm2022/components/dropdown-list/tekus-design-system-components-dropdown-list.mjs +0 -5
- package/esm2022/components/search-bar/public-api.mjs +0 -2
- package/esm2022/components/search-bar/search-bar.component.mjs +0 -83
- package/esm2022/components/search-bar/tekus-design-system-components-search-bar.mjs +0 -5
- package/fesm2022/tekus-design-system-components-dropdown-list.mjs.map +0 -1
- package/fesm2022/tekus-design-system-components-search-bar.mjs +0 -90
- package/fesm2022/tekus-design-system-components-search-bar.mjs.map +0 -1
- /package/components/{dropdown-list → tk-dropdown-list}/models/dropdown-list-item.model.d.ts +0 -0
|
@@ -0,0 +1,167 @@
|
|
|
1
|
+
import { Input, Output, Component, ViewChild, EventEmitter, ChangeDetectionStrategy, } from '@angular/core';
|
|
2
|
+
import { MatFormFieldModule, } from '@angular/material/form-field';
|
|
3
|
+
import { MatAutocompleteModule, } from '@angular/material/autocomplete';
|
|
4
|
+
import { map, startWith } from 'rxjs';
|
|
5
|
+
import { AsyncPipe, NgStyle } from '@angular/common';
|
|
6
|
+
import { COMMA, ENTER } from '@angular/cdk/keycodes';
|
|
7
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
8
|
+
import { MatChipsModule } from '@angular/material/chips';
|
|
9
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
10
|
+
import { FormControl, FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
11
|
+
import * as i0 from "@angular/core";
|
|
12
|
+
import * as i1 from "@angular/forms";
|
|
13
|
+
import * as i2 from "@angular/material/icon";
|
|
14
|
+
import * as i3 from "@angular/material/chips";
|
|
15
|
+
import * as i4 from "@angular/material/form-field";
|
|
16
|
+
import * as i5 from "@angular/material/autocomplete";
|
|
17
|
+
import * as i6 from "@angular/material/core";
|
|
18
|
+
export class TkFormChipsAutocompleteFieldComponent {
|
|
19
|
+
/**
|
|
20
|
+
* @ignore
|
|
21
|
+
* Class constructor
|
|
22
|
+
*/
|
|
23
|
+
constructor() {
|
|
24
|
+
/**
|
|
25
|
+
* Input field label
|
|
26
|
+
*/
|
|
27
|
+
this.fieldLabel = '';
|
|
28
|
+
/**
|
|
29
|
+
* Input field placeholder
|
|
30
|
+
* @default ''
|
|
31
|
+
*/
|
|
32
|
+
this.placeHolder = '';
|
|
33
|
+
/**
|
|
34
|
+
* What color palette to use
|
|
35
|
+
* @default 'accent'
|
|
36
|
+
*/
|
|
37
|
+
this.theme = 'accent';
|
|
38
|
+
/**
|
|
39
|
+
* Form field reserved space for one line by default.
|
|
40
|
+
* @default 'dynamic'
|
|
41
|
+
*/
|
|
42
|
+
this.subscriptSizing = 'dynamic';
|
|
43
|
+
/**
|
|
44
|
+
* Form field appearance
|
|
45
|
+
* @default 'fill'
|
|
46
|
+
*/
|
|
47
|
+
this.appearance = 'fill';
|
|
48
|
+
/**
|
|
49
|
+
* Input field control
|
|
50
|
+
* @ignore
|
|
51
|
+
*/
|
|
52
|
+
this.formControl = new FormControl('');
|
|
53
|
+
/**
|
|
54
|
+
* Selected keywords
|
|
55
|
+
* @ignore
|
|
56
|
+
*/
|
|
57
|
+
this.keywords = [];
|
|
58
|
+
/**
|
|
59
|
+
* Input field changes handler
|
|
60
|
+
*/
|
|
61
|
+
this.inputStatus = new EventEmitter();
|
|
62
|
+
/**
|
|
63
|
+
* Keywords changes handler
|
|
64
|
+
*/
|
|
65
|
+
this.selectedKeywords = new EventEmitter();
|
|
66
|
+
/**
|
|
67
|
+
* Separator constants
|
|
68
|
+
* @ignore
|
|
69
|
+
*/
|
|
70
|
+
this.separatorKeysCodes = [ENTER, COMMA];
|
|
71
|
+
/**
|
|
72
|
+
* Options to be displayed
|
|
73
|
+
* @ignore
|
|
74
|
+
*/
|
|
75
|
+
this.allKeywords = [];
|
|
76
|
+
this.filteredKeywords = this.formControl.valueChanges.pipe(startWith(null), map((keyword) => keyword ? this._filter(String(keyword)) : this.allKeywords.slice()));
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* Handles every keyword deletion
|
|
80
|
+
* @ignore
|
|
81
|
+
*/
|
|
82
|
+
remove(keyword) {
|
|
83
|
+
const index = this.keywords.indexOf(keyword);
|
|
84
|
+
if (index >= 0) {
|
|
85
|
+
this.keywords.splice(index, 1);
|
|
86
|
+
this.onKeywordsChanged();
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Emits the formControl variable every time the field value changes
|
|
91
|
+
* @ignore
|
|
92
|
+
*/
|
|
93
|
+
onInputChanged() {
|
|
94
|
+
this.inputStatus.emit(this.formControl);
|
|
95
|
+
}
|
|
96
|
+
/**
|
|
97
|
+
* Emits the selected keywords every time they changed
|
|
98
|
+
* @ignore
|
|
99
|
+
*/
|
|
100
|
+
onKeywordsChanged() {
|
|
101
|
+
this.selectedKeywords.emit(this.keywords.map(keyword => keyword.Value));
|
|
102
|
+
}
|
|
103
|
+
/**
|
|
104
|
+
* Handles the autocomplete selection
|
|
105
|
+
* @ignore
|
|
106
|
+
*/
|
|
107
|
+
selected(event) {
|
|
108
|
+
const value = event.option.value;
|
|
109
|
+
const selectedKeyword = this.allKeywords.find(option => option.Value === value);
|
|
110
|
+
if (selectedKeyword &&
|
|
111
|
+
!this.keywords.some(keyword => keyword.Value === selectedKeyword.Value)) {
|
|
112
|
+
this.keywords.push(selectedKeyword);
|
|
113
|
+
this.onKeywordsChanged();
|
|
114
|
+
}
|
|
115
|
+
this.keywordInput.nativeElement.value = '';
|
|
116
|
+
this.formControl.setValue(null);
|
|
117
|
+
}
|
|
118
|
+
/**
|
|
119
|
+
* Filters the keywords based on the input
|
|
120
|
+
* @ignore
|
|
121
|
+
*/
|
|
122
|
+
_filter(value) {
|
|
123
|
+
this.onInputChanged();
|
|
124
|
+
const filterValue = value.toLowerCase();
|
|
125
|
+
return this.allKeywords.filter(keyword => keyword.ViewValue.toLowerCase().includes(filterValue));
|
|
126
|
+
}
|
|
127
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: TkFormChipsAutocompleteFieldComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
128
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.10", type: TkFormChipsAutocompleteFieldComponent, isStandalone: true, selector: "lib-tk-form-chips-autocomplete-field", inputs: { fieldLabel: "fieldLabel", placeHolder: "placeHolder", fieldTitle: "fieldTitle", theme: "theme", subscriptSizing: "subscriptSizing", fieldWidth: "fieldWidth", appearance: "appearance", allKeywords: "allKeywords" }, outputs: { inputStatus: "inputStatus", selectedKeywords: "selectedKeywords" }, viewQueries: [{ propertyName: "keywordInput", first: true, predicate: ["keywordInput"], descendants: true }], ngImport: i0, template: "<section class=\"section\">\n @if (fieldTitle) {\n <h1 class=\"field__title\">{{ fieldTitle }}</h1>\n }\n <div class=\"field\" [ngStyle]=\"{ width: fieldWidth }\">\n <mat-form-field\n class=\"form__field\"\n [color]=\"theme\"\n [appearance]=\"appearance\"\n [subscriptSizing]=\"subscriptSizing\">\n <mat-label class=\"form__field__label\">{{ fieldLabel }}</mat-label>\n <mat-chip-grid #chipGrid aria-label=\"Keyword selection\">\n @for (keyword of keywords; track keyword.Value) {\n <mat-chip-row (removed)=\"remove(keyword)\">\n {{ keyword.ViewValue }}\n <button\n matChipRemove\n [attr.aria-label]=\"'remove ' + keyword.ViewValue\">\n <mat-icon>cancel</mat-icon>\n </button>\n </mat-chip-row>\n }\n </mat-chip-grid>\n <input\n #keywordInput\n [matAutocomplete]=\"auto\"\n [formControl]=\"formControl\"\n [placeholder]=\"placeHolder\"\n [matChipInputFor]=\"chipGrid\"\n [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\" />\n <mat-autocomplete\n #auto=\"matAutocomplete\"\n (optionSelected)=\"selected($event)\">\n @for (keyword of filteredKeywords | async; track keyword.Value) {\n <mat-option [value]=\"keyword.Value\">{{\n keyword.ViewValue\n }}</mat-option>\n }\n </mat-autocomplete>\n </mat-form-field>\n </div>\n</section>\n", styles: [".section{gap:.5rem;display:flex;flex-wrap:wrap;width:fit-content;align-items:flex-start;justify-content:flex-start}.field{flex:1;display:flex;min-width:none;max-width:100%;align-items:flex-start;flex-flow:column nowrap;justify-content:flex-start}.form__field{width:100%;font-size:clamp(.8rem,.657rem + .381vw,1rem)}.form__field__label{font-weight:400;font-style:normal;line-height:.98438em;font-size:clamp(.688rem,.554rem + .357vw,.875rem)}.field__title{margin:0;padding:0;align-self:center;font-size:clamp(1rem,.94rem + .345vw,1.25rem)}\n"], dependencies: [{ kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.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: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatChipsModule }, { kind: "component", type: i3.MatChipGrid, selector: "mat-chip-grid", inputs: ["disabled", "placeholder", "required", "value", "errorStateMatcher"], outputs: ["change", "valueChange"] }, { kind: "directive", type: i3.MatChipInput, selector: "input[matChipInputFor]", inputs: ["matChipInputFor", "matChipInputAddOnBlur", "matChipInputSeparatorKeyCodes", "placeholder", "id", "disabled"], outputs: ["matChipInputTokenEnd"], exportAs: ["matChipInput", "matChipInputFor"] }, { kind: "directive", type: i3.MatChipRemove, selector: "[matChipRemove]" }, { kind: "component", type: i3.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: MatFormFieldModule }, { 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: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { 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"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
129
|
+
}
|
|
130
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: TkFormChipsAutocompleteFieldComponent, decorators: [{
|
|
131
|
+
type: Component,
|
|
132
|
+
args: [{ selector: 'lib-tk-form-chips-autocomplete-field', standalone: true, imports: [
|
|
133
|
+
NgStyle,
|
|
134
|
+
AsyncPipe,
|
|
135
|
+
FormsModule,
|
|
136
|
+
MatIconModule,
|
|
137
|
+
MatChipsModule,
|
|
138
|
+
MatButtonModule,
|
|
139
|
+
MatFormFieldModule,
|
|
140
|
+
ReactiveFormsModule,
|
|
141
|
+
MatAutocompleteModule,
|
|
142
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<section class=\"section\">\n @if (fieldTitle) {\n <h1 class=\"field__title\">{{ fieldTitle }}</h1>\n }\n <div class=\"field\" [ngStyle]=\"{ width: fieldWidth }\">\n <mat-form-field\n class=\"form__field\"\n [color]=\"theme\"\n [appearance]=\"appearance\"\n [subscriptSizing]=\"subscriptSizing\">\n <mat-label class=\"form__field__label\">{{ fieldLabel }}</mat-label>\n <mat-chip-grid #chipGrid aria-label=\"Keyword selection\">\n @for (keyword of keywords; track keyword.Value) {\n <mat-chip-row (removed)=\"remove(keyword)\">\n {{ keyword.ViewValue }}\n <button\n matChipRemove\n [attr.aria-label]=\"'remove ' + keyword.ViewValue\">\n <mat-icon>cancel</mat-icon>\n </button>\n </mat-chip-row>\n }\n </mat-chip-grid>\n <input\n #keywordInput\n [matAutocomplete]=\"auto\"\n [formControl]=\"formControl\"\n [placeholder]=\"placeHolder\"\n [matChipInputFor]=\"chipGrid\"\n [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\" />\n <mat-autocomplete\n #auto=\"matAutocomplete\"\n (optionSelected)=\"selected($event)\">\n @for (keyword of filteredKeywords | async; track keyword.Value) {\n <mat-option [value]=\"keyword.Value\">{{\n keyword.ViewValue\n }}</mat-option>\n }\n </mat-autocomplete>\n </mat-form-field>\n </div>\n</section>\n", styles: [".section{gap:.5rem;display:flex;flex-wrap:wrap;width:fit-content;align-items:flex-start;justify-content:flex-start}.field{flex:1;display:flex;min-width:none;max-width:100%;align-items:flex-start;flex-flow:column nowrap;justify-content:flex-start}.form__field{width:100%;font-size:clamp(.8rem,.657rem + .381vw,1rem)}.form__field__label{font-weight:400;font-style:normal;line-height:.98438em;font-size:clamp(.688rem,.554rem + .357vw,.875rem)}.field__title{margin:0;padding:0;align-self:center;font-size:clamp(1rem,.94rem + .345vw,1.25rem)}\n"] }]
|
|
143
|
+
}], ctorParameters: () => [], propDecorators: { fieldLabel: [{
|
|
144
|
+
type: Input
|
|
145
|
+
}], placeHolder: [{
|
|
146
|
+
type: Input
|
|
147
|
+
}], fieldTitle: [{
|
|
148
|
+
type: Input
|
|
149
|
+
}], theme: [{
|
|
150
|
+
type: Input
|
|
151
|
+
}], subscriptSizing: [{
|
|
152
|
+
type: Input
|
|
153
|
+
}], fieldWidth: [{
|
|
154
|
+
type: Input
|
|
155
|
+
}], appearance: [{
|
|
156
|
+
type: Input
|
|
157
|
+
}], inputStatus: [{
|
|
158
|
+
type: Output
|
|
159
|
+
}], selectedKeywords: [{
|
|
160
|
+
type: Output
|
|
161
|
+
}], allKeywords: [{
|
|
162
|
+
type: Input
|
|
163
|
+
}], keywordInput: [{
|
|
164
|
+
type: ViewChild,
|
|
165
|
+
args: ['keywordInput']
|
|
166
|
+
}] } });
|
|
167
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tk-form-chips-autocomplete-field.component.js","sourceRoot":"","sources":["../../../../../../projects/design-system/components/forms/tk-form-chips-autocomplete-field/tk-form-chips-autocomplete-field.component.ts","../../../../../../projects/design-system/components/forms/tk-form-chips-autocomplete-field/tk-form-chips-autocomplete-field.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,EACL,MAAM,EACN,SAAS,EACT,SAAS,EAET,YAAY,EACZ,uBAAuB,GACxB,MAAM,eAAe,CAAC;AACvB,OAAO,EAEL,kBAAkB,GAEnB,MAAM,8BAA8B,CAAC;AACtC,OAAO,EACL,qBAAqB,GAEtB,MAAM,gCAAgC,CAAC;AAExC,OAAO,EAAE,GAAG,EAAc,SAAS,EAAE,MAAM,MAAM,CAAC;AAClD,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AACrD,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAErD,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;;;;;;;;AAoB/E,MAAM,OAAO,qCAAqC;IAiGhD;;;OAGG;IACH;QApGA;;WAEG;QAEI,eAAU,GAAG,EAAE,CAAC;QAEvB;;;WAGG;QAEI,gBAAW,GAAG,EAAE,CAAC;QASxB;;;WAGG;QAEI,UAAK,GAAkB,QAAQ,CAAC;QAEvC;;;WAGG;QAEI,oBAAe,GAAoB,SAAS,CAAC;QASpD;;;WAGG;QAEI,eAAU,GAA2B,MAAM,CAAC;QAEnD;;;WAGG;QACI,gBAAW,GAAG,IAAI,WAAW,CAAC,EAAE,CAAC,CAAC;QACzC;;;WAGG;QACI,aAAQ,GAAa,EAAE,CAAC;QAE/B;;WAEG;QAEI,gBAAW,GAAG,IAAI,YAAY,EAAe,CAAC;QAErD;;WAEG;QAEI,qBAAgB,GAAG,IAAI,YAAY,EAAuB,CAAC;QAElE;;;WAGG;QACa,uBAAkB,GAAa,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAE9D;;;WAGG;QAEI,gBAAW,GAAa,EAAE,CAAC;QAmBhC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,IAAI,CACxD,SAAS,CAAC,IAAI,CAAC,EACf,GAAG,CAAC,CAAC,OAAsB,EAAE,EAAE,CAC7B,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CACnE,CACF,CAAC;IACJ,CAAC;IAED;;;OAGG;IACI,MAAM,CAAC,OAAe;QAC3B,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QAE7C,IAAI,KAAK,IAAI,CAAC,EAAE,CAAC;YACf,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;YAC/B,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC3B,CAAC;IACH,CAAC;IAED;;;OAGG;IACI,cAAc;QACnB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IAC1C,CAAC;IAED;;;OAGG;IACI,iBAAiB;QACtB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC;IAC1E,CAAC;IAED;;;OAGG;IACI,QAAQ,CAAC,KAAmC;QACjD,MAAM,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;QACjC,MAAM,eAAe,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAC3C,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,KAAK,KAAK,CACjC,CAAC;QAEF,IACE,eAAe;YACf,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,KAAK,KAAK,eAAe,CAAC,KAAK,CAAC,EACvE,CAAC;YACD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;YACpC,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC3B,CAAC;QAED,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,KAAK,GAAG,EAAE,CAAC;QAC3C,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IAClC,CAAC;IAED;;;OAGG;IACK,OAAO,CAAC,KAAa;QAC3B,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,MAAM,WAAW,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC;QAExC,OAAO,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CACvC,OAAO,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,WAAW,CAAC,CACtD,CAAC;IACJ,CAAC;+GA5KU,qCAAqC;mGAArC,qCAAqC,6fC9ClD,+9CA0CA,qlBDVI,OAAO,sEACP,SAAS,6CACT,WAAW,sZACX,aAAa,mLACb,cAAc,4uBACd,eAAe,8BACf,kBAAkB,0SAClB,mBAAmB,iNACnB,qBAAqB;;4FAMZ,qCAAqC;kBAlBjD,SAAS;+BACE,sCAAsC,cACpC,IAAI,WACP;wBACP,OAAO;wBACP,SAAS;wBACT,WAAW;wBACX,aAAa;wBACb,cAAc;wBACd,eAAe;wBACf,kBAAkB;wBAClB,mBAAmB;wBACnB,qBAAqB;qBACtB,mBACgB,uBAAuB,CAAC,MAAM;wDASxC,UAAU;sBADhB,KAAK;gBAQC,WAAW;sBADjB,KAAK;gBAQC,UAAU;sBADhB,KAAK;gBAQC,KAAK;sBADX,KAAK;gBAQC,eAAe;sBADrB,KAAK;gBAQC,UAAU;sBADhB,KAAK;gBAQC,UAAU;sBADhB,KAAK;gBAkBC,WAAW;sBADjB,MAAM;gBAOA,gBAAgB;sBADtB,MAAM;gBAcA,WAAW;sBADjB,KAAK;gBAaqB,YAAY;sBAAtC,SAAS;uBAAC,cAAc","sourcesContent":["import {\n  Input,\n  Output,\n  Component,\n  ViewChild,\n  ElementRef,\n  EventEmitter,\n  ChangeDetectionStrategy,\n} from '@angular/core';\nimport {\n  SubscriptSizing,\n  MatFormFieldModule,\n  MatFormFieldAppearance,\n} from '@angular/material/form-field';\nimport {\n  MatAutocompleteModule,\n  MatAutocompleteSelectedEvent,\n} from '@angular/material/autocomplete';\nimport { Option } from './models/option.model';\nimport { map, Observable, startWith } from 'rxjs';\nimport { AsyncPipe, NgStyle } from '@angular/common';\nimport { COMMA, ENTER } from '@angular/cdk/keycodes';\nimport { ThemePalette } from '@angular/material/core';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatChipsModule } from '@angular/material/chips';\nimport { MatButtonModule } from '@angular/material/button';\nimport { FormControl, FormsModule, ReactiveFormsModule } from '@angular/forms';\n\n@Component({\n  selector: 'lib-tk-form-chips-autocomplete-field',\n  standalone: true,\n  imports: [\n    NgStyle,\n    AsyncPipe,\n    FormsModule,\n    MatIconModule,\n    MatChipsModule,\n    MatButtonModule,\n    MatFormFieldModule,\n    ReactiveFormsModule,\n    MatAutocompleteModule,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  templateUrl: './tk-form-chips-autocomplete-field.component.html',\n  styleUrl: './tk-form-chips-autocomplete-field.component.scss',\n})\nexport class TkFormChipsAutocompleteFieldComponent {\n  /**\n   * Input field label\n   */\n  @Input()\n  public fieldLabel = '';\n\n  /**\n   * Input field placeholder\n   * @default ''\n   */\n  @Input()\n  public placeHolder = '';\n\n  /**\n   * Optional input field title\n   * @default null\n   */\n  @Input()\n  public fieldTitle?: string;\n\n  /**\n   * What color palette to use\n   * @default 'accent'\n   */\n  @Input()\n  public theme?: ThemePalette = 'accent';\n\n  /**\n   * Form field reserved space for one line by default.\n   * @default 'dynamic'\n   */\n  @Input()\n  public subscriptSizing: SubscriptSizing = 'dynamic';\n\n  /**\n   * Optional input field width\n   * @default 100%\n   */\n  @Input()\n  public fieldWidth?: string;\n\n  /**\n   * Form field appearance\n   * @default 'fill'\n   */\n  @Input()\n  public appearance: MatFormFieldAppearance = 'fill';\n\n  /**\n   * Input field control\n   * @ignore\n   */\n  public formControl = new FormControl('');\n  /**\n   * Selected keywords\n   * @ignore\n   */\n  public keywords: Option[] = [];\n\n  /**\n   * Input field changes handler\n   */\n  @Output()\n  public inputStatus = new EventEmitter<FormControl>();\n\n  /**\n   * Keywords changes handler\n   */\n  @Output()\n  public selectedKeywords = new EventEmitter<(string | number)[]>();\n\n  /**\n   * Separator constants\n   * @ignore\n   */\n  public readonly separatorKeysCodes: number[] = [ENTER, COMMA];\n\n  /**\n   * Options to be displayed\n   * @ignore\n   */\n  @Input()\n  public allKeywords: Option[] = [];\n\n  /**\n   * Filtered keywords after the input field changes\n   * @ignore\n   */\n  public readonly filteredKeywords: Observable<Option[]>;\n\n  /**\n   * Keyword Input element reference\n   * @ignore\n   */\n  @ViewChild('keywordInput') keywordInput!: ElementRef<HTMLInputElement>;\n\n  /**\n   * @ignore\n   * Class constructor\n   */\n  constructor() {\n    this.filteredKeywords = this.formControl.valueChanges.pipe(\n      startWith(null),\n      map((keyword: string | null) =>\n        keyword ? this._filter(String(keyword)) : this.allKeywords.slice()\n      )\n    );\n  }\n\n  /**\n   * Handles every keyword deletion\n   * @ignore\n   */\n  public remove(keyword: Option): void {\n    const index = this.keywords.indexOf(keyword);\n\n    if (index >= 0) {\n      this.keywords.splice(index, 1);\n      this.onKeywordsChanged();\n    }\n  }\n\n  /**\n   * Emits the formControl variable every time the field value changes\n   * @ignore\n   */\n  public onInputChanged(): void {\n    this.inputStatus.emit(this.formControl);\n  }\n\n  /**\n   * Emits the selected keywords every time they changed\n   * @ignore\n   */\n  public onKeywordsChanged(): void {\n    this.selectedKeywords.emit(this.keywords.map(keyword => keyword.Value));\n  }\n\n  /**\n   * Handles the autocomplete selection\n   * @ignore\n   */\n  public selected(event: MatAutocompleteSelectedEvent): void {\n    const value = event.option.value;\n    const selectedKeyword = this.allKeywords.find(\n      option => option.Value === value\n    );\n\n    if (\n      selectedKeyword &&\n      !this.keywords.some(keyword => keyword.Value === selectedKeyword.Value)\n    ) {\n      this.keywords.push(selectedKeyword);\n      this.onKeywordsChanged();\n    }\n\n    this.keywordInput.nativeElement.value = '';\n    this.formControl.setValue(null);\n  }\n\n  /**\n   * Filters the keywords based on the input\n   * @ignore\n   */\n  private _filter(value: string): Option[] {\n    this.onInputChanged();\n    const filterValue = value.toLowerCase();\n\n    return this.allKeywords.filter(keyword =>\n      keyword.ViewValue.toLowerCase().includes(filterValue)\n    );\n  }\n}\n","<section class=\"section\">\n  @if (fieldTitle) {\n    <h1 class=\"field__title\">{{ fieldTitle }}</h1>\n  }\n  <div class=\"field\" [ngStyle]=\"{ width: fieldWidth }\">\n    <mat-form-field\n      class=\"form__field\"\n      [color]=\"theme\"\n      [appearance]=\"appearance\"\n      [subscriptSizing]=\"subscriptSizing\">\n      <mat-label class=\"form__field__label\">{{ fieldLabel }}</mat-label>\n      <mat-chip-grid #chipGrid aria-label=\"Keyword selection\">\n        @for (keyword of keywords; track keyword.Value) {\n          <mat-chip-row (removed)=\"remove(keyword)\">\n            {{ keyword.ViewValue }}\n            <button\n              matChipRemove\n              [attr.aria-label]=\"'remove ' + keyword.ViewValue\">\n              <mat-icon>cancel</mat-icon>\n            </button>\n          </mat-chip-row>\n        }\n      </mat-chip-grid>\n      <input\n        #keywordInput\n        [matAutocomplete]=\"auto\"\n        [formControl]=\"formControl\"\n        [placeholder]=\"placeHolder\"\n        [matChipInputFor]=\"chipGrid\"\n        [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\" />\n      <mat-autocomplete\n        #auto=\"matAutocomplete\"\n        (optionSelected)=\"selected($event)\">\n        @for (keyword of filteredKeywords | async; track keyword.Value) {\n          <mat-option [value]=\"keyword.Value\">{{\n            keyword.ViewValue\n          }}</mat-option>\n        }\n      </mat-autocomplete>\n    </mat-form-field>\n  </div>\n</section>\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdG9yLXdpdGgtbWVzc2FnZS5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1zeXN0ZW0vY29tcG9uZW50cy9mb3Jtcy90ay1mb3JtLWlucHV0LWZpZWxkL21vZGVscy92YWxpZGF0b3Itd2l0aC1tZXNzYWdlLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBWYWxpZGF0b3JGbiB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuZXhwb3J0IGludGVyZmFjZSBWYWxpZGF0b3JXaXRoTWVzc2FnZSB7XG4gIHZhbGlkYXRvcjogVmFsaWRhdG9yRm47XG4gIG1lc3NhZ2U6IHN0cmluZztcbn1cbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './tk-form-input-field.component';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1zeXN0ZW0vY29tcG9uZW50cy9mb3Jtcy90ay1mb3JtLWlucHV0LWZpZWxkL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxpQ0FBaUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vdGstZm9ybS1pbnB1dC1maWVsZC5jb21wb25lbnQnO1xuIl19
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './public-api';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVrdXMtZGVzaWduLXN5c3RlbS1jb21wb25lbnRzLWZvcm1zLXRrLWZvcm0taW5wdXQtZmllbGQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tc3lzdGVtL2NvbXBvbmVudHMvZm9ybXMvdGstZm9ybS1pbnB1dC1maWVsZC90ZWt1cy1kZXNpZ24tc3lzdGVtLWNvbXBvbmVudHMtZm9ybXMtdGstZm9ybS1pbnB1dC1maWVsZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpYy1hcGknO1xuIl19
|
|
@@ -0,0 +1,199 @@
|
|
|
1
|
+
import { Input, Output, Component, EventEmitter, } from '@angular/core';
|
|
2
|
+
import { FormControl, FormsModule, ReactiveFormsModule, } from '@angular/forms';
|
|
3
|
+
import { merge } from 'rxjs';
|
|
4
|
+
import { MatFormFieldModule, } from '@angular/material/form-field';
|
|
5
|
+
import { NgStyle } from '@angular/common';
|
|
6
|
+
import { MatInputModule } from '@angular/material/input';
|
|
7
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "@angular/forms";
|
|
10
|
+
import * as i2 from "@angular/material/input";
|
|
11
|
+
import * as i3 from "@angular/material/form-field";
|
|
12
|
+
export class TkFormInputFieldComponent {
|
|
13
|
+
/**
|
|
14
|
+
* @ignore
|
|
15
|
+
* Class constructor
|
|
16
|
+
*/
|
|
17
|
+
constructor() {
|
|
18
|
+
/**
|
|
19
|
+
* What color palette to use
|
|
20
|
+
* @default 'accent'
|
|
21
|
+
*/
|
|
22
|
+
this.theme = 'accent';
|
|
23
|
+
/**
|
|
24
|
+
* Whether the field is required
|
|
25
|
+
* @default true
|
|
26
|
+
*/
|
|
27
|
+
this.required = true;
|
|
28
|
+
/**
|
|
29
|
+
* Form field label behavior
|
|
30
|
+
* @default 'auto'
|
|
31
|
+
*/
|
|
32
|
+
this.floatLabel = 'auto';
|
|
33
|
+
/**
|
|
34
|
+
* Form field appearance
|
|
35
|
+
* @default 'fill'
|
|
36
|
+
*/
|
|
37
|
+
this.appearance = 'fill';
|
|
38
|
+
/**
|
|
39
|
+
* Form field reserved space for one line by default.
|
|
40
|
+
* @default 'dynamic'
|
|
41
|
+
*/
|
|
42
|
+
this.subscriptSizing = 'dynamic';
|
|
43
|
+
/**
|
|
44
|
+
* Input field label
|
|
45
|
+
*/
|
|
46
|
+
this.fieldLabel = '';
|
|
47
|
+
/**
|
|
48
|
+
* Input field placeholder
|
|
49
|
+
* @default ''
|
|
50
|
+
*/
|
|
51
|
+
this.placeHolder = '';
|
|
52
|
+
/**
|
|
53
|
+
* Input field control
|
|
54
|
+
* @ignore
|
|
55
|
+
*/
|
|
56
|
+
this.formControl = new FormControl('');
|
|
57
|
+
/**
|
|
58
|
+
* Input field error message
|
|
59
|
+
* @ignore
|
|
60
|
+
*/
|
|
61
|
+
this.errorMessage = '';
|
|
62
|
+
/**
|
|
63
|
+
* Optional validators for the field
|
|
64
|
+
* @default ''
|
|
65
|
+
*/
|
|
66
|
+
this.validatorsWithMessages = {};
|
|
67
|
+
/**
|
|
68
|
+
* Optional async validators for the field
|
|
69
|
+
* @default ''
|
|
70
|
+
*/
|
|
71
|
+
this.asyncValidatorsWithMessages = {};
|
|
72
|
+
/**
|
|
73
|
+
* Input field changes handler
|
|
74
|
+
*/
|
|
75
|
+
this.inputStatus = new EventEmitter();
|
|
76
|
+
merge(this.formControl.statusChanges, this.formControl.valueChanges)
|
|
77
|
+
.pipe(takeUntilDestroyed())
|
|
78
|
+
.subscribe(() => {
|
|
79
|
+
this.updateErrorMessage();
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* Component lifecycle method
|
|
84
|
+
* @ignore
|
|
85
|
+
*/
|
|
86
|
+
ngOnInit() {
|
|
87
|
+
this.applyValidators();
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Component lifecycle method
|
|
91
|
+
* @ignore
|
|
92
|
+
*/
|
|
93
|
+
ngOnChanges(changes) {
|
|
94
|
+
if (changes['validatorsWithMessages'] ||
|
|
95
|
+
changes['asyncValidatorsWithMessages']) {
|
|
96
|
+
this.applyValidators();
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* @ignore
|
|
101
|
+
* Component lifecycle method
|
|
102
|
+
*/
|
|
103
|
+
isThereAnyValidator(validatorsWithMessages) {
|
|
104
|
+
return Object.keys(validatorsWithMessages).length > 0;
|
|
105
|
+
}
|
|
106
|
+
/**
|
|
107
|
+
* Applies all the passed validators
|
|
108
|
+
* @ignore
|
|
109
|
+
*/
|
|
110
|
+
applyValidators() {
|
|
111
|
+
const hasSyncValidators = this.isThereAnyValidator(this.validatorsWithMessages);
|
|
112
|
+
const hasAsyncValidators = this.isThereAnyValidator(this.asyncValidatorsWithMessages);
|
|
113
|
+
const activeValidators = hasSyncValidators
|
|
114
|
+
? Object.values(this.validatorsWithMessages).map(validatorWithMessage => validatorWithMessage.validator)
|
|
115
|
+
: [];
|
|
116
|
+
const activeAsyncValidators = hasAsyncValidators
|
|
117
|
+
? Object.values(this.asyncValidatorsWithMessages).map(validatorWithMessage => validatorWithMessage.validator)
|
|
118
|
+
: [];
|
|
119
|
+
if (hasSyncValidators || hasAsyncValidators) {
|
|
120
|
+
this.formControl.setValidators(activeValidators);
|
|
121
|
+
this.formControl.setAsyncValidators(activeAsyncValidators);
|
|
122
|
+
this.formControl.updateValueAndValidity();
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
/**
|
|
126
|
+
* Checks if there is any validation error
|
|
127
|
+
* @ignore
|
|
128
|
+
*/
|
|
129
|
+
checkValidationErrors(errors, validatorsWithMessages) {
|
|
130
|
+
for (const errorKey in errors) {
|
|
131
|
+
if (validatorsWithMessages[errorKey]) {
|
|
132
|
+
this.errorMessage = validatorsWithMessages[errorKey].message;
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
/**
|
|
137
|
+
* Emits the formControl variable every time the field value changes
|
|
138
|
+
* @ignore
|
|
139
|
+
*/
|
|
140
|
+
onInputChanged() {
|
|
141
|
+
this.inputStatus.emit(this.formControl);
|
|
142
|
+
}
|
|
143
|
+
/**
|
|
144
|
+
* Updates the error message every time the input value changes
|
|
145
|
+
* @ignore
|
|
146
|
+
*/
|
|
147
|
+
updateErrorMessage() {
|
|
148
|
+
this.errorMessage = '';
|
|
149
|
+
const errors = this.formControl.errors;
|
|
150
|
+
if (!errors) {
|
|
151
|
+
this.errorMessage = '';
|
|
152
|
+
return;
|
|
153
|
+
}
|
|
154
|
+
this.checkValidationErrors(errors, this.validatorsWithMessages);
|
|
155
|
+
this.checkValidationErrors(errors, this.asyncValidatorsWithMessages);
|
|
156
|
+
this.onInputChanged();
|
|
157
|
+
}
|
|
158
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: TkFormInputFieldComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
159
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.10", type: TkFormInputFieldComponent, isStandalone: true, selector: "lib-tk-form-input-field", inputs: { fieldWidth: "fieldWidth", fieldTitle: "fieldTitle", theme: "theme", required: "required", floatLabel: "floatLabel", appearance: "appearance", subscriptSizing: "subscriptSizing", fieldLabel: "fieldLabel", placeHolder: "placeHolder", inputPrefix: "inputPrefix", inputSuffix: "inputSuffix", validatorsWithMessages: "validatorsWithMessages", asyncValidatorsWithMessages: "asyncValidatorsWithMessages" }, outputs: { inputStatus: "inputStatus" }, usesOnChanges: true, ngImport: i0, template: "<section class=\"section\">\n @if (fieldTitle) {\n <h1 class=\"field__title\">{{ fieldTitle }}</h1>\n }\n <div class=\"field\" [ngStyle]=\"{ width: fieldWidth }\">\n <mat-form-field\n class=\"form__field\"\n [color]=\"theme\"\n [appearance]=\"appearance\"\n [floatLabel]=\"floatLabel\"\n [subscriptSizing]=\"subscriptSizing\">\n <mat-label class=\"form__field__label\">{{ fieldLabel }}</mat-label>\n <input\n matInput\n [required]=\"required\"\n (input)=\"onInputChanged()\"\n [placeholder]=\"placeHolder\"\n [formControl]=\"formControl\"\n (blur)=\"updateErrorMessage()\" />\n @if (inputPrefix) {\n <span class=\"form__field__label\" matTextPrefix\n >{{ inputPrefix }} </span\n >\n }\n @if (inputSuffix) {\n <span class=\"form__field__label\" matTextSuffix>{{ inputSuffix }}</span>\n }\n @if (formControl.invalid) {\n <mat-error class=\"form__field__error\">{{ errorMessage }}</mat-error>\n }\n </mat-form-field>\n </div>\n</section>\n", styles: [".section{gap:.5rem;display:flex;flex-wrap:wrap;width:fit-content;align-items:flex-start;justify-content:flex-start}.field{flex:1;display:flex;min-width:none;max-width:100%;align-items:flex-start;flex-flow:column nowrap;justify-content:flex-start}.form__field{width:100%;font-size:clamp(.8rem,.657rem + .381vw,1rem)}.form__field__label{font-weight:400;font-style:normal;line-height:.98438em;font-size:clamp(.688rem,.554rem + .357vw,.875rem)}.form__field__error{font-weight:400;font-style:normal;font-size:clamp(.688rem,.554rem + .357vw,.875rem)}.field__title{margin:0;padding:0;align-self:center;font-size:clamp(1rem,.94rem + .345vw,1.25rem)}\n"], dependencies: [{ kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.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: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i2.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i3.MatPrefix, selector: "[matPrefix], [matIconPrefix], [matTextPrefix]", inputs: ["matTextPrefix"] }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }] }); }
|
|
160
|
+
}
|
|
161
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: TkFormInputFieldComponent, decorators: [{
|
|
162
|
+
type: Component,
|
|
163
|
+
args: [{ selector: 'lib-tk-form-input-field', standalone: true, imports: [
|
|
164
|
+
NgStyle,
|
|
165
|
+
FormsModule,
|
|
166
|
+
MatInputModule,
|
|
167
|
+
MatFormFieldModule,
|
|
168
|
+
ReactiveFormsModule,
|
|
169
|
+
], template: "<section class=\"section\">\n @if (fieldTitle) {\n <h1 class=\"field__title\">{{ fieldTitle }}</h1>\n }\n <div class=\"field\" [ngStyle]=\"{ width: fieldWidth }\">\n <mat-form-field\n class=\"form__field\"\n [color]=\"theme\"\n [appearance]=\"appearance\"\n [floatLabel]=\"floatLabel\"\n [subscriptSizing]=\"subscriptSizing\">\n <mat-label class=\"form__field__label\">{{ fieldLabel }}</mat-label>\n <input\n matInput\n [required]=\"required\"\n (input)=\"onInputChanged()\"\n [placeholder]=\"placeHolder\"\n [formControl]=\"formControl\"\n (blur)=\"updateErrorMessage()\" />\n @if (inputPrefix) {\n <span class=\"form__field__label\" matTextPrefix\n >{{ inputPrefix }} </span\n >\n }\n @if (inputSuffix) {\n <span class=\"form__field__label\" matTextSuffix>{{ inputSuffix }}</span>\n }\n @if (formControl.invalid) {\n <mat-error class=\"form__field__error\">{{ errorMessage }}</mat-error>\n }\n </mat-form-field>\n </div>\n</section>\n", styles: [".section{gap:.5rem;display:flex;flex-wrap:wrap;width:fit-content;align-items:flex-start;justify-content:flex-start}.field{flex:1;display:flex;min-width:none;max-width:100%;align-items:flex-start;flex-flow:column nowrap;justify-content:flex-start}.form__field{width:100%;font-size:clamp(.8rem,.657rem + .381vw,1rem)}.form__field__label{font-weight:400;font-style:normal;line-height:.98438em;font-size:clamp(.688rem,.554rem + .357vw,.875rem)}.form__field__error{font-weight:400;font-style:normal;font-size:clamp(.688rem,.554rem + .357vw,.875rem)}.field__title{margin:0;padding:0;align-self:center;font-size:clamp(1rem,.94rem + .345vw,1.25rem)}\n"] }]
|
|
170
|
+
}], ctorParameters: () => [], propDecorators: { fieldWidth: [{
|
|
171
|
+
type: Input
|
|
172
|
+
}], fieldTitle: [{
|
|
173
|
+
type: Input
|
|
174
|
+
}], theme: [{
|
|
175
|
+
type: Input
|
|
176
|
+
}], required: [{
|
|
177
|
+
type: Input
|
|
178
|
+
}], floatLabel: [{
|
|
179
|
+
type: Input
|
|
180
|
+
}], appearance: [{
|
|
181
|
+
type: Input
|
|
182
|
+
}], subscriptSizing: [{
|
|
183
|
+
type: Input
|
|
184
|
+
}], fieldLabel: [{
|
|
185
|
+
type: Input
|
|
186
|
+
}], placeHolder: [{
|
|
187
|
+
type: Input
|
|
188
|
+
}], inputPrefix: [{
|
|
189
|
+
type: Input
|
|
190
|
+
}], inputSuffix: [{
|
|
191
|
+
type: Input
|
|
192
|
+
}], validatorsWithMessages: [{
|
|
193
|
+
type: Input
|
|
194
|
+
}], asyncValidatorsWithMessages: [{
|
|
195
|
+
type: Input
|
|
196
|
+
}], inputStatus: [{
|
|
197
|
+
type: Output
|
|
198
|
+
}] } });
|
|
199
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tk-form-input-field.component.js","sourceRoot":"","sources":["../../../../../../projects/design-system/components/forms/tk-form-input-field/tk-form-input-field.component.ts","../../../../../../projects/design-system/components/forms/tk-form-input-field/tk-form-input-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Input,\n  OnInit,\n  Output,\n  Component,\n  OnChanges,\n  EventEmitter,\n  SimpleChanges,\n} from '@angular/core';\nimport {\n  FormControl,\n  FormsModule,\n  ValidatorFn,\n  AsyncValidatorFn,\n  ValidationErrors,\n  ReactiveFormsModule,\n} from '@angular/forms';\nimport { merge } from 'rxjs';\nimport {\n  FloatLabelType,\n  SubscriptSizing,\n  MatFormFieldModule,\n  MatFormFieldAppearance,\n} from '@angular/material/form-field';\nimport { NgStyle } from '@angular/common';\nimport { ThemePalette } from '@angular/material/core';\nimport { MatInputModule } from '@angular/material/input';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { ValidatorWithMessage } from './models/validator-with-message.model';\n\n@Component({\n  selector: 'lib-tk-form-input-field',\n  standalone: true,\n  imports: [\n    NgStyle,\n    FormsModule,\n    MatInputModule,\n    MatFormFieldModule,\n    ReactiveFormsModule,\n  ],\n  templateUrl: './tk-form-input-field.component.html',\n  styleUrl: './tk-form-input-field.component.scss',\n})\nexport class TkFormInputFieldComponent implements OnInit, OnChanges {\n  /**\n   * Optional input field width\n   * @default 100%\n   */\n  @Input()\n  public fieldWidth?: string;\n\n  /**\n   * Optional input field title\n   * @default null\n   */\n  @Input()\n  public fieldTitle?: string;\n\n  /**\n   * What color palette to use\n   * @default 'accent'\n   */\n  @Input()\n  public theme?: ThemePalette = 'accent';\n\n  /**\n   * Whether the field is required\n   * @default true\n   */\n  @Input()\n  public required = true;\n\n  /**\n   * Form field label behavior\n   * @default 'auto'\n   */\n  @Input()\n  public floatLabel: FloatLabelType = 'auto';\n\n  /**\n   * Form field appearance\n   * @default 'fill'\n   */\n  @Input()\n  public appearance: MatFormFieldAppearance = 'fill';\n\n  /**\n   * Form field reserved space for one line by default.\n   * @default 'dynamic'\n   */\n  @Input()\n  public subscriptSizing: SubscriptSizing = 'dynamic';\n\n  /**\n   * Input field label\n   */\n  @Input()\n  public fieldLabel = '';\n\n  /**\n   * Input field placeholder\n   * @default ''\n   */\n  @Input()\n  public placeHolder = '';\n\n  /**\n   * Optional Input field text prefix\n   * @default ''\n   */\n  @Input()\n  public inputPrefix?: string;\n\n  /**\n   * Optional Input field text suffix\n   * @default ''\n   */\n  @Input()\n  public inputSuffix?: string;\n\n  /**\n   * Input field control\n   * @ignore\n   */\n  public formControl = new FormControl('');\n\n  /**\n   * Input field error message\n   * @ignore\n   */\n  public errorMessage: string = '';\n\n  /**\n   * Optional validators for the field\n   * @default ''\n   */\n  @Input()\n  public validatorsWithMessages: { [key: string]: ValidatorWithMessage } = {};\n\n  /**\n   * Optional async validators for the field\n   * @default ''\n   */\n  @Input()\n  public asyncValidatorsWithMessages: { [key: string]: ValidatorWithMessage } =\n    {};\n\n  /**\n   * Input field changes handler\n   */\n  @Output()\n  public inputStatus = new EventEmitter<FormControl>();\n\n  /**\n   * @ignore\n   * Class constructor\n   */\n  constructor() {\n    merge(this.formControl.statusChanges, this.formControl.valueChanges)\n      .pipe(takeUntilDestroyed())\n      .subscribe(() => {\n        this.updateErrorMessage();\n      });\n  }\n\n  /**\n   * Component lifecycle method\n   * @ignore\n   */\n  ngOnInit(): void {\n    this.applyValidators();\n  }\n\n  /**\n   * Component lifecycle method\n   * @ignore\n   */\n  ngOnChanges(changes: SimpleChanges): void {\n    if (\n      changes['validatorsWithMessages'] ||\n      changes['asyncValidatorsWithMessages']\n    ) {\n      this.applyValidators();\n    }\n  }\n\n  /**\n   * @ignore\n   * Component lifecycle method\n   */\n  private isThereAnyValidator(validatorsWithMessages: {\n    [key: string]: ValidatorWithMessage;\n  }): boolean {\n    return Object.keys(validatorsWithMessages).length > 0;\n  }\n\n  /**\n   * Applies all the passed validators\n   * @ignore\n   */\n  private applyValidators(): void {\n    const hasSyncValidators = this.isThereAnyValidator(\n      this.validatorsWithMessages\n    );\n\n    const hasAsyncValidators = this.isThereAnyValidator(\n      this.asyncValidatorsWithMessages\n    );\n\n    const activeValidators: ValidatorFn[] = hasSyncValidators\n      ? Object.values(this.validatorsWithMessages).map(\n          validatorWithMessage => validatorWithMessage.validator\n        )\n      : [];\n\n    const activeAsyncValidators: AsyncValidatorFn[] = hasAsyncValidators\n      ? Object.values(this.asyncValidatorsWithMessages).map(\n          validatorWithMessage =>\n            validatorWithMessage.validator as AsyncValidatorFn\n        )\n      : [];\n\n    if (hasSyncValidators || hasAsyncValidators) {\n      this.formControl.setValidators(activeValidators);\n      this.formControl.setAsyncValidators(activeAsyncValidators);\n      this.formControl.updateValueAndValidity();\n    }\n  }\n\n  /**\n   * Checks if there is any validation error\n   * @ignore\n   */\n  private checkValidationErrors(\n    errors: ValidationErrors | null,\n    validatorsWithMessages: {\n      [key: string]: ValidatorWithMessage;\n    }\n  ): void {\n    for (const errorKey in errors) {\n      if (validatorsWithMessages[errorKey]) {\n        this.errorMessage = validatorsWithMessages[errorKey].message;\n      }\n    }\n  }\n\n  /**\n   * Emits the formControl variable every time the field value changes\n   * @ignore\n   */\n  public onInputChanged(): void {\n    this.inputStatus.emit(this.formControl);\n  }\n\n  /**\n   * Updates the error message every time the input value changes\n   * @ignore\n   */\n  public updateErrorMessage(): void {\n    this.errorMessage = '';\n    const errors = this.formControl.errors;\n\n    if (!errors) {\n      this.errorMessage = '';\n      return;\n    }\n\n    this.checkValidationErrors(errors, this.validatorsWithMessages);\n    this.checkValidationErrors(errors, this.asyncValidatorsWithMessages);\n    this.onInputChanged();\n  }\n}\n","<section class=\"section\">\n  @if (fieldTitle) {\n    <h1 class=\"field__title\">{{ fieldTitle }}</h1>\n  }\n  <div class=\"field\" [ngStyle]=\"{ width: fieldWidth }\">\n    <mat-form-field\n      class=\"form__field\"\n      [color]=\"theme\"\n      [appearance]=\"appearance\"\n      [floatLabel]=\"floatLabel\"\n      [subscriptSizing]=\"subscriptSizing\">\n      <mat-label class=\"form__field__label\">{{ fieldLabel }}</mat-label>\n      <input\n        matInput\n        [required]=\"required\"\n        (input)=\"onInputChanged()\"\n        [placeholder]=\"placeHolder\"\n        [formControl]=\"formControl\"\n        (blur)=\"updateErrorMessage()\" />\n      @if (inputPrefix) {\n        <span class=\"form__field__label\" matTextPrefix\n          >{{ inputPrefix }}&nbsp;</span\n        >\n      }\n      @if (inputSuffix) {\n        <span class=\"form__field__label\" matTextSuffix>{{ inputSuffix }}</span>\n      }\n      @if (formControl.invalid) {\n        <mat-error class=\"form__field__error\">{{ errorMessage }}</mat-error>\n      }\n    </mat-form-field>\n  </div>\n</section>\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24tbGlzdC1pdGVtLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGVzaWduLXN5c3RlbS9jb21wb25lbnRzL3RrLWRyb3Bkb3duLWxpc3QvbW9kZWxzL2Ryb3Bkb3duLWxpc3QtaXRlbS5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueSAqL1xuZXhwb3J0IGludGVyZmFjZSBEcm9wZG93bkxpc3RJdGVtIHtcbiAgVmFsdWU6IGFueTtcbiAgVmlld1ZhbHVlOiBhbnk7XG59XG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './tk-dropdown-list.component';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1zeXN0ZW0vY29tcG9uZW50cy90ay1kcm9wZG93bi1saXN0L3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw4QkFBOEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vdGstZHJvcGRvd24tbGlzdC5jb21wb25lbnQnO1xuIl19
|
package/esm2022/components/tk-dropdown-list/tekus-design-system-components-tk-dropdown-list.mjs
ADDED
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './public-api';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVrdXMtZGVzaWduLXN5c3RlbS1jb21wb25lbnRzLXRrLWRyb3Bkb3duLWxpc3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tc3lzdGVtL2NvbXBvbmVudHMvdGstZHJvcGRvd24tbGlzdC90ZWt1cy1kZXNpZ24tc3lzdGVtLWNvbXBvbmVudHMtdGstZHJvcGRvd24tbGlzdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpYy1hcGknO1xuIl19
|