@rlucan/ui 16.2.2 → 17.1.2

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 (77) hide show
  1. package/esm2022/lib/action-button/action-button.component.mjs +99 -99
  2. package/esm2022/lib/action-icon/action-icon.component.mjs +37 -37
  3. package/esm2022/lib/autocomplete/autocomplete.component.mjs +391 -391
  4. package/esm2022/lib/avatar/avatar.component.mjs +34 -34
  5. package/esm2022/lib/button/button.component.mjs +57 -57
  6. package/esm2022/lib/checkbox/checkbox.component.mjs +39 -39
  7. package/esm2022/lib/checkbox-group/checkbox-group.component.mjs +91 -91
  8. package/esm2022/lib/currency/currency.component.mjs +151 -151
  9. package/esm2022/lib/date/date.component.mjs +68 -68
  10. package/esm2022/lib/dialog/dialog.component.mjs +37 -37
  11. package/esm2022/lib/directives/force-visibility/force-visibility.directive.mjs +104 -104
  12. package/esm2022/lib/editor/editor.component.mjs +119 -119
  13. package/esm2022/lib/elements/burger/burger.component.mjs +21 -21
  14. package/esm2022/lib/elements/expander/expander.component.mjs +28 -28
  15. package/esm2022/lib/elements/validation-message/validation-message.component.mjs +47 -47
  16. package/esm2022/lib/file/file.component.mjs +166 -145
  17. package/esm2022/lib/file-uploader/ui-file-uploader.component.mjs +423 -405
  18. package/esm2022/lib/input/input.component.mjs +265 -265
  19. package/esm2022/lib/input-autocomplete/input-autocomplete.component.mjs +277 -277
  20. package/esm2022/lib/layouts/base/ui-base-layout.component.mjs +22 -22
  21. package/esm2022/lib/layouts/base/ui-base.component.mjs +74 -74
  22. package/esm2022/lib/layouts/simple/ui-simple-layout.component.mjs +18 -18
  23. package/esm2022/lib/layouts/simple/ui-simple.component.mjs +166 -166
  24. package/esm2022/lib/radio/radio.component.mjs +21 -21
  25. package/esm2022/lib/radio-group/radio-group.component.mjs +53 -53
  26. package/esm2022/lib/select/select.component.mjs +126 -126
  27. package/esm2022/lib/services/message-box.service.mjs +112 -112
  28. package/esm2022/lib/services/toast.service.mjs +23 -23
  29. package/esm2022/lib/services/ui-file.service.mjs +72 -71
  30. package/esm2022/lib/services/ui-translate.service.mjs +32 -32
  31. package/esm2022/lib/submit-button/submit-button.component.mjs +72 -72
  32. package/esm2022/lib/table/table.component.mjs +97 -97
  33. package/esm2022/lib/text-area/text-area.component.mjs +46 -46
  34. package/esm2022/lib/ui.model.mjs +1 -1
  35. package/esm2022/lib/ui.module.mjs +269 -269
  36. package/esm2022/public-api.mjs +34 -34
  37. package/esm2022/rlucan-ui.mjs +4 -4
  38. package/fesm2022/rlucan-ui.mjs +3329 -3289
  39. package/fesm2022/rlucan-ui.mjs.map +1 -1
  40. package/index.d.ts +5 -5
  41. package/lib/action-button/action-button.component.d.ts +28 -28
  42. package/lib/action-icon/action-icon.component.d.ts +15 -15
  43. package/lib/autocomplete/autocomplete.component.d.ts +57 -57
  44. package/lib/avatar/avatar.component.d.ts +14 -14
  45. package/lib/button/button.component.d.ts +18 -18
  46. package/lib/checkbox/checkbox.component.d.ts +15 -15
  47. package/lib/checkbox-group/checkbox-group.component.d.ts +18 -18
  48. package/lib/currency/currency.component.d.ts +31 -31
  49. package/lib/date/date.component.d.ts +24 -24
  50. package/lib/dialog/dialog.component.d.ts +13 -13
  51. package/lib/directives/force-visibility/force-visibility.directive.d.ts +22 -22
  52. package/lib/editor/editor.component.d.ts +24 -24
  53. package/lib/elements/burger/burger.component.d.ts +9 -9
  54. package/lib/elements/expander/expander.component.d.ts +10 -10
  55. package/lib/elements/validation-message/validation-message.component.d.ts +12 -12
  56. package/lib/file/file.component.d.ts +36 -35
  57. package/lib/file-uploader/ui-file-uploader.component.d.ts +106 -102
  58. package/lib/input/input.component.d.ts +42 -42
  59. package/lib/input-autocomplete/input-autocomplete.component.d.ts +44 -44
  60. package/lib/layouts/base/ui-base-layout.component.d.ts +8 -8
  61. package/lib/layouts/base/ui-base.component.d.ts +23 -23
  62. package/lib/layouts/simple/ui-simple-layout.component.d.ts +8 -8
  63. package/lib/layouts/simple/ui-simple.component.d.ts +40 -40
  64. package/lib/radio/radio.component.d.ts +8 -8
  65. package/lib/radio-group/radio-group.component.d.ts +18 -18
  66. package/lib/select/select.component.d.ts +37 -37
  67. package/lib/services/message-box.service.d.ts +58 -58
  68. package/lib/services/toast.service.d.ts +13 -13
  69. package/lib/services/ui-file.service.d.ts +37 -33
  70. package/lib/services/ui-translate.service.d.ts +11 -11
  71. package/lib/submit-button/submit-button.component.d.ts +21 -21
  72. package/lib/table/table.component.d.ts +36 -36
  73. package/lib/text-area/text-area.component.d.ts +18 -18
  74. package/lib/ui.model.d.ts +2 -2
  75. package/lib/ui.module.d.ts +59 -59
  76. package/package.json +14 -14
  77. package/public-api.d.ts +29 -29
