@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.
Files changed (87) hide show
  1. package/assets/styles/_index.scss +1 -0
  2. package/assets/styles/_variables.scss +284 -0
  3. package/components/{search-bar → forms}/index.d.ts +1 -1
  4. package/components/forms/public-api.d.ts +3 -0
  5. package/components/forms/tk-form-autocomplete-field/index.d.ts +5 -0
  6. package/components/forms/tk-form-autocomplete-field/models/option.model.d.ts +4 -0
  7. package/components/forms/tk-form-autocomplete-field/public-api.d.ts +1 -0
  8. package/components/forms/tk-form-autocomplete-field/tk-form-autocomplete-field.component.d.ts +158 -0
  9. package/components/forms/tk-form-chips-autocomplete-field/index.d.ts +5 -0
  10. package/components/forms/tk-form-chips-autocomplete-field/models/option.model.d.ts +4 -0
  11. package/components/forms/tk-form-chips-autocomplete-field/public-api.d.ts +1 -0
  12. package/components/forms/tk-form-chips-autocomplete-field/tk-form-chips-autocomplete-field.component.d.ts +114 -0
  13. package/components/forms/tk-form-input-field/index.d.ts +5 -0
  14. package/components/forms/tk-form-input-field/models/validator-with-message.model.d.ts +5 -0
  15. package/components/forms/tk-form-input-field/public-api.d.ts +1 -0
  16. package/components/forms/tk-form-input-field/tk-form-input-field.component.d.ts +132 -0
  17. package/components/tk-dropdown-list/index.d.ts +5 -0
  18. package/components/tk-dropdown-list/public-api.d.ts +1 -0
  19. package/components/{dropdown-list/dropdown-list.component.d.ts → tk-dropdown-list/tk-dropdown-list.component.d.ts} +3 -3
  20. package/components/{dropdown-list → tk-search-bar}/index.d.ts +1 -1
  21. package/components/tk-search-bar/public-api.d.ts +1 -0
  22. package/components/{search-bar/search-bar.component.d.ts → tk-search-bar/tk-search-bar.component.d.ts} +3 -3
  23. package/components/tk-typography/index.d.ts +5 -0
  24. package/components/tk-typography/public-api.d.ts +1 -0
  25. package/components/tk-typography/tk-typography.component.d.ts +10 -0
  26. package/esm2022/components/forms/public-api.mjs +4 -0
  27. package/esm2022/components/forms/tekus-design-system-components-forms.mjs +5 -0
  28. package/esm2022/components/forms/tk-form-autocomplete-field/models/option.model.mjs +2 -0
  29. package/esm2022/components/forms/tk-form-autocomplete-field/public-api.mjs +2 -0
  30. package/esm2022/components/forms/tk-form-autocomplete-field/tekus-design-system-components-forms-tk-form-autocomplete-field.mjs +5 -0
  31. package/esm2022/components/forms/tk-form-autocomplete-field/tk-form-autocomplete-field.component.mjs +238 -0
  32. package/esm2022/components/forms/tk-form-chips-autocomplete-field/models/option.model.mjs +2 -0
  33. package/esm2022/components/forms/tk-form-chips-autocomplete-field/public-api.mjs +2 -0
  34. package/esm2022/components/forms/tk-form-chips-autocomplete-field/tekus-design-system-components-forms-tk-form-chips-autocomplete-field.mjs +5 -0
  35. package/esm2022/components/forms/tk-form-chips-autocomplete-field/tk-form-chips-autocomplete-field.component.mjs +167 -0
  36. package/esm2022/components/forms/tk-form-input-field/models/validator-with-message.model.mjs +2 -0
  37. package/esm2022/components/forms/tk-form-input-field/public-api.mjs +2 -0
  38. package/esm2022/components/forms/tk-form-input-field/tekus-design-system-components-forms-tk-form-input-field.mjs +5 -0
  39. package/esm2022/components/forms/tk-form-input-field/tk-form-input-field.component.mjs +199 -0
  40. package/esm2022/components/tk-dropdown-list/models/dropdown-list-item.model.mjs +2 -0
  41. package/esm2022/components/tk-dropdown-list/public-api.mjs +2 -0
  42. package/esm2022/components/tk-dropdown-list/tekus-design-system-components-tk-dropdown-list.mjs +5 -0
  43. package/esm2022/components/tk-dropdown-list/tk-dropdown-list.component.mjs +137 -0
  44. package/esm2022/components/tk-search-bar/public-api.mjs +2 -0
  45. package/esm2022/components/tk-search-bar/tekus-design-system-components-tk-search-bar.mjs +5 -0
  46. package/esm2022/components/tk-search-bar/tk-search-bar.component.mjs +49 -0
  47. package/esm2022/components/tk-typography/public-api.mjs +2 -0
  48. package/esm2022/components/tk-typography/tekus-design-system-components-tk-typography.mjs +5 -0
  49. package/esm2022/components/tk-typography/tk-typography.component.mjs +29 -0
  50. package/esm2022/services/typography/models/typographyStyles.model.mjs +2 -0
  51. package/esm2022/services/typography/public-api.mjs +2 -0
  52. package/esm2022/services/typography/tekus-design-system-services-typography.mjs +5 -0
  53. package/esm2022/services/typography/typography.service.mjs +84 -0
  54. package/fesm2022/tekus-design-system-components-forms-tk-form-autocomplete-field.mjs +245 -0
  55. package/fesm2022/tekus-design-system-components-forms-tk-form-autocomplete-field.mjs.map +1 -0
  56. package/fesm2022/tekus-design-system-components-forms-tk-form-chips-autocomplete-field.mjs +174 -0
  57. package/fesm2022/tekus-design-system-components-forms-tk-form-chips-autocomplete-field.mjs.map +1 -0
  58. package/fesm2022/tekus-design-system-components-forms-tk-form-input-field.mjs +206 -0
  59. package/fesm2022/tekus-design-system-components-forms-tk-form-input-field.mjs.map +1 -0
  60. package/fesm2022/tekus-design-system-components-forms.mjs +590 -0
  61. package/fesm2022/tekus-design-system-components-forms.mjs.map +1 -0
  62. package/fesm2022/{tekus-design-system-components-dropdown-list.mjs → tekus-design-system-components-tk-dropdown-list.mjs} +7 -7
  63. package/fesm2022/tekus-design-system-components-tk-dropdown-list.mjs.map +1 -0
  64. package/fesm2022/tekus-design-system-components-tk-search-bar.mjs +56 -0
  65. package/fesm2022/tekus-design-system-components-tk-search-bar.mjs.map +1 -0
  66. package/fesm2022/tekus-design-system-components-tk-typography.mjs +36 -0
  67. package/fesm2022/tekus-design-system-components-tk-typography.mjs.map +1 -0
  68. package/fesm2022/tekus-design-system-services-typography.mjs +91 -0
  69. package/fesm2022/tekus-design-system-services-typography.mjs.map +1 -0
  70. package/package.json +55 -15
  71. package/services/typography/index.d.ts +5 -0
  72. package/services/typography/models/typographyStyles.model.d.ts +36 -0
  73. package/services/typography/public-api.d.ts +1 -0
  74. package/services/typography/typography.service.d.ts +8 -0
  75. package/components/dropdown-list/public-api.d.ts +0 -2
  76. package/components/search-bar/public-api.d.ts +0 -1
  77. package/esm2022/components/dropdown-list/dropdown-list.component.mjs +0 -137
  78. package/esm2022/components/dropdown-list/models/dropdown-list-item.model.mjs +0 -2
  79. package/esm2022/components/dropdown-list/public-api.mjs +0 -3
  80. package/esm2022/components/dropdown-list/tekus-design-system-components-dropdown-list.mjs +0 -5
  81. package/esm2022/components/search-bar/public-api.mjs +0 -2
  82. package/esm2022/components/search-bar/search-bar.component.mjs +0 -83
  83. package/esm2022/components/search-bar/tekus-design-system-components-search-bar.mjs +0 -5
  84. package/fesm2022/tekus-design-system-components-dropdown-list.mjs.map +0 -1
  85. package/fesm2022/tekus-design-system-components-search-bar.mjs +0 -90
  86. package/fesm2022/tekus-design-system-components-search-bar.mjs.map +0 -1
  87. /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":"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","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 }}&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", 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 }}&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", 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
@@ -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