@@ -1,265 +1,265 @@
1
- import { Component, EventEmitter, Host, HostBinding, Input, Optional, Output, SkipSelf, ViewChild } from '@angular/core';
2
- import { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';
3
- import { UiSimpleComponent } from '../layouts/simple/ui-simple.component';
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "@angular/forms";
6
- import * as i2 from "@angular/common";
7
- import * as i3 from "@angular/material/icon";
8
- import * as i4 from "@angular/material/tooltip";
9
- import * as i5 from "../layouts/simple/ui-simple-layout.component";
10
- import * as i6 from "../action-icon/action-icon.component";
11
- export class InputComponent extends UiSimpleComponent {
12
- get textAlignClass() {
13
- return `text-align-${this.textAlign}`;
14
- }
15
- get hasPrefix() {
16
- return (this.prefixIcon && this.prefixIcon.icon !== '') || this.prefix?.nativeElement?.innerText !== '' || this.forceHasPrefix;
17
- }
18
- get hasSuffix() {
19
- return (this.suffixIcon && this.suffixIcon.icon !== '') || this.suffix?.nativeElement?.innerText !== '' || this.forceHasSuffix;
20
- }
21
- // control;
22
- // onTouched = () => {};
23
- // onChange = (value) => {};
24
- // get showInvalid(): boolean {
25
- // return true;
26
- // // return this.control.touched && !!this.control.errors;
27
- // }
28
- // get validationMessage(): string {
29
- // // console.log(this.control?.errors);
30
- // let e: any = {code: 'Neznámá chyba'};
31
- // const errors = this.control?.errors || {};
32
- // Object.keys(errors).find(a => {
33
- // e = {code: a, data: errors[a]};
34
- // return true;
35
- // });
36
- // switch (e.code) {
37
- // case 'required':
38
- // return this.translateService.instant('ui.controls.validation.required');
39
- // case 'email':
40
- // return this.translateService.instant('ui.controls.validation.email');
41
- // case 'matDatepickerParse':
42
- // return this.translateService.instant('ui.controls.validation.matDatepickerParse');
43
- // case 'maxlength':
44
- // return this.translateService.instant('ui.controls.validation.maxlength', e.data);
45
- // case 'minlength':
46
- // return this.translateService.instant('ui.controls.validation.minlength', e.data);
47
- // case 'positive':
48
- // return this.translateService.instant(isNaN(Number(e.data)) ? 'ui.controls.validation.invalidNumber' : 'ui.controls.validation.positive');
49
- // case 'custom':
50
- // return this.translateService.instant(e.data);
51
- // default:
52
- // return this.translateService.instant(e.code);
53
- // }
54
- // }
55
- get maxLenRequired() {
56
- return true;
57
- // return this.control.value && (this.control.value.length > (this.validators?.maxLength || 0));
58
- }
59
- constructor(controlContainer) {
60
- super(null, controlContainer);
61
- this.controlContainer = controlContainer;
62
- this.type = 'text';
63
- this.clearButton = false;
64
- this.activeIcons = true;
65
- this.forceHasPrefix = false;
66
- this.forceHasSuffix = false;
67
- this.textAlign = 'left';
68
- this.focusChanged = new EventEmitter();
69
- this.keyPressed = new EventEmitter();
70
- // control = new FormControl();
71
- this.required = false;
72
- this.hasFocus = false;
73
- // this.componentFormControl = new FormControl();
74
- // super();
75
- // super(undefined, /*ngControl*/ translateService);
76
- // super(control);
77
- // console.log(control);
78
- // if (control) {
79
- // control.valueAccessor = this;
80
- // }
81
- // if (ngControl != null) {
82
- // // Setting the value accessor directly (instead of using
83
- // // the providers) to avoid running into a circular import.
84
- // ngControl.valueAccessor = this;
85
- // }
86
- }
87
- get showClearButton() {
88
- return this.clearButton && this.componentFormControl?.value !== '';
89
- }
90
- ngOnInit() {
91
- super.ngOnInit();
92
- // console.log('probiha vubec oninit?');
93
- // if (this.ngControl) {
94
- // console.log('from ngControl....??');
95
- // if (this.formControl) {
96
- // this.componentFormControl = this.formControl;
97
- // } else {
98
- // this.componentFormControl = this.ngControl.control as UntypedFormControl;
99
- // }
100
- // setTimeout(() => {
101
- // this.applyValidators();
102
- // });
103
- // } else {
104
- // const control = this.formControlName ?
105
- // (this.controlContainer as FormGroupDirective).control.get(this.formControlName) : this.formControl;
106
- // this.componentFormControl.setValidators(control.validator);
107
- // this.componentFormControl.valueChanges.subscribe(v => console.log('onitin sub', v));
108
- // control._componentFormControl = this.componentFormControl;
109
- // if (control._markAsTouched === undefined) {
110
- // // control._componentFormControl = this.componentFormControl;
111
- // console.log('overriding markAsTouched for', this.formControlName);
112
- // control._markAsTouched = control.markAsTouched;
113
- // control.markAsTouched = ({onlySelf}: { onlySelf?: boolean } = {}): void => {
114
- // console.log('marking as touched', this.componentFormControl.value, control.value, this.xxx.value, control._componentFormControl.value);
115
- // control._markAsTouched({onlySelf});
116
- // setTimeout(() => control._componentFormControl.markAsTouched(), 1000);
117
- // }
118
- // }
119
- // }
120
- }
121
- clearValue() {
122
- this.componentFormControl?.setValue('');
123
- this.input?.nativeElement.focus();
124
- }
125
- focus() {
126
- this.input?.nativeElement.focus();
127
- }
128
- onFocus(focus) {
129
- setTimeout(() => {
130
- this.hasFocus = focus;
131
- this.focusChanged.emit(focus);
132
- });
133
- }
134
- onKeypressed($event) {
135
- this.keyPressed.emit($event);
136
- }
137
- // registerOnChange(onChange: any): void {
138
- // this.onChange = onChange;
139
- // }
140
- //
141
- // registerOnTouched(onTouched: any): void {
142
- // this.onTouched = onTouched;
143
- // }
144
- // registerOnValidatorChange(fn: () => void): void {
145
- // }
146
- // setDisabledState(isDisabled: boolean): void {
147
- // // isDisabled ? this.control.disable() : this.control.enable();
148
- // }
149
- // validate(control: AbstractControl): ValidationErrors | null {
150
- // // this.control = control;
151
- // // console.log(control, control.value, control.errors);
152
- // if (this.value === 'error') {
153
- // return { customError: 'muj error'}
154
- // } else {
155
- // return null;
156
- // }
157
- // // console.log('custom validate');
158
- // // return null;
159
- // }
160
- //
161
- // writeValue(obj: any): void {
162
- // console.log('writevalue: ', obj);
163
- // this.componentFormControl.setValue(obj);
164
- // // this.value = obj;
165
- // // this.control.setValue(obj);
166
- // }
167
- //
168
- // registerOnChange(fn: any): void {
169
- // }
170
- //
171
- // registerOnTouched(fn: any): void {
172
- // }
173
- //
174
- // setDisabledState(isDisabled: boolean): void {
175
- // }
176
- // modelChange($event: any) {
177
- // console.log($event);
178
- // this.onTouched();
179
- // this.onChange($event)
180
- // }
181
- // validate(control: AbstractControl): ValidationErrors | null {
182
- // console.log(this.label, 'validate');
183
- // return this.componentFormControl.errors;
184
- // // return undefined;
185
- // }
186
- validate(control) {
187
- if (this.parentFormControl) {
188
- return this.parentFormControl._componentFormControl.errors;
189
- }
190
- // console.log('validate', this.componentFormControl.errors);
191
- // // this.componentFormControl.setErrors( { custom: 'xxx' });
192
- // this.componentFormControl.setErrors( this.componentFormControl.errors);
193
- // console.log('validate 2', this.componentFormControl.errors);
194
- // return this.componentFormControl.errors;
195
- // console.log(this.componentFormControl.errors, control.errors, this.parentFormControl.errors, this);
196
- // return this.componentFormControl.errors;
197
- }
198
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: InputComponent, deps: [{ token: i1.ControlContainer, host: true, optional: true, skipSelf: true }], target: i0.ɵɵFactoryTarget.Component }); }
199
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.11", type: InputComponent, selector: "ui-input", inputs: { prefixIcon: "prefixIcon", suffixIcon: "suffixIcon", type: "type", clearButton: "clearButton", activeIcons: "activeIcons", forceHasPrefix: "forceHasPrefix", forceHasSuffix: "forceHasSuffix", textAlign: "textAlign" }, outputs: { focusChanged: "focusChanged", keyPressed: "keyPressed" }, host: { properties: { "class": "this.textAlignClass" } }, providers: [
200
- {
201
- provide: NG_VALUE_ACCESSOR,
202
- multi: true,
203
- useExisting: InputComponent
204
- },
205
- {
206
- provide: NG_VALIDATORS,
207
- multi: true,
208
- useExisting: InputComponent
209
- }
210
- ], viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }, { propertyName: "prefix", first: true, predicate: ["prefix"], descendants: true, static: true }, { propertyName: "suffix", first: true, predicate: ["suffix"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<ui-simple-layout [ctx]=\"this\">\r\n\r\n<div class=\"control-container\" [ngClass]=\"{'has-suffix': hasSuffix, 'has-prefix': hasPrefix, 'has-clear-icon': showClearButton, 'active-icons': activeIcons, 'has-focus': hasFocus}\">\r\n <input #input [type]=\"type\" [formControl]=\"componentFormControl\" [placeholder]=\"placeholder\" (keydown)=\"onKeypressed($event)\" (focus)=\"onFocus(true)\" (blur)=\"onFocus(false)\" />\r\n <div #prefix><ng-content select=\"[slot=prefix]\"></ng-content></div>\r\n <div #suffix><ng-content select=\"[slot=suffix]\"></ng-content></div>\r\n <mat-icon *ngIf=\"prefixIcon\" class=\"prefix-icon\" [matTooltip]=\"prefixIcon.tooltip\">{{ prefixIcon.icon }}</mat-icon>\r\n <mat-icon *ngIf=\"suffixIcon\" class=\"suffix-icon\" [matTooltip]=\"suffixIcon.tooltip\">{{ suffixIcon.icon }}</mat-icon>\r\n <ui-action-icon [size]=\"'small'\" [color]=\"'warn'\" *ngIf=\"showClearButton\" (click)=\"clearValue()\" [matIcon]=\"'clear'\" class=\"clear-icon\"></ui-action-icon>\r\n</div>\r\n\r\n</ui-simple-layout>\r\n", styles: [":host{display:flex;flex-direction:column;width:100%}:host .control-container{width:100%;position:relative}:host .control-container.has-prefix ::ng-deep input,:host .control-container.has-prefix ::ng-deep textarea,:host .control-container.has-prefix ::ng-deep .mat-mdc-select-trigger{padding-left:1.8em}:host .control-container.has-suffix:not(.has-clear-icon) ::ng-deep input,:host .control-container.has-suffix:not(.has-clear-icon) ::ng-deep textarea,:host .control-container.has-suffix:not(.has-clear-icon) ::ng-deep .mat-mdc-select-trigger{padding-right:1.8em}:host .control-container.has-clear-icon:not(.has-suffix) ::ng-deep input,:host .control-container.has-clear-icon:not(.has-suffix) ::ng-deep textarea,:host .control-container.has-clear-icon:not(.has-suffix) ::ng-deep .mat-mdc-select-trigger{padding-right:1.8em}:host .control-container.has-suffix.has-clear-icon ::ng-deep input,:host .control-container.has-suffix.has-clear-icon ::ng-deep textarea,:host .control-container.has-suffix.has-clear-icon ::ng-deep .mat-mdc-select-trigger{padding-right:3.6em}:host .control-container.has-suffix.has-clear-icon ::ng-deep .clear-icon{right:1.4em!important}:host ::ng-deep [slot=suffix],:host ::ng-deep .clear-icon,:host ::ng-deep .suffix-icon{position:absolute;-webkit-user-select:none;user-select:none;transition:color .25s;top:calc(50% - .5em);right:.2em;width:1em;height:1em;font-size:1.5em}:host ::ng-deep [slot=suffix]:not(.disabled),:host ::ng-deep .clear-icon:not(.disabled),:host ::ng-deep .suffix-icon:not(.disabled){cursor:pointer}:host ::ng-deep [slot=prefix],:host ::ng-deep .prefix-icon{position:absolute;-webkit-user-select:none;user-select:none;transition:color .25s;top:calc(50% - .5em);left:.2em;width:1em;height:1em;font-size:1.5em}:host ::ng-deep [slot=prefix]:not(.disabled),:host ::ng-deep .prefix-icon:not(.disabled){cursor:pointer}:host ::ng-deep input,:host ::ng-deep textarea,:host ::ng-deep .mat-mdc-select-trigger,:host ::ng-deep .editor-wrapper{resize:none;width:100%;line-height:1.2em;font-size:1em;outline:none;border-style:solid;transition:border-color 333ms}:host ::ng-deep textarea.autoresize{box-sizing:content-box;width:calc(100% - 1.4em)}:host ::ng-deep ::ng-deep .mat-select-trigger,:host ::ng-deep ::ng-deep .mat-mdc-select-trigger{height:100%}:host ::ng-deep ::ng-deep .mat-select-value,:host ::ng-deep ::ng-deep .mat-mdc-select-value{vertical-align:middle}::ng-deep ui-input{display:block}\n", ":host.text-align-left ::ng-deep input{text-align:left}:host.text-align-right ::ng-deep input{text-align:right}:host.text-align-center ::ng-deep input{text-align:center}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { 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.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i5.UiSimpleLayoutComponent, selector: "ui-simple-layout", inputs: ["ctx"] }, { kind: "component", type: i6.ActionIconComponent, selector: "ui-action-icon", inputs: ["size", "color", "disabled", "busy", "matIcon"] }] }); }
211
- }
212
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: InputComponent, decorators: [{
213
- type: Component,
214
- args: [{ selector: 'ui-input', providers: [
215
- {
216
- provide: NG_VALUE_ACCESSOR,
217
- multi: true,
218
- useExisting: InputComponent
219
- },
220
- {
221
- provide: NG_VALIDATORS,
222
- multi: true,
223
- useExisting: InputComponent
224
- }
225
- ], template: "<ui-simple-layout [ctx]=\"this\">\r\n\r\n<div class=\"control-container\" [ngClass]=\"{'has-suffix': hasSuffix, 'has-prefix': hasPrefix, 'has-clear-icon': showClearButton, 'active-icons': activeIcons, 'has-focus': hasFocus}\">\r\n <input #input [type]=\"type\" [formControl]=\"componentFormControl\" [placeholder]=\"placeholder\" (keydown)=\"onKeypressed($event)\" (focus)=\"onFocus(true)\" (blur)=\"onFocus(false)\" />\r\n <div #prefix><ng-content select=\"[slot=prefix]\"></ng-content></div>\r\n <div #suffix><ng-content select=\"[slot=suffix]\"></ng-content></div>\r\n <mat-icon *ngIf=\"prefixIcon\" class=\"prefix-icon\" [matTooltip]=\"prefixIcon.tooltip\">{{ prefixIcon.icon }}</mat-icon>\r\n <mat-icon *ngIf=\"suffixIcon\" class=\"suffix-icon\" [matTooltip]=\"suffixIcon.tooltip\">{{ suffixIcon.icon }}</mat-icon>\r\n <ui-action-icon [size]=\"'small'\" [color]=\"'warn'\" *ngIf=\"showClearButton\" (click)=\"clearValue()\" [matIcon]=\"'clear'\" class=\"clear-icon\"></ui-action-icon>\r\n</div>\r\n\r\n</ui-simple-layout>\r\n", styles: [":host{display:flex;flex-direction:column;width:100%}:host .control-container{width:100%;position:relative}:host .control-container.has-prefix ::ng-deep input,:host .control-container.has-prefix ::ng-deep textarea,:host .control-container.has-prefix ::ng-deep .mat-mdc-select-trigger{padding-left:1.8em}:host .control-container.has-suffix:not(.has-clear-icon) ::ng-deep input,:host .control-container.has-suffix:not(.has-clear-icon) ::ng-deep textarea,:host .control-container.has-suffix:not(.has-clear-icon) ::ng-deep .mat-mdc-select-trigger{padding-right:1.8em}:host .control-container.has-clear-icon:not(.has-suffix) ::ng-deep input,:host .control-container.has-clear-icon:not(.has-suffix) ::ng-deep textarea,:host .control-container.has-clear-icon:not(.has-suffix) ::ng-deep .mat-mdc-select-trigger{padding-right:1.8em}:host .control-container.has-suffix.has-clear-icon ::ng-deep input,:host .control-container.has-suffix.has-clear-icon ::ng-deep textarea,:host .control-container.has-suffix.has-clear-icon ::ng-deep .mat-mdc-select-trigger{padding-right:3.6em}:host .control-container.has-suffix.has-clear-icon ::ng-deep .clear-icon{right:1.4em!important}:host ::ng-deep [slot=suffix],:host ::ng-deep .clear-icon,:host ::ng-deep .suffix-icon{position:absolute;-webkit-user-select:none;user-select:none;transition:color .25s;top:calc(50% - .5em);right:.2em;width:1em;height:1em;font-size:1.5em}:host ::ng-deep [slot=suffix]:not(.disabled),:host ::ng-deep .clear-icon:not(.disabled),:host ::ng-deep .suffix-icon:not(.disabled){cursor:pointer}:host ::ng-deep [slot=prefix],:host ::ng-deep .prefix-icon{position:absolute;-webkit-user-select:none;user-select:none;transition:color .25s;top:calc(50% - .5em);left:.2em;width:1em;height:1em;font-size:1.5em}:host ::ng-deep [slot=prefix]:not(.disabled),:host ::ng-deep .prefix-icon:not(.disabled){cursor:pointer}:host ::ng-deep input,:host ::ng-deep textarea,:host ::ng-deep .mat-mdc-select-trigger,:host ::ng-deep .editor-wrapper{resize:none;width:100%;line-height:1.2em;font-size:1em;outline:none;border-style:solid;transition:border-color 333ms}:host ::ng-deep textarea.autoresize{box-sizing:content-box;width:calc(100% - 1.4em)}:host ::ng-deep ::ng-deep .mat-select-trigger,:host ::ng-deep ::ng-deep .mat-mdc-select-trigger{height:100%}:host ::ng-deep ::ng-deep .mat-select-value,:host ::ng-deep ::ng-deep .mat-mdc-select-value{vertical-align:middle}::ng-deep ui-input{display:block}\n", ":host.text-align-left ::ng-deep input{text-align:left}:host.text-align-right ::ng-deep input{text-align:right}:host.text-align-center ::ng-deep input{text-align:center}\n"] }]
226
- }], ctorParameters: function () { return [{ type: i1.ControlContainer, decorators: [{
227
- type: Optional
228
- }, {
229
- type: Host
230
- }, {
231
- type: SkipSelf
232
- }] }]; }, propDecorators: { prefixIcon: [{
233
- type: Input
234
- }], suffixIcon: [{
235
- type: Input
236
- }], type: [{
237
- type: Input
238
- }], clearButton: [{
239
- type: Input
240
- }], activeIcons: [{
241
- type: Input
242
- }], forceHasPrefix: [{
243
- type: Input
244
- }], forceHasSuffix: [{
245
- type: Input
246
- }], textAlignClass: [{
247
- type: HostBinding,
248
- args: ['class']
249
- }], textAlign: [{
250
- type: Input
251
- }], input: [{
252
- type: ViewChild,
253
- args: ['input']
254
- }], prefix: [{
255
- type: ViewChild,
256
- args: ['prefix', { static: true }]
257
- }], suffix: [{
258
- type: ViewChild,
259
- args: ['suffix', { static: true }]
260
- }], focusChanged: [{
261
- type: Output
262
- }], keyPressed: [{
263
- type: Output
264
- }] } });
265
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../projects/ui/src/lib/input/input.component.ts","../../../../../projects/ui/src/lib/input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Host, HostBinding,\r\n  Input,\r\n  OnInit,\r\n  Optional,\r\n  Output,\r\n  SkipSelf,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { AbstractControl, ControlContainer, NG_VALIDATORS, NG_VALUE_ACCESSOR, ValidationErrors } from '@angular/forms';\r\nimport { UiSimpleComponent } from '../layouts/simple/ui-simple.component';\r\n\r\ntype PrefixSuffix = { icon: string, tooltip?: string };\r\n@Component({\r\n  selector: 'ui-input',\r\n  templateUrl: './input.component.html',\r\n  styleUrls: [ '../layouts/simple/ui-simple-layout.component.scss', './input.component.scss' ],\r\n\r\n  providers: [\r\n    {\r\n    provide: NG_VALUE_ACCESSOR,\r\n    multi: true,\r\n    useExisting: InputComponent\r\n  },\r\n  {\r\n    provide: NG_VALIDATORS,\r\n    multi: true,\r\n    useExisting: InputComponent\r\n  }\r\n  ]\r\n})\r\nexport class InputComponent extends UiSimpleComponent\r\n  implements OnInit { // }, ControlValueAccessor { // }, ControlValueAccessor, Validator { // }, AfterViewInit {\r\n\r\n  // UiSimpleComponent = InputComponent;\r\n\r\n  // @Input() placeholder = '';\r\n  // @Input() label: string | undefined;\r\n  // @Input() useInputMessages: 'never' | 'always' | 'ondemand' = 'always';\r\n  // @Input() hint: string | undefined;\r\n  // @Input() validators: UiValidators | undefined;\r\n  // @Input() size: 'small' | 'smaller' | 'normal' | 'larger' | 'large' = 'normal';\r\n  // @Input() formControlName;\r\n\r\n  // componentFormControl: UntypedFormControl;\r\n  //\r\n  // ngControl: NgControl;\r\n  //\r\n  // @Input() validators: UiValidators | undefined;\r\n  // @Input() formControlName;\r\n  //\r\n  // @Input() placeholder = '';\r\n  // @Input() label: string | undefined;\r\n  // @Input() useInputMessages: 'never' | 'always' | 'ondemand' = 'always';\r\n  // @Input() hint?: string;\r\n  // @Input() size: 'small' | 'smaller' | 'normal' | 'larger' | 'large' = 'normal';\r\n\r\n  @Input() prefixIcon: PrefixSuffix;\r\n  @Input() suffixIcon: PrefixSuffix;\r\n  @Input() type: 'text' | 'number' | 'password' = 'text';\r\n  @Input() clearButton = false;\r\n  @Input() activeIcons = true;\r\n  @Input() forceHasPrefix = false;\r\n  @Input() forceHasSuffix = false;\r\n\r\n  @HostBinding('class')\r\n  get textAlignClass() {\r\n    return `text-align-${this.textAlign}`;\r\n  }\r\n\r\n  @Input() textAlign: 'left' | 'center' | 'right' = 'left';\r\n\r\n  @ViewChild('input') input: ElementRef | undefined;\r\n  @ViewChild('prefix', { static: true }) prefix: ElementRef | undefined;\r\n  @ViewChild('suffix', { static: true }) suffix: ElementRef | undefined;\r\n\r\n  @Output() focusChanged = new EventEmitter<boolean>();\r\n  @Output() keyPressed = new EventEmitter<KeyboardEvent>();\r\n\r\n  get hasPrefix() {\r\n    return (this.prefixIcon && this.prefixIcon.icon !== '') || this.prefix?.nativeElement?.innerText !== '' || this.forceHasPrefix;\r\n  }\r\n\r\n  get hasSuffix() {\r\n    return (this.suffixIcon && this.suffixIcon.icon !== '') || this.suffix?.nativeElement?.innerText !== '' || this.forceHasSuffix;\r\n  }\r\n\r\n  // control = new FormControl();\r\n\r\n  required = false;\r\n  hasFocus = false;\r\n\r\n  value: string;\r\n\r\n  // control;\r\n\r\n\r\n  // onTouched = () => {};\r\n  // onChange = (value) => {};\r\n\r\n  // get showInvalid(): boolean {\r\n  //   return true;\r\n  //   // return this.control.touched && !!this.control.errors;\r\n  // }\r\n\r\n  // get validationMessage(): string {\r\n  //   // console.log(this.control?.errors);\r\n  //   let e: any = {code: 'Neznámá chyba'};\r\n  //   const errors = this.control?.errors || {};\r\n  //   Object.keys(errors).find(a => {\r\n  //     e = {code: a, data: errors[a]};\r\n  //     return true;\r\n  //   });\r\n  //   switch (e.code) {\r\n  //     case 'required':\r\n  //       return this.translateService.instant('ui.controls.validation.required');\r\n  //     case 'email':\r\n  //       return this.translateService.instant('ui.controls.validation.email');\r\n  //     case 'matDatepickerParse':\r\n  //       return this.translateService.instant('ui.controls.validation.matDatepickerParse');\r\n  //     case 'maxlength':\r\n  //       return this.translateService.instant('ui.controls.validation.maxlength', e.data);\r\n  //     case 'minlength':\r\n  //       return this.translateService.instant('ui.controls.validation.minlength', e.data);\r\n  //     case 'positive':\r\n  //       return this.translateService.instant(isNaN(Number(e.data)) ? 'ui.controls.validation.invalidNumber' : 'ui.controls.validation.positive');\r\n  //     case 'custom':\r\n  //       return this.translateService.instant(e.data);\r\n  //     default:\r\n  //       return this.translateService.instant(e.code);\r\n  //   }\r\n  // }\r\n\r\n  get maxLenRequired(): boolean {\r\n    return true;\r\n    // return this.control.value && (this.control.value.length > (this.validators?.maxLength || 0));\r\n  }\r\n\r\n\r\n  constructor(@Optional() @Host() @SkipSelf() protected controlContainer: ControlContainer,\r\n    /*\r\n    bud pres @Optional() @Self() public control: NgControl a control.valueAccessor = this => ztratime ale custom validaci\r\n    anebo pres DI jako providers a pak this.control = viz ngOnInit - pokud jej vubec potrebujem\r\n\r\n     */\r\n    // private injector: Injector,\r\n   // @Optional() @Self() public control: NgControl,\r\n    // @Self() private controlDirective: NgControl,\r\n   ) {\r\n    super(null, controlContainer);\r\n\r\n    // this.componentFormControl = new FormControl();\r\n    // super();\r\n  //  super(undefined, /*ngControl*/ translateService);\r\n    // super(control);\r\n    // console.log(control);\r\n    // if (control) {\r\n    //   control.valueAccessor = this;\r\n    // }\r\n\r\n    // if (ngControl != null) {\r\n    //   // Setting the value accessor directly (instead of using\r\n    //   // the providers) to avoid running into a circular import.\r\n    //   ngControl.valueAccessor = this;\r\n    // }\r\n  }\r\n\r\n  get showClearButton(): boolean {\r\n    return this.clearButton && this.componentFormControl?.value !== '';\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    super.ngOnInit();\r\n    // console.log('probiha vubec oninit?');\r\n    // if (this.ngControl) {\r\n    //   console.log('from ngControl....??');\r\n    //   if (this.formControl) {\r\n    //     this.componentFormControl = this.formControl;\r\n    //   } else {\r\n    //     this.componentFormControl = this.ngControl.control as UntypedFormControl;\r\n    //   }\r\n    //   setTimeout(() => {\r\n    //     this.applyValidators();\r\n    //   });\r\n    // } else {\r\n    //   const control = this.formControlName ?\r\n    //     (this.controlContainer as FormGroupDirective).control.get(this.formControlName) : this.formControl;\r\n    //   this.componentFormControl.setValidators(control.validator);\r\n    //   this.componentFormControl.valueChanges.subscribe(v => console.log('onitin sub', v));\r\n    //   control._componentFormControl = this.componentFormControl;\r\n    //   if (control._markAsTouched === undefined) {\r\n    //     // control._componentFormControl = this.componentFormControl;\r\n    //     console.log('overriding markAsTouched for', this.formControlName);\r\n    //     control._markAsTouched = control.markAsTouched;\r\n    //     control.markAsTouched = ({onlySelf}: { onlySelf?: boolean } = {}): void => {\r\n    //       console.log('marking as touched', this.componentFormControl.value, control.value, this.xxx.value, control._componentFormControl.value);\r\n    //       control._markAsTouched({onlySelf});\r\n    //       setTimeout(() => control._componentFormControl.markAsTouched(), 1000);\r\n    //     }\r\n    //   }\r\n    // }\r\n  }\r\n\r\n  clearValue(): void {\r\n    this.componentFormControl?.setValue('');\r\n    this.input?.nativeElement.focus();\r\n  }\r\n\r\n  focus(): void {\r\n    this.input?.nativeElement.focus();\r\n  }\r\n\r\n  onFocus(focus: boolean): void {\r\n    setTimeout(() => {\r\n      this.hasFocus = focus;\r\n      this.focusChanged.emit(focus);\r\n    });\r\n  }\r\n\r\n  onKeypressed($event: any): void {\r\n    this.keyPressed.emit($event);\r\n  }\r\n\r\n  // registerOnChange(onChange: any): void {\r\n  //   this.onChange = onChange;\r\n  // }\r\n  //\r\n  // registerOnTouched(onTouched: any): void {\r\n  //   this.onTouched = onTouched;\r\n  // }\r\n\r\n  // registerOnValidatorChange(fn: () => void): void {\r\n  // }\r\n\r\n  // setDisabledState(isDisabled: boolean): void {\r\n  //   // isDisabled ? this.control.disable() : this.control.enable();\r\n  // }\r\n\r\n  // validate(control: AbstractControl): ValidationErrors | null {\r\n  //   // this.control = control;\r\n  //   // console.log(control, control.value, control.errors);\r\n  //   if (this.value === 'error') {\r\n  //     return { customError: 'muj error'}\r\n  //   } else {\r\n  //     return null;\r\n  //   }\r\n  //   // console.log('custom validate');\r\n  //   // return null;\r\n  // }\r\n  //\r\n  // writeValue(obj: any): void {\r\n  //   console.log('writevalue: ', obj);\r\n  //   this.componentFormControl.setValue(obj);\r\n  //   // this.value = obj;\r\n  //   // this.control.setValue(obj);\r\n  // }\r\n  //\r\n  // registerOnChange(fn: any): void {\r\n  // }\r\n  //\r\n  // registerOnTouched(fn: any): void {\r\n  // }\r\n  //\r\n  // setDisabledState(isDisabled: boolean): void {\r\n  // }\r\n\r\n  // modelChange($event: any) {\r\n  //   console.log($event);\r\n  //   this.onTouched();\r\n  //   this.onChange($event)\r\n  // }\r\n\r\n  // validate(control: AbstractControl): ValidationErrors | null {\r\n  //   console.log(this.label, 'validate');\r\n  //   return this.componentFormControl.errors;\r\n  //   // return undefined;\r\n  // }\r\n\r\n  validate(control: AbstractControl): ValidationErrors | null {\r\n    if (this.parentFormControl) {\r\n      return this.parentFormControl._componentFormControl.errors;\r\n    }\r\n    // console.log('validate', this.componentFormControl.errors);\r\n    // // this.componentFormControl.setErrors( { custom: 'xxx' });\r\n    // this.componentFormControl.setErrors( this.componentFormControl.errors);\r\n    // console.log('validate 2', this.componentFormControl.errors);\r\n    // return this.componentFormControl.errors;\r\n    // console.log(this.componentFormControl.errors, control.errors, this.parentFormControl.errors, this);\r\n    // return this.componentFormControl.errors;\r\n  }\r\n}\r\n\r\n","<ui-simple-layout [ctx]=\"this\">\r\n\r\n<div class=\"control-container\" [ngClass]=\"{'has-suffix': hasSuffix, 'has-prefix': hasPrefix, 'has-clear-icon': showClearButton, 'active-icons': activeIcons, 'has-focus': hasFocus}\">\r\n  <input #input [type]=\"type\" [formControl]=\"componentFormControl\" [placeholder]=\"placeholder\" (keydown)=\"onKeypressed($event)\" (focus)=\"onFocus(true)\" (blur)=\"onFocus(false)\" />\r\n  <div #prefix><ng-content select=\"[slot=prefix]\"></ng-content></div>\r\n  <div #suffix><ng-content select=\"[slot=suffix]\"></ng-content></div>\r\n  <mat-icon *ngIf=\"prefixIcon\" class=\"prefix-icon\" [matTooltip]=\"prefixIcon.tooltip\">{{ prefixIcon.icon }}</mat-icon>\r\n  <mat-icon *ngIf=\"suffixIcon\" class=\"suffix-icon\" [matTooltip]=\"suffixIcon.tooltip\">{{ suffixIcon.icon }}</mat-icon>\r\n  <ui-action-icon [size]=\"'small'\" [color]=\"'warn'\" *ngIf=\"showClearButton\" (click)=\"clearValue()\" [matIcon]=\"'clear'\" class=\"clear-icon\"></ui-action-icon>\r\n</div>\r\n\r\n</ui-simple-layout>\r\n"]}
1
+ import { Component, EventEmitter, Host, HostBinding, Input, Optional, Output, SkipSelf, ViewChild } from '@angular/core';
2
+ import { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import { UiSimpleComponent } from '../layouts/simple/ui-simple.component';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/forms";
6
+ import * as i2 from "@angular/common";
7
+ import * as i3 from "@angular/material/icon";
8
+ import * as i4 from "@angular/material/tooltip";
9
+ import * as i5 from "../layouts/simple/ui-simple-layout.component";
10
+ import * as i6 from "../action-icon/action-icon.component";
11
+ export class InputComponent extends UiSimpleComponent {
12
+ get textAlignClass() {
13
+ return `text-align-${this.textAlign}`;
14
+ }
15
+ get hasPrefix() {
16
+ return (this.prefixIcon && this.prefixIcon.icon !== '') || this.prefix?.nativeElement?.innerText !== '' || this.forceHasPrefix;
17
+ }
18
+ get hasSuffix() {
19
+ return (this.suffixIcon && this.suffixIcon.icon !== '') || this.suffix?.nativeElement?.innerText !== '' || this.forceHasSuffix;
20
+ }
21
+ // control;
22
+ // onTouched = () => {};
23
+ // onChange = (value) => {};
24
+ // get showInvalid(): boolean {
25
+ // return true;
26
+ // // return this.control.touched && !!this.control.errors;
27
+ // }
28
+ // get validationMessage(): string {
29
+ // // console.log(this.control?.errors);
30
+ // let e: any = {code: 'Neznámá chyba'};
31
+ // const errors = this.control?.errors || {};
32
+ // Object.keys(errors).find(a => {
33
+ // e = {code: a, data: errors[a]};
34
+ // return true;
35
+ // });
36
+ // switch (e.code) {
37
+ // case 'required':
38
+ // return this.translateService.instant('ui.controls.validation.required');
39
+ // case 'email':
40
+ // return this.translateService.instant('ui.controls.validation.email');
41
+ // case 'matDatepickerParse':
42
+ // return this.translateService.instant('ui.controls.validation.matDatepickerParse');
43
+ // case 'maxlength':
44
+ // return this.translateService.instant('ui.controls.validation.maxlength', e.data);
45
+ // case 'minlength':
46
+ // return this.translateService.instant('ui.controls.validation.minlength', e.data);
47
+ // case 'positive':
48
+ // return this.translateService.instant(isNaN(Number(e.data)) ? 'ui.controls.validation.invalidNumber' : 'ui.controls.validation.positive');
49
+ // case 'custom':
50
+ // return this.translateService.instant(e.data);
51
+ // default:
52
+ // return this.translateService.instant(e.code);
53
+ // }
54
+ // }
55
+ get maxLenRequired() {
56
+ return true;
57
+ // return this.control.value && (this.control.value.length > (this.validators?.maxLength || 0));
58
+ }
59
+ constructor(controlContainer) {
60
+ super(null, controlContainer);
61
+ this.controlContainer = controlContainer;
62
+ this.type = 'text';
63
+ this.clearButton = false;
64
+ this.activeIcons = true;
65
+ this.forceHasPrefix = false;
66
+ this.forceHasSuffix = false;
67
+ this.textAlign = 'left';
68
+ this.focusChanged = new EventEmitter();
69
+ this.keyPressed = new EventEmitter();
70
+ // control = new FormControl();
71
+ this.required = false;
72
+ this.hasFocus = false;
73
+ // this.componentFormControl = new FormControl();
74
+ // super();
75
+ // super(undefined, /*ngControl*/ translateService);
76
+ // super(control);
77
+ // console.log(control);
78
+ // if (control) {
79
+ // control.valueAccessor = this;
80
+ // }
81
+ // if (ngControl != null) {
82
+ // // Setting the value accessor directly (instead of using
83
+ // // the providers) to avoid running into a circular import.
84
+ // ngControl.valueAccessor = this;
85
+ // }
86
+ }
87
+ get showClearButton() {
88
+ return this.clearButton && this.componentFormControl?.value !== '';
89
+ }
90
+ ngOnInit() {
91
+ super.ngOnInit();
92
+ // console.log('probiha vubec oninit?');
93
+ // if (this.ngControl) {
94
+ // console.log('from ngControl....??');
95
+ // if (this.formControl) {
96
+ // this.componentFormControl = this.formControl;
97
+ // } else {
98
+ // this.componentFormControl = this.ngControl.control as UntypedFormControl;
99
+ // }
100
+ // setTimeout(() => {
101
+ // this.applyValidators();
102
+ // });
103
+ // } else {
104
+ // const control = this.formControlName ?
105
+ // (this.controlContainer as FormGroupDirective).control.get(this.formControlName) : this.formControl;
106
+ // this.componentFormControl.setValidators(control.validator);
107
+ // this.componentFormControl.valueChanges.subscribe(v => console.log('onitin sub', v));
108
+ // control._componentFormControl = this.componentFormControl;
109
+ // if (control._markAsTouched === undefined) {
110
+ // // control._componentFormControl = this.componentFormControl;
111
+ // console.log('overriding markAsTouched for', this.formControlName);
112
+ // control._markAsTouched = control.markAsTouched;
113
+ // control.markAsTouched = ({onlySelf}: { onlySelf?: boolean } = {}): void => {
114
+ // console.log('marking as touched', this.componentFormControl.value, control.value, this.xxx.value, control._componentFormControl.value);
115
+ // control._markAsTouched({onlySelf});
116
+ // setTimeout(() => control._componentFormControl.markAsTouched(), 1000);
117
+ // }
118
+ // }
119
+ // }
120
+ }
121
+ clearValue() {
122
+ this.componentFormControl?.setValue('');
123
+ this.input?.nativeElement.focus();
124
+ }
125
+ focus() {
126
+ this.input?.nativeElement.focus();
127
+ }
128
+ onFocus(focus) {
129
+ setTimeout(() => {
130
+ this.hasFocus = focus;
131
+ this.focusChanged.emit(focus);
132
+ });
133
+ }
134
+ onKeypressed($event) {
135
+ this.keyPressed.emit($event);
136
+ }
137
+ // registerOnChange(onChange: any): void {
138
+ // this.onChange = onChange;
139
+ // }
140
+ //
141
+ // registerOnTouched(onTouched: any): void {
142
+ // this.onTouched = onTouched;
143
+ // }
144
+ // registerOnValidatorChange(fn: () => void): void {
145
+ // }
146
+ // setDisabledState(isDisabled: boolean): void {
147
+ // // isDisabled ? this.control.disable() : this.control.enable();
148
+ // }
149
+ // validate(control: AbstractControl): ValidationErrors | null {
150
+ // // this.control = control;
151
+ // // console.log(control, control.value, control.errors);
152
+ // if (this.value === 'error') {
153
+ // return { customError: 'muj error'}
154
+ // } else {
155
+ // return null;
156
+ // }
157
+ // // console.log('custom validate');
158
+ // // return null;
159
+ // }
160
+ //
161
+ // writeValue(obj: any): void {
162
+ // console.log('writevalue: ', obj);
163
+ // this.componentFormControl.setValue(obj);
164
+ // // this.value = obj;
165
+ // // this.control.setValue(obj);
166
+ // }
167
+ //
168
+ // registerOnChange(fn: any): void {
169
+ // }
170
+ //
171
+ // registerOnTouched(fn: any): void {
172
+ // }
173
+ //
174
+ // setDisabledState(isDisabled: boolean): void {
175
+ // }
176
+ // modelChange($event: any) {
177
+ // console.log($event);
178
+ // this.onTouched();
179
+ // this.onChange($event)
180
+ // }
181
+ // validate(control: AbstractControl): ValidationErrors | null {
182
+ // console.log(this.label, 'validate');
183
+ // return this.componentFormControl.errors;
184
+ // // return undefined;
185
+ // }
186
+ validate(control) {
187
+ if (this.parentFormControl) {
188
+ return this.parentFormControl._componentFormControl.errors;
189
+ }
190
+ // console.log('validate', this.componentFormControl.errors);
191
+ // // this.componentFormControl.setErrors( { custom: 'xxx' });
192
+ // this.componentFormControl.setErrors( this.componentFormControl.errors);
193
+ // console.log('validate 2', this.componentFormControl.errors);
194
+ // return this.componentFormControl.errors;
195
+ // console.log(this.componentFormControl.errors, control.errors, this.parentFormControl.errors, this);
196
+ // return this.componentFormControl.errors;
197
+ }
198
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: InputComponent, deps: [{ token: i1.ControlContainer, host: true, optional: true, skipSelf: true }], target: i0.ɵɵFactoryTarget.Component }); }
199
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: InputComponent, selector: "ui-input", inputs: { prefixIcon: "prefixIcon", suffixIcon: "suffixIcon", type: "type", clearButton: "clearButton", activeIcons: "activeIcons", forceHasPrefix: "forceHasPrefix", forceHasSuffix: "forceHasSuffix", textAlign: "textAlign" }, outputs: { focusChanged: "focusChanged", keyPressed: "keyPressed" }, host: { properties: { "class": "this.textAlignClass" } }, providers: [
200
+ {
201
+ provide: NG_VALUE_ACCESSOR,
202
+ multi: true,
203
+ useExisting: InputComponent
204
+ },
205
+ {
206
+ provide: NG_VALIDATORS,
207
+ multi: true,
208
+ useExisting: InputComponent
209
+ }
210
+ ], viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }, { propertyName: "prefix", first: true, predicate: ["prefix"], descendants: true, static: true }, { propertyName: "suffix", first: true, predicate: ["suffix"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<ui-simple-layout [ctx]=\"this\">\r\n\r\n<div class=\"control-container\" [ngClass]=\"{'has-suffix': hasSuffix, 'has-prefix': hasPrefix, 'has-clear-icon': showClearButton, 'active-icons': activeIcons, 'has-focus': hasFocus}\">\r\n <input #input [type]=\"type\" [formControl]=\"componentFormControl\" [placeholder]=\"placeholder\" (keydown)=\"onKeypressed($event)\" (focus)=\"onFocus(true)\" (blur)=\"onFocus(false)\" />\r\n <div #prefix><ng-content select=\"[slot=prefix]\"></ng-content></div>\r\n <div #suffix><ng-content select=\"[slot=suffix]\"></ng-content></div>\r\n <mat-icon *ngIf=\"prefixIcon\" class=\"prefix-icon\" [matTooltip]=\"prefixIcon.tooltip\">{{ prefixIcon.icon }}</mat-icon>\r\n <mat-icon *ngIf=\"suffixIcon\" class=\"suffix-icon\" [matTooltip]=\"suffixIcon.tooltip\">{{ suffixIcon.icon }}</mat-icon>\r\n <ui-action-icon [size]=\"'small'\" [color]=\"'warn'\" *ngIf=\"showClearButton\" (click)=\"clearValue()\" [matIcon]=\"'clear'\" class=\"clear-icon\"></ui-action-icon>\r\n</div>\r\n\r\n</ui-simple-layout>\r\n", styles: [":host{display:flex;flex-direction:column;width:100%}:host .control-container{width:100%;position:relative}:host .control-container.has-prefix ::ng-deep input,:host .control-container.has-prefix ::ng-deep textarea,:host .control-container.has-prefix ::ng-deep .mat-mdc-select-trigger{padding-left:1.8em}:host .control-container.has-suffix:not(.has-clear-icon) ::ng-deep input,:host .control-container.has-suffix:not(.has-clear-icon) ::ng-deep textarea,:host .control-container.has-suffix:not(.has-clear-icon) ::ng-deep .mat-mdc-select-trigger{padding-right:1.8em}:host .control-container.has-clear-icon:not(.has-suffix) ::ng-deep input,:host .control-container.has-clear-icon:not(.has-suffix) ::ng-deep textarea,:host .control-container.has-clear-icon:not(.has-suffix) ::ng-deep .mat-mdc-select-trigger{padding-right:1.8em}:host .control-container.has-suffix.has-clear-icon ::ng-deep input,:host .control-container.has-suffix.has-clear-icon ::ng-deep textarea,:host .control-container.has-suffix.has-clear-icon ::ng-deep .mat-mdc-select-trigger{padding-right:3.6em}:host .control-container.has-suffix.has-clear-icon ::ng-deep .clear-icon{right:1.4em!important}:host ::ng-deep [slot=suffix],:host ::ng-deep .clear-icon,:host ::ng-deep .suffix-icon{position:absolute;-webkit-user-select:none;user-select:none;transition:color .25s;top:calc(50% - .5em);right:.2em;width:1em;height:1em;font-size:1.5em}:host ::ng-deep [slot=suffix]:not(.disabled),:host ::ng-deep .clear-icon:not(.disabled),:host ::ng-deep .suffix-icon:not(.disabled){cursor:pointer}:host ::ng-deep [slot=prefix],:host ::ng-deep .prefix-icon{position:absolute;-webkit-user-select:none;user-select:none;transition:color .25s;top:calc(50% - .5em);left:.2em;width:1em;height:1em;font-size:1.5em}:host ::ng-deep [slot=prefix]:not(.disabled),:host ::ng-deep .prefix-icon:not(.disabled){cursor:pointer}:host ::ng-deep input,:host ::ng-deep textarea,:host ::ng-deep .mat-mdc-select-trigger,:host ::ng-deep .editor-wrapper{resize:none;width:100%;line-height:1.2em;font-size:1em;outline:none;border-style:solid;transition:border-color 333ms}:host ::ng-deep textarea.autoresize{box-sizing:content-box;width:calc(100% - 1.4em)}:host ::ng-deep ::ng-deep .mat-select-trigger,:host ::ng-deep ::ng-deep .mat-mdc-select-trigger{height:100%}:host ::ng-deep ::ng-deep .mat-select-value,:host ::ng-deep ::ng-deep .mat-mdc-select-value{vertical-align:middle}::ng-deep ui-input{display:block}\n", ":host.text-align-left ::ng-deep input{text-align:left}:host.text-align-right ::ng-deep input{text-align:right}:host.text-align-center ::ng-deep input{text-align:center}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { 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.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: i5.UiSimpleLayoutComponent, selector: "ui-simple-layout", inputs: ["ctx"] }, { kind: "component", type: i6.ActionIconComponent, selector: "ui-action-icon", inputs: ["size", "color", "disabled", "busy", "matIcon"] }] }); }
211
+ }
212
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: InputComponent, decorators: [{
213
+ type: Component,
214
+ args: [{ selector: 'ui-input', providers: [
215
+ {
216
+ provide: NG_VALUE_ACCESSOR,
217
+ multi: true,
218
+ useExisting: InputComponent
219
+ },
220
+ {
221
+ provide: NG_VALIDATORS,
222
+ multi: true,
223
+ useExisting: InputComponent
224
+ }
225
+ ], template: "<ui-simple-layout [ctx]=\"this\">\r\n\r\n<div class=\"control-container\" [ngClass]=\"{'has-suffix': hasSuffix, 'has-prefix': hasPrefix, 'has-clear-icon': showClearButton, 'active-icons': activeIcons, 'has-focus': hasFocus}\">\r\n <input #input [type]=\"type\" [formControl]=\"componentFormControl\" [placeholder]=\"placeholder\" (keydown)=\"onKeypressed($event)\" (focus)=\"onFocus(true)\" (blur)=\"onFocus(false)\" />\r\n <div #prefix><ng-content select=\"[slot=prefix]\"></ng-content></div>\r\n <div #suffix><ng-content select=\"[slot=suffix]\"></ng-content></div>\r\n <mat-icon *ngIf=\"prefixIcon\" class=\"prefix-icon\" [matTooltip]=\"prefixIcon.tooltip\">{{ prefixIcon.icon }}</mat-icon>\r\n <mat-icon *ngIf=\"suffixIcon\" class=\"suffix-icon\" [matTooltip]=\"suffixIcon.tooltip\">{{ suffixIcon.icon }}</mat-icon>\r\n <ui-action-icon [size]=\"'small'\" [color]=\"'warn'\" *ngIf=\"showClearButton\" (click)=\"clearValue()\" [matIcon]=\"'clear'\" class=\"clear-icon\"></ui-action-icon>\r\n</div>\r\n\r\n</ui-simple-layout>\r\n", styles: [":host{display:flex;flex-direction:column;width:100%}:host .control-container{width:100%;position:relative}:host .control-container.has-prefix ::ng-deep input,:host .control-container.has-prefix ::ng-deep textarea,:host .control-container.has-prefix ::ng-deep .mat-mdc-select-trigger{padding-left:1.8em}:host .control-container.has-suffix:not(.has-clear-icon) ::ng-deep input,:host .control-container.has-suffix:not(.has-clear-icon) ::ng-deep textarea,:host .control-container.has-suffix:not(.has-clear-icon) ::ng-deep .mat-mdc-select-trigger{padding-right:1.8em}:host .control-container.has-clear-icon:not(.has-suffix) ::ng-deep input,:host .control-container.has-clear-icon:not(.has-suffix) ::ng-deep textarea,:host .control-container.has-clear-icon:not(.has-suffix) ::ng-deep .mat-mdc-select-trigger{padding-right:1.8em}:host .control-container.has-suffix.has-clear-icon ::ng-deep input,:host .control-container.has-suffix.has-clear-icon ::ng-deep textarea,:host .control-container.has-suffix.has-clear-icon ::ng-deep .mat-mdc-select-trigger{padding-right:3.6em}:host .control-container.has-suffix.has-clear-icon ::ng-deep .clear-icon{right:1.4em!important}:host ::ng-deep [slot=suffix],:host ::ng-deep .clear-icon,:host ::ng-deep .suffix-icon{position:absolute;-webkit-user-select:none;user-select:none;transition:color .25s;top:calc(50% - .5em);right:.2em;width:1em;height:1em;font-size:1.5em}:host ::ng-deep [slot=suffix]:not(.disabled),:host ::ng-deep .clear-icon:not(.disabled),:host ::ng-deep .suffix-icon:not(.disabled){cursor:pointer}:host ::ng-deep [slot=prefix],:host ::ng-deep .prefix-icon{position:absolute;-webkit-user-select:none;user-select:none;transition:color .25s;top:calc(50% - .5em);left:.2em;width:1em;height:1em;font-size:1.5em}:host ::ng-deep [slot=prefix]:not(.disabled),:host ::ng-deep .prefix-icon:not(.disabled){cursor:pointer}:host ::ng-deep input,:host ::ng-deep textarea,:host ::ng-deep .mat-mdc-select-trigger,:host ::ng-deep .editor-wrapper{resize:none;width:100%;line-height:1.2em;font-size:1em;outline:none;border-style:solid;transition:border-color 333ms}:host ::ng-deep textarea.autoresize{box-sizing:content-box;width:calc(100% - 1.4em)}:host ::ng-deep ::ng-deep .mat-select-trigger,:host ::ng-deep ::ng-deep .mat-mdc-select-trigger{height:100%}:host ::ng-deep ::ng-deep .mat-select-value,:host ::ng-deep ::ng-deep .mat-mdc-select-value{vertical-align:middle}::ng-deep ui-input{display:block}\n", ":host.text-align-left ::ng-deep input{text-align:left}:host.text-align-right ::ng-deep input{text-align:right}:host.text-align-center ::ng-deep input{text-align:center}\n"] }]
226
+ }], ctorParameters: () => [{ type: i1.ControlContainer, decorators: [{
227
+ type: Optional
228
+ }, {
229
+ type: Host
230
+ }, {
231
+ type: SkipSelf
232
+ }] }], propDecorators: { prefixIcon: [{
233
+ type: Input
234
+ }], suffixIcon: [{
235
+ type: Input
236
+ }], type: [{
237
+ type: Input
238
+ }], clearButton: [{
239
+ type: Input
240
+ }], activeIcons: [{
241
+ type: Input
242
+ }], forceHasPrefix: [{
243
+ type: Input
244
+ }], forceHasSuffix: [{
245
+ type: Input
246
+ }], textAlignClass: [{
247
+ type: HostBinding,
248
+ args: ['class']
249
+ }], textAlign: [{
250
+ type: Input
251
+ }], input: [{
252
+ type: ViewChild,
253
+ args: ['input']
254
+ }], prefix: [{
255
+ type: ViewChild,
256
+ args: ['prefix', { static: true }]
257
+ }], suffix: [{
258
+ type: ViewChild,
259
+ args: ['suffix', { static: true }]
260
+ }], focusChanged: [{
261
+ type: Output
262
+ }], keyPressed: [{
263
+ type: Output
264
+ }] } });
265
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../projects/ui/src/lib/input/input.component.ts","../../../../../projects/ui/src/lib/input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Host, HostBinding,\r\n  Input,\r\n  OnInit,\r\n  Optional,\r\n  Output,\r\n  SkipSelf,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { AbstractControl, ControlContainer, NG_VALIDATORS, NG_VALUE_ACCESSOR, ValidationErrors } from '@angular/forms';\r\nimport { UiSimpleComponent } from '../layouts/simple/ui-simple.component';\r\n\r\ntype PrefixSuffix = { icon: string, tooltip?: string };\r\n@Component({\r\n  selector: 'ui-input',\r\n  templateUrl: './input.component.html',\r\n  styleUrls: [ '../layouts/simple/ui-simple-layout.component.scss', './input.component.scss' ],\r\n\r\n  providers: [\r\n    {\r\n    provide: NG_VALUE_ACCESSOR,\r\n    multi: true,\r\n    useExisting: InputComponent\r\n  },\r\n  {\r\n    provide: NG_VALIDATORS,\r\n    multi: true,\r\n    useExisting: InputComponent\r\n  }\r\n  ]\r\n})\r\nexport class InputComponent extends UiSimpleComponent\r\n  implements OnInit { // }, ControlValueAccessor { // }, ControlValueAccessor, Validator { // }, AfterViewInit {\r\n\r\n  // UiSimpleComponent = InputComponent;\r\n\r\n  // @Input() placeholder = '';\r\n  // @Input() label: string | undefined;\r\n  // @Input() useInputMessages: 'never' | 'always' | 'ondemand' = 'always';\r\n  // @Input() hint: string | undefined;\r\n  // @Input() validators: UiValidators | undefined;\r\n  // @Input() size: 'small' | 'smaller' | 'normal' | 'larger' | 'large' = 'normal';\r\n  // @Input() formControlName;\r\n\r\n  // componentFormControl: UntypedFormControl;\r\n  //\r\n  // ngControl: NgControl;\r\n  //\r\n  // @Input() validators: UiValidators | undefined;\r\n  // @Input() formControlName;\r\n  //\r\n  // @Input() placeholder = '';\r\n  // @Input() label: string | undefined;\r\n  // @Input() useInputMessages: 'never' | 'always' | 'ondemand' = 'always';\r\n  // @Input() hint?: string;\r\n  // @Input() size: 'small' | 'smaller' | 'normal' | 'larger' | 'large' = 'normal';\r\n\r\n  @Input() prefixIcon: PrefixSuffix;\r\n  @Input() suffixIcon: PrefixSuffix;\r\n  @Input() type: 'text' | 'number' | 'password' = 'text';\r\n  @Input() clearButton = false;\r\n  @Input() activeIcons = true;\r\n  @Input() forceHasPrefix = false;\r\n  @Input() forceHasSuffix = false;\r\n\r\n  @HostBinding('class')\r\n  get textAlignClass() {\r\n    return `text-align-${this.textAlign}`;\r\n  }\r\n\r\n  @Input() textAlign: 'left' | 'center' | 'right' = 'left';\r\n\r\n  @ViewChild('input') input: ElementRef | undefined;\r\n  @ViewChild('prefix', { static: true }) prefix: ElementRef | undefined;\r\n  @ViewChild('suffix', { static: true }) suffix: ElementRef | undefined;\r\n\r\n  @Output() focusChanged = new EventEmitter<boolean>();\r\n  @Output() keyPressed = new EventEmitter<KeyboardEvent>();\r\n\r\n  get hasPrefix() {\r\n    return (this.prefixIcon && this.prefixIcon.icon !== '') || this.prefix?.nativeElement?.innerText !== '' || this.forceHasPrefix;\r\n  }\r\n\r\n  get hasSuffix() {\r\n    return (this.suffixIcon && this.suffixIcon.icon !== '') || this.suffix?.nativeElement?.innerText !== '' || this.forceHasSuffix;\r\n  }\r\n\r\n  // control = new FormControl();\r\n\r\n  required = false;\r\n  hasFocus = false;\r\n\r\n  value: string;\r\n\r\n  // control;\r\n\r\n\r\n  // onTouched = () => {};\r\n  // onChange = (value) => {};\r\n\r\n  // get showInvalid(): boolean {\r\n  //   return true;\r\n  //   // return this.control.touched && !!this.control.errors;\r\n  // }\r\n\r\n  // get validationMessage(): string {\r\n  //   // console.log(this.control?.errors);\r\n  //   let e: any = {code: 'Neznámá chyba'};\r\n  //   const errors = this.control?.errors || {};\r\n  //   Object.keys(errors).find(a => {\r\n  //     e = {code: a, data: errors[a]};\r\n  //     return true;\r\n  //   });\r\n  //   switch (e.code) {\r\n  //     case 'required':\r\n  //       return this.translateService.instant('ui.controls.validation.required');\r\n  //     case 'email':\r\n  //       return this.translateService.instant('ui.controls.validation.email');\r\n  //     case 'matDatepickerParse':\r\n  //       return this.translateService.instant('ui.controls.validation.matDatepickerParse');\r\n  //     case 'maxlength':\r\n  //       return this.translateService.instant('ui.controls.validation.maxlength', e.data);\r\n  //     case 'minlength':\r\n  //       return this.translateService.instant('ui.controls.validation.minlength', e.data);\r\n  //     case 'positive':\r\n  //       return this.translateService.instant(isNaN(Number(e.data)) ? 'ui.controls.validation.invalidNumber' : 'ui.controls.validation.positive');\r\n  //     case 'custom':\r\n  //       return this.translateService.instant(e.data);\r\n  //     default:\r\n  //       return this.translateService.instant(e.code);\r\n  //   }\r\n  // }\r\n\r\n  get maxLenRequired(): boolean {\r\n    return true;\r\n    // return this.control.value && (this.control.value.length > (this.validators?.maxLength || 0));\r\n  }\r\n\r\n\r\n  constructor(@Optional() @Host() @SkipSelf() protected controlContainer: ControlContainer,\r\n    /*\r\n    bud pres @Optional() @Self() public control: NgControl a control.valueAccessor = this => ztratime ale custom validaci\r\n    anebo pres DI jako providers a pak this.control = viz ngOnInit - pokud jej vubec potrebujem\r\n\r\n     */\r\n    // private injector: Injector,\r\n   // @Optional() @Self() public control: NgControl,\r\n    // @Self() private controlDirective: NgControl,\r\n   ) {\r\n    super(null, controlContainer);\r\n\r\n    // this.componentFormControl = new FormControl();\r\n    // super();\r\n  //  super(undefined, /*ngControl*/ translateService);\r\n    // super(control);\r\n    // console.log(control);\r\n    // if (control) {\r\n    //   control.valueAccessor = this;\r\n    // }\r\n\r\n    // if (ngControl != null) {\r\n    //   // Setting the value accessor directly (instead of using\r\n    //   // the providers) to avoid running into a circular import.\r\n    //   ngControl.valueAccessor = this;\r\n    // }\r\n  }\r\n\r\n  get showClearButton(): boolean {\r\n    return this.clearButton && this.componentFormControl?.value !== '';\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    super.ngOnInit();\r\n    // console.log('probiha vubec oninit?');\r\n    // if (this.ngControl) {\r\n    //   console.log('from ngControl....??');\r\n    //   if (this.formControl) {\r\n    //     this.componentFormControl = this.formControl;\r\n    //   } else {\r\n    //     this.componentFormControl = this.ngControl.control as UntypedFormControl;\r\n    //   }\r\n    //   setTimeout(() => {\r\n    //     this.applyValidators();\r\n    //   });\r\n    // } else {\r\n    //   const control = this.formControlName ?\r\n    //     (this.controlContainer as FormGroupDirective).control.get(this.formControlName) : this.formControl;\r\n    //   this.componentFormControl.setValidators(control.validator);\r\n    //   this.componentFormControl.valueChanges.subscribe(v => console.log('onitin sub', v));\r\n    //   control._componentFormControl = this.componentFormControl;\r\n    //   if (control._markAsTouched === undefined) {\r\n    //     // control._componentFormControl = this.componentFormControl;\r\n    //     console.log('overriding markAsTouched for', this.formControlName);\r\n    //     control._markAsTouched = control.markAsTouched;\r\n    //     control.markAsTouched = ({onlySelf}: { onlySelf?: boolean } = {}): void => {\r\n    //       console.log('marking as touched', this.componentFormControl.value, control.value, this.xxx.value, control._componentFormControl.value);\r\n    //       control._markAsTouched({onlySelf});\r\n    //       setTimeout(() => control._componentFormControl.markAsTouched(), 1000);\r\n    //     }\r\n    //   }\r\n    // }\r\n  }\r\n\r\n  clearValue(): void {\r\n    this.componentFormControl?.setValue('');\r\n    this.input?.nativeElement.focus();\r\n  }\r\n\r\n  focus(): void {\r\n    this.input?.nativeElement.focus();\r\n  }\r\n\r\n  onFocus(focus: boolean): void {\r\n    setTimeout(() => {\r\n      this.hasFocus = focus;\r\n      this.focusChanged.emit(focus);\r\n    });\r\n  }\r\n\r\n  onKeypressed($event: any): void {\r\n    this.keyPressed.emit($event);\r\n  }\r\n\r\n  // registerOnChange(onChange: any): void {\r\n  //   this.onChange = onChange;\r\n  // }\r\n  //\r\n  // registerOnTouched(onTouched: any): void {\r\n  //   this.onTouched = onTouched;\r\n  // }\r\n\r\n  // registerOnValidatorChange(fn: () => void): void {\r\n  // }\r\n\r\n  // setDisabledState(isDisabled: boolean): void {\r\n  //   // isDisabled ? this.control.disable() : this.control.enable();\r\n  // }\r\n\r\n  // validate(control: AbstractControl): ValidationErrors | null {\r\n  //   // this.control = control;\r\n  //   // console.log(control, control.value, control.errors);\r\n  //   if (this.value === 'error') {\r\n  //     return { customError: 'muj error'}\r\n  //   } else {\r\n  //     return null;\r\n  //   }\r\n  //   // console.log('custom validate');\r\n  //   // return null;\r\n  // }\r\n  //\r\n  // writeValue(obj: any): void {\r\n  //   console.log('writevalue: ', obj);\r\n  //   this.componentFormControl.setValue(obj);\r\n  //   // this.value = obj;\r\n  //   // this.control.setValue(obj);\r\n  // }\r\n  //\r\n  // registerOnChange(fn: any): void {\r\n  // }\r\n  //\r\n  // registerOnTouched(fn: any): void {\r\n  // }\r\n  //\r\n  // setDisabledState(isDisabled: boolean): void {\r\n  // }\r\n\r\n  // modelChange($event: any) {\r\n  //   console.log($event);\r\n  //   this.onTouched();\r\n  //   this.onChange($event)\r\n  // }\r\n\r\n  // validate(control: AbstractControl): ValidationErrors | null {\r\n  //   console.log(this.label, 'validate');\r\n  //   return this.componentFormControl.errors;\r\n  //   // return undefined;\r\n  // }\r\n\r\n  validate(control: AbstractControl): ValidationErrors | null {\r\n    if (this.parentFormControl) {\r\n      return this.parentFormControl._componentFormControl.errors;\r\n    }\r\n    // console.log('validate', this.componentFormControl.errors);\r\n    // // this.componentFormControl.setErrors( { custom: 'xxx' });\r\n    // this.componentFormControl.setErrors( this.componentFormControl.errors);\r\n    // console.log('validate 2', this.componentFormControl.errors);\r\n    // return this.componentFormControl.errors;\r\n    // console.log(this.componentFormControl.errors, control.errors, this.parentFormControl.errors, this);\r\n    // return this.componentFormControl.errors;\r\n  }\r\n}\r\n\r\n","<ui-simple-layout [ctx]=\"this\">\r\n\r\n<div class=\"control-container\" [ngClass]=\"{'has-suffix': hasSuffix, 'has-prefix': hasPrefix, 'has-clear-icon': showClearButton, 'active-icons': activeIcons, 'has-focus': hasFocus}\">\r\n  <input #input [type]=\"type\" [formControl]=\"componentFormControl\" [placeholder]=\"placeholder\" (keydown)=\"onKeypressed($event)\" (focus)=\"onFocus(true)\" (blur)=\"onFocus(false)\" />\r\n  <div #prefix><ng-content select=\"[slot=prefix]\"></ng-content></div>\r\n  <div #suffix><ng-content select=\"[slot=suffix]\"></ng-content></div>\r\n  <mat-icon *ngIf=\"prefixIcon\" class=\"prefix-icon\" [matTooltip]=\"prefixIcon.tooltip\">{{ prefixIcon.icon }}</mat-icon>\r\n  <mat-icon *ngIf=\"suffixIcon\" class=\"suffix-icon\" [matTooltip]=\"suffixIcon.tooltip\">{{ suffixIcon.icon }}</mat-icon>\r\n  <ui-action-icon [size]=\"'small'\" [color]=\"'warn'\" *ngIf=\"showClearButton\" (click)=\"clearValue()\" [matIcon]=\"'clear'\" class=\"clear-icon\"></ui-action-icon>\r\n</div>\r\n\r\n</ui-simple-layout>\r\n"]}