@rlucan/ui 14.2.1

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 (78) hide show
  1. package/README.md +24 -0
  2. package/esm2020/lib/action-button/action-button.component.mjs +96 -0
  3. package/esm2020/lib/action-icon/action-icon.component.mjs +37 -0
  4. package/esm2020/lib/autocomplete/autocomplete.component.mjs +391 -0
  5. package/esm2020/lib/avatar/avatar.component.mjs +34 -0
  6. package/esm2020/lib/base/ui-base-layout.component.mjs +22 -0
  7. package/esm2020/lib/base/ui-base.component.mjs +74 -0
  8. package/esm2020/lib/button/button.component.mjs +57 -0
  9. package/esm2020/lib/checkbox/checkbox.component.mjs +39 -0
  10. package/esm2020/lib/checkbox-group/checkbox-group.component.mjs +91 -0
  11. package/esm2020/lib/currency/currency.component.mjs +148 -0
  12. package/esm2020/lib/date/date.component.mjs +64 -0
  13. package/esm2020/lib/dialog/dialog.component.mjs +37 -0
  14. package/esm2020/lib/directives/force-visibility/force-visibility.directive.mjs +96 -0
  15. package/esm2020/lib/elements/burger/burger.component.mjs +21 -0
  16. package/esm2020/lib/elements/expander/expander.component.mjs +28 -0
  17. package/esm2020/lib/elements/validation-message/validation-message.component.mjs +47 -0
  18. package/esm2020/lib/file/file.component.mjs +88 -0
  19. package/esm2020/lib/file-uploader/ui-file-uploader.component.mjs +394 -0
  20. package/esm2020/lib/input/input.component.mjs +258 -0
  21. package/esm2020/lib/radio/radio.component.mjs +21 -0
  22. package/esm2020/lib/radio-group/radio-group.component.mjs +53 -0
  23. package/esm2020/lib/select/select.component.mjs +91 -0
  24. package/esm2020/lib/services/message-box.service.mjs +113 -0
  25. package/esm2020/lib/services/toast.service.mjs +23 -0
  26. package/esm2020/lib/services/ui-file.service.mjs +71 -0
  27. package/esm2020/lib/services/ui-translate.service.mjs +32 -0
  28. package/esm2020/lib/simple/ui-simple-layout.component.mjs +15 -0
  29. package/esm2020/lib/simple/ui-simple.component.mjs +154 -0
  30. package/esm2020/lib/submit-button/submit-button.component.mjs +72 -0
  31. package/esm2020/lib/table/table.component.mjs +97 -0
  32. package/esm2020/lib/text-area/text-area.component.mjs +46 -0
  33. package/esm2020/lib/ui.model.mjs +2 -0
  34. package/esm2020/lib/ui.module.mjs +255 -0
  35. package/esm2020/public-api.mjs +33 -0
  36. package/esm2020/rlucan-ui.mjs +5 -0
  37. package/fesm2015/rlucan-ui.mjs +2918 -0
  38. package/fesm2015/rlucan-ui.mjs.map +1 -0
  39. package/fesm2020/rlucan-ui.mjs +2886 -0
  40. package/fesm2020/rlucan-ui.mjs.map +1 -0
  41. package/index.d.ts +5 -0
  42. package/lib/action-button/action-button.component.d.ts +33 -0
  43. package/lib/action-icon/action-icon.component.d.ts +15 -0
  44. package/lib/autocomplete/autocomplete.component.d.ts +57 -0
  45. package/lib/avatar/avatar.component.d.ts +14 -0
  46. package/lib/base/ui-base-layout.component.d.ts +8 -0
  47. package/lib/base/ui-base.component.d.ts +23 -0
  48. package/lib/button/button.component.d.ts +18 -0
  49. package/lib/checkbox/checkbox.component.d.ts +15 -0
  50. package/lib/checkbox-group/checkbox-group.component.d.ts +18 -0
  51. package/lib/currency/currency.component.d.ts +30 -0
  52. package/lib/date/date.component.d.ts +23 -0
  53. package/lib/dialog/dialog.component.d.ts +13 -0
  54. package/lib/directives/force-visibility/force-visibility.directive.d.ts +20 -0
  55. package/lib/elements/burger/burger.component.d.ts +9 -0
  56. package/lib/elements/expander/expander.component.d.ts +10 -0
  57. package/lib/elements/validation-message/validation-message.component.d.ts +12 -0
  58. package/lib/file/file.component.d.ts +29 -0
  59. package/lib/file-uploader/ui-file-uploader.component.d.ts +102 -0
  60. package/lib/input/input.component.d.ts +29 -0
  61. package/lib/radio/radio.component.d.ts +8 -0
  62. package/lib/radio-group/radio-group.component.d.ts +18 -0
  63. package/lib/select/select.component.d.ts +33 -0
  64. package/lib/services/message-box.service.d.ts +42 -0
  65. package/lib/services/toast.service.d.ts +13 -0
  66. package/lib/services/ui-file.service.d.ts +33 -0
  67. package/lib/services/ui-translate.service.d.ts +11 -0
  68. package/lib/simple/ui-simple-layout.component.d.ts +7 -0
  69. package/lib/simple/ui-simple.component.d.ts +39 -0
  70. package/lib/submit-button/submit-button.component.d.ts +21 -0
  71. package/lib/table/table.component.d.ts +36 -0
  72. package/lib/text-area/text-area.component.d.ts +18 -0
  73. package/lib/ui.model.d.ts +2 -0
  74. package/lib/ui.module.d.ts +56 -0
  75. package/package.json +44 -0
  76. package/public-api.d.ts +27 -0
  77. package/scss/ui-defaults.scss +339 -0
  78. package/ui.scss +911 -0
@@ -0,0 +1,258 @@
1
+ import { Component, EventEmitter, Host, Input, Optional, Output, SkipSelf, ViewChild } from '@angular/core';
2
+ import { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import { UiSimpleComponent } from '../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 "../simple/ui-simple-layout.component";
8
+ export class InputComponent extends UiSimpleComponent {
9
+ constructor(controlContainer) {
10
+ super(null, controlContainer);
11
+ this.controlContainer = controlContainer;
12
+ // UiSimpleComponent = InputComponent;
13
+ // @Input() placeholder = '';
14
+ // @Input() label: string | undefined;
15
+ // @Input() useInputMessages: 'never' | 'always' | 'ondemand' = 'always';
16
+ // @Input() hint: string | undefined;
17
+ // @Input() validators: UiValidators | undefined;
18
+ // @Input() size: 'small' | 'smaller' | 'normal' | 'larger' | 'large' = 'normal';
19
+ // @Input() formControlName;
20
+ // componentFormControl: UntypedFormControl;
21
+ //
22
+ // ngControl: NgControl;
23
+ //
24
+ // @Input() validators: UiValidators | undefined;
25
+ // @Input() formControlName;
26
+ //
27
+ // @Input() placeholder = '';
28
+ // @Input() label: string | undefined;
29
+ // @Input() useInputMessages: 'never' | 'always' | 'ondemand' = 'always';
30
+ // @Input() hint?: string;
31
+ // @Input() size: 'small' | 'smaller' | 'normal' | 'larger' | 'large' = 'normal';
32
+ this.prefix = '';
33
+ this.suffix = '';
34
+ this.type = 'text';
35
+ this.clearButton = false;
36
+ this.disableUserInput = false;
37
+ // @HostBinding('class.centered')
38
+ this.centered = false;
39
+ this.focusChanged = new EventEmitter();
40
+ this.keyPressed = new EventEmitter();
41
+ // control = new FormControl();
42
+ this.required = false;
43
+ // this.componentFormControl = new FormControl();
44
+ // super();
45
+ // super(undefined, /*ngControl*/ translateService);
46
+ // super(control);
47
+ // console.log(control);
48
+ // if (control) {
49
+ // control.valueAccessor = this;
50
+ // }
51
+ // if (ngControl != null) {
52
+ // // Setting the value accessor directly (instead of using
53
+ // // the providers) to avoid running into a circular import.
54
+ // ngControl.valueAccessor = this;
55
+ // }
56
+ }
57
+ // control;
58
+ // onTouched = () => {};
59
+ // onChange = (value) => {};
60
+ // get showInvalid(): boolean {
61
+ // return true;
62
+ // // return this.control.touched && !!this.control.errors;
63
+ // }
64
+ // get validationMessage(): string {
65
+ // // console.log(this.control?.errors);
66
+ // let e: any = {code: 'Neznámá chyba'};
67
+ // const errors = this.control?.errors || {};
68
+ // Object.keys(errors).find(a => {
69
+ // e = {code: a, data: errors[a]};
70
+ // return true;
71
+ // });
72
+ // switch (e.code) {
73
+ // case 'required':
74
+ // return this.translateService.instant('ui.controls.validation.required');
75
+ // case 'email':
76
+ // return this.translateService.instant('ui.controls.validation.email');
77
+ // case 'matDatepickerParse':
78
+ // return this.translateService.instant('ui.controls.validation.matDatepickerParse');
79
+ // case 'maxlength':
80
+ // return this.translateService.instant('ui.controls.validation.maxlength', e.data);
81
+ // case 'minlength':
82
+ // return this.translateService.instant('ui.controls.validation.minlength', e.data);
83
+ // case 'positive':
84
+ // return this.translateService.instant(isNaN(Number(e.data)) ? 'ui.controls.validation.invalidNumber' : 'ui.controls.validation.positive');
85
+ // case 'custom':
86
+ // return this.translateService.instant(e.data);
87
+ // default:
88
+ // return this.translateService.instant(e.code);
89
+ // }
90
+ // }
91
+ get maxLenRequired() {
92
+ return true;
93
+ // return this.control.value && (this.control.value.length > (this.validators?.maxLength || 0));
94
+ }
95
+ get showClearButton() {
96
+ return false;
97
+ // return this.clearButton && this.control?.value !== '';
98
+ }
99
+ ngOnInit() {
100
+ super.ngOnInit();
101
+ // console.log('probiha vubec oninit?');
102
+ // if (this.ngControl) {
103
+ // console.log('from ngControl....??');
104
+ // if (this.formControl) {
105
+ // this.componentFormControl = this.formControl;
106
+ // } else {
107
+ // this.componentFormControl = this.ngControl.control as UntypedFormControl;
108
+ // }
109
+ // setTimeout(() => {
110
+ // this.applyValidators();
111
+ // });
112
+ // } else {
113
+ // const control = this.formControlName ?
114
+ // (this.controlContainer as FormGroupDirective).control.get(this.formControlName) : this.formControl;
115
+ // this.componentFormControl.setValidators(control.validator);
116
+ // this.componentFormControl.valueChanges.subscribe(v => console.log('onitin sub', v));
117
+ // control._componentFormControl = this.componentFormControl;
118
+ // if (control._markAsTouched === undefined) {
119
+ // // control._componentFormControl = this.componentFormControl;
120
+ // console.log('overriding markAsTouched for', this.formControlName);
121
+ // control._markAsTouched = control.markAsTouched;
122
+ // control.markAsTouched = ({onlySelf}: { onlySelf?: boolean } = {}): void => {
123
+ // console.log('marking as touched', this.componentFormControl.value, control.value, this.xxx.value, control._componentFormControl.value);
124
+ // control._markAsTouched({onlySelf});
125
+ // setTimeout(() => control._componentFormControl.markAsTouched(), 1000);
126
+ // }
127
+ // }
128
+ // }
129
+ }
130
+ clearValue() {
131
+ // this.control?.setValue('');
132
+ this.input?.nativeElement.focus();
133
+ }
134
+ focus() {
135
+ this.input?.nativeElement.focus();
136
+ }
137
+ onFocus(focus) {
138
+ this.focusChanged.emit(focus);
139
+ }
140
+ onKeypressed($event) {
141
+ this.keyPressed.emit($event);
142
+ }
143
+ // registerOnChange(onChange: any): void {
144
+ // this.onChange = onChange;
145
+ // }
146
+ //
147
+ // registerOnTouched(onTouched: any): void {
148
+ // this.onTouched = onTouched;
149
+ // }
150
+ // registerOnValidatorChange(fn: () => void): void {
151
+ // }
152
+ // setDisabledState(isDisabled: boolean): void {
153
+ // // isDisabled ? this.control.disable() : this.control.enable();
154
+ // }
155
+ // validate(control: AbstractControl): ValidationErrors | null {
156
+ // // this.control = control;
157
+ // // console.log(control, control.value, control.errors);
158
+ // if (this.value === 'error') {
159
+ // return { customError: 'muj error'}
160
+ // } else {
161
+ // return null;
162
+ // }
163
+ // // console.log('custom validate');
164
+ // // return null;
165
+ // }
166
+ //
167
+ // writeValue(obj: any): void {
168
+ // console.log('writevalue: ', obj);
169
+ // this.componentFormControl.setValue(obj);
170
+ // // this.value = obj;
171
+ // // this.control.setValue(obj);
172
+ // }
173
+ //
174
+ // registerOnChange(fn: any): void {
175
+ // }
176
+ //
177
+ // registerOnTouched(fn: any): void {
178
+ // }
179
+ //
180
+ // setDisabledState(isDisabled: boolean): void {
181
+ // }
182
+ // modelChange($event: any) {
183
+ // console.log($event);
184
+ // this.onTouched();
185
+ // this.onChange($event)
186
+ // }
187
+ // validate(control: AbstractControl): ValidationErrors | null {
188
+ // console.log(this.label, 'validate');
189
+ // return this.componentFormControl.errors;
190
+ // // return undefined;
191
+ // }
192
+ validate(control) {
193
+ if (this.parentFormControl) {
194
+ return this.parentFormControl._componentFormControl.errors;
195
+ }
196
+ // console.log('validate', this.componentFormControl.errors);
197
+ // // this.componentFormControl.setErrors( { custom: 'xxx' });
198
+ // this.componentFormControl.setErrors( this.componentFormControl.errors);
199
+ // console.log('validate 2', this.componentFormControl.errors);
200
+ // return this.componentFormControl.errors;
201
+ // console.log(this.componentFormControl.errors, control.errors, this.parentFormControl.errors, this);
202
+ // return this.componentFormControl.errors;
203
+ }
204
+ }
205
+ InputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: InputComponent, deps: [{ token: i1.ControlContainer, host: true, optional: true, skipSelf: true }], target: i0.ɵɵFactoryTarget.Component });
206
+ InputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.5", type: InputComponent, selector: "ui-input", inputs: { prefix: "prefix", suffix: "suffix", type: "type", clearButton: "clearButton", disableUserInput: "disableUserInput", centered: "centered" }, outputs: { focusChanged: "focusChanged", keyPressed: "keyPressed" }, providers: [
207
+ {
208
+ provide: NG_VALUE_ACCESSOR,
209
+ multi: true,
210
+ useExisting: InputComponent
211
+ },
212
+ {
213
+ provide: NG_VALIDATORS,
214
+ multi: true,
215
+ useExisting: InputComponent
216
+ }
217
+ ], viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<ui-simple-layout [ctx]=\"this\">\r\n\r\n<div class=\"control-container\">\r\n <input #input [ngClass]=\"{centered: centered}\" [type]=\"type\" [formControl]=\"componentFormControl\" [placeholder]=\"placeholder\" (keydown)=\"onKeypressed($event)\" (focus)=\"onFocus(true)\" (blur)=\"onFocus(false)\" />\r\n <ng-content select=\"[slot=prefix]\"></ng-content>\r\n <ng-content select=\"[slot=suffix]\"></ng-content>\r\n</div>\r\n\r\n</ui-simple-layout>\r\n", styles: [":host{width:100%}:host .control-container{width:100%;position:relative}:host ::ng-deep [slot=suffix]{position:absolute;cursor:pointer;user-select:none;transition:color .25s;top:calc(50% - .5em);right:.2em;width:1em;height:1em;font-size:1.5em}:host ::ng-deep [slot=prefix]{position:absolute;cursor:pointer;user-select:none;transition:color .25s;top:calc(50% - .5em);left:.2em;width:1em;height:1em;font-size:1.5em}:host ::ng-deep input,:host ::ng-deep textarea,:host ::ng-deep ::ng-deep .mat-select-trigger,:host ::ng-deep ::ng-deep .mat-mdc-select-trigger{resize:none;width:100%;line-height:1.2em;font-size:1em;outline:none;border-style:solid;transition:border-color 333ms}:host ::ng-deep input.has-suffix,:host ::ng-deep textarea.has-suffix,:host ::ng-deep ::ng-deep .mat-select-trigger.has-suffix,:host ::ng-deep ::ng-deep .mat-mdc-select-trigger.has-suffix{padding-right:1.8em}:host ::ng-deep input.centered,:host ::ng-deep textarea.centered,:host ::ng-deep ::ng-deep .mat-select-trigger.centered,:host ::ng-deep ::ng-deep .mat-mdc-select-trigger.centered{text-align:center}: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"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { 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: "component", type: i3.UiSimpleLayoutComponent, selector: "ui-simple-layout", inputs: ["ctx"] }] });
218
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: InputComponent, decorators: [{
219
+ type: Component,
220
+ args: [{ selector: 'ui-input', providers: [
221
+ {
222
+ provide: NG_VALUE_ACCESSOR,
223
+ multi: true,
224
+ useExisting: InputComponent
225
+ },
226
+ {
227
+ provide: NG_VALIDATORS,
228
+ multi: true,
229
+ useExisting: InputComponent
230
+ }
231
+ ], template: "<ui-simple-layout [ctx]=\"this\">\r\n\r\n<div class=\"control-container\">\r\n <input #input [ngClass]=\"{centered: centered}\" [type]=\"type\" [formControl]=\"componentFormControl\" [placeholder]=\"placeholder\" (keydown)=\"onKeypressed($event)\" (focus)=\"onFocus(true)\" (blur)=\"onFocus(false)\" />\r\n <ng-content select=\"[slot=prefix]\"></ng-content>\r\n <ng-content select=\"[slot=suffix]\"></ng-content>\r\n</div>\r\n\r\n</ui-simple-layout>\r\n", styles: [":host{width:100%}:host .control-container{width:100%;position:relative}:host ::ng-deep [slot=suffix]{position:absolute;cursor:pointer;user-select:none;transition:color .25s;top:calc(50% - .5em);right:.2em;width:1em;height:1em;font-size:1.5em}:host ::ng-deep [slot=prefix]{position:absolute;cursor:pointer;user-select:none;transition:color .25s;top:calc(50% - .5em);left:.2em;width:1em;height:1em;font-size:1.5em}:host ::ng-deep input,:host ::ng-deep textarea,:host ::ng-deep ::ng-deep .mat-select-trigger,:host ::ng-deep ::ng-deep .mat-mdc-select-trigger{resize:none;width:100%;line-height:1.2em;font-size:1em;outline:none;border-style:solid;transition:border-color 333ms}:host ::ng-deep input.has-suffix,:host ::ng-deep textarea.has-suffix,:host ::ng-deep ::ng-deep .mat-select-trigger.has-suffix,:host ::ng-deep ::ng-deep .mat-mdc-select-trigger.has-suffix{padding-right:1.8em}:host ::ng-deep input.centered,:host ::ng-deep textarea.centered,:host ::ng-deep ::ng-deep .mat-select-trigger.centered,:host ::ng-deep ::ng-deep .mat-mdc-select-trigger.centered{text-align:center}: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"] }]
232
+ }], ctorParameters: function () { return [{ type: i1.ControlContainer, decorators: [{
233
+ type: Optional
234
+ }, {
235
+ type: Host
236
+ }, {
237
+ type: SkipSelf
238
+ }] }]; }, propDecorators: { prefix: [{
239
+ type: Input
240
+ }], suffix: [{
241
+ type: Input
242
+ }], type: [{
243
+ type: Input
244
+ }], clearButton: [{
245
+ type: Input
246
+ }], disableUserInput: [{
247
+ type: Input
248
+ }], centered: [{
249
+ type: Input
250
+ }], input: [{
251
+ type: ViewChild,
252
+ args: ['input']
253
+ }], focusChanged: [{
254
+ type: Output
255
+ }], keyPressed: [{
256
+ type: Output
257
+ }] } });
258
+ //# 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,\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 '../simple/ui-simple.component';\r\n\r\n@Component({\r\n  selector: 'ui-input',\r\n  templateUrl: './input.component.html',\r\n//   styleUrls: [ './input.component.scss' ],\r\n  styleUrls: [ '../simple/ui-simple-layout.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() prefix = '';\r\n  @Input() suffix = '';\r\n  @Input() type: 'text' | 'number' | 'password' = 'text';\r\n  @Input() clearButton = false;\r\n  @Input() disableUserInput = false;\r\n\r\n  // @HostBinding('class.centered')\r\n  @Input() centered = false;\r\n\r\n  @ViewChild('input') input: ElementRef | undefined;\r\n\r\n  @Output() focusChanged = new EventEmitter<boolean>();\r\n  @Output() keyPressed = new EventEmitter<KeyboardEvent>();\r\n\r\n  // control = new FormControl();\r\n\r\n  required = 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 false;\r\n    // return this.clearButton && this.control?.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.control?.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    this.focusChanged.emit(focus);\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\">\r\n  <input #input [ngClass]=\"{centered: centered}\" [type]=\"type\" [formControl]=\"componentFormControl\" [placeholder]=\"placeholder\" (keydown)=\"onKeypressed($event)\" (focus)=\"onFocus(true)\" (blur)=\"onFocus(false)\" />\r\n  <ng-content select=\"[slot=prefix]\"></ng-content>\r\n  <ng-content select=\"[slot=suffix]\"></ng-content>\r\n</div>\r\n\r\n</ui-simple-layout>\r\n"]}
@@ -0,0 +1,21 @@
1
+ import { Component, Input } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@angular/material/radio";
4
+ export class RadioComponent {
5
+ constructor() {
6
+ this.color = 'primary';
7
+ }
8
+ }
9
+ RadioComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: RadioComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
10
+ RadioComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.5", type: RadioComponent, selector: "ui-radio", inputs: { value: "value", label: "label", color: "color" }, ngImport: i0, template: "<mat-radio-button [value]=\"value\" [color]=\"color\">\r\n {{label}}\r\n</mat-radio-button>\r\n", styles: [""], dependencies: [{ kind: "component", type: i1.MatRadioButton, selector: "mat-radio-button", inputs: ["disableRipple", "tabIndex"], exportAs: ["matRadioButton"] }] });
11
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: RadioComponent, decorators: [{
12
+ type: Component,
13
+ args: [{ selector: 'ui-radio', template: "<mat-radio-button [value]=\"value\" [color]=\"color\">\r\n {{label}}\r\n</mat-radio-button>\r\n" }]
14
+ }], propDecorators: { value: [{
15
+ type: Input
16
+ }], label: [{
17
+ type: Input
18
+ }], color: [{
19
+ type: Input
20
+ }] } });
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFkaW8uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkvc3JjL2xpYi9yYWRpby9yYWRpby5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL3JhZGlvL3JhZGlvLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFPakQsTUFBTSxPQUFPLGNBQWM7SUFMM0I7UUFTVyxVQUFLLEdBQWtDLFNBQVMsQ0FBQTtLQUsxRDs7MkdBVFksY0FBYzsrRkFBZCxjQUFjLDRHQ1AzQixrR0FHQTsyRkRJYSxjQUFjO2tCQUwxQixTQUFTOytCQUNFLFVBQVU7OEJBTVgsS0FBSztzQkFBYixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ3VpLXJhZGlvJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vcmFkaW8uY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL3JhZGlvLmNvbXBvbmVudC5zY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIFJhZGlvQ29tcG9uZW50IHsgLy8gZXh0ZW5kcyBVaVNpbXBsZUNvbXBvbmVudCB7XHJcblxyXG4gIEBJbnB1dCgpIHZhbHVlO1xyXG4gIEBJbnB1dCgpIGxhYmVsO1xyXG4gIEBJbnB1dCgpIGNvbG9yOiAncHJpbWFyeScgfCAnYWNjZW50JyB8ICd3YXJuJyA9ICdwcmltYXJ5J1xyXG5cclxuICAvLyBjb25zdHJ1Y3RvcihAT3B0aW9uYWwoKSBAU2VsZigpIHB1YmxpYyBuZ0NvbnRyb2w6IE5nQ29udHJvbCkge1xyXG4gIC8vICAgc3VwZXIobmdDb250cm9sKTtcclxuICAvLyB9XHJcbn1cclxuIiwiPG1hdC1yYWRpby1idXR0b24gW3ZhbHVlXT1cInZhbHVlXCIgW2NvbG9yXT1cImNvbG9yXCI+XHJcbiAge3tsYWJlbH19XHJcbjwvbWF0LXJhZGlvLWJ1dHRvbj5cclxuIl19
@@ -0,0 +1,53 @@
1
+ import { Component, Input, Optional, Self } from '@angular/core';
2
+ import { UiSimpleComponent } from '../simple/ui-simple.component';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/forms";
5
+ import * as i2 from "@angular/common";
6
+ import * as i3 from "@angular/material/radio";
7
+ import * as i4 from "../simple/ui-simple-layout.component";
8
+ export class RadioGroupComponent extends UiSimpleComponent {
9
+ constructor(control) {
10
+ super(control);
11
+ this.control = control;
12
+ this.id = Math.round(Math.random() * 999999);
13
+ this.displayAttribute = 'name';
14
+ this.groupName = 'radio-' + this.id;
15
+ this.optionEnabled = (option) => true;
16
+ }
17
+ // ngOnInit(): void {
18
+ // super.ngOnInit();
19
+ // }
20
+ ngOnChanges(changes) {
21
+ super.ngOnChanges(changes);
22
+ if (changes.options) {
23
+ this.cbxs = [];
24
+ changes.options.currentValue.forEach(cv => {
25
+ this.cbxs.push({
26
+ value: this.valueAttribute ? cv[this.valueAttribute] : cv,
27
+ label: cv[this.displayAttribute]
28
+ });
29
+ });
30
+ }
31
+ }
32
+ }
33
+ RadioGroupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: RadioGroupComponent, deps: [{ token: i1.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component });
34
+ RadioGroupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.5", type: RadioGroupComponent, selector: "ui-radio-group", inputs: { options: "options", displayAttribute: "displayAttribute", valueAttribute: "valueAttribute", groupName: "groupName", optionEnabled: "optionEnabled" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<ui-simple-layout [ctx]=\"this\">\r\n\r\n <mat-radio-group [formControl]=\"componentFormControl\" [name]=\"groupName\" [class]=\"size\">\r\n\r\n <mat-radio-button *ngFor=\"let cbx of cbxs\" [value]=\"cbx.value\" >{{cbx.label}}</mat-radio-button>\r\n\r\n </mat-radio-group>\r\n\r\n</ui-simple-layout>\r\n", styles: [":host mat-radio-group{display:flex;flex-direction:column}:host mat-radio-button{margin-top:.2em;margin-bottom:.2em}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { 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: i3.MatRadioGroup, selector: "mat-radio-group", exportAs: ["matRadioGroup"] }, { kind: "component", type: i3.MatRadioButton, selector: "mat-radio-button", inputs: ["disableRipple", "tabIndex"], exportAs: ["matRadioButton"] }, { kind: "component", type: i4.UiSimpleLayoutComponent, selector: "ui-simple-layout", inputs: ["ctx"] }] });
35
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: RadioGroupComponent, decorators: [{
36
+ type: Component,
37
+ args: [{ selector: 'ui-radio-group', template: "<ui-simple-layout [ctx]=\"this\">\r\n\r\n <mat-radio-group [formControl]=\"componentFormControl\" [name]=\"groupName\" [class]=\"size\">\r\n\r\n <mat-radio-button *ngFor=\"let cbx of cbxs\" [value]=\"cbx.value\" >{{cbx.label}}</mat-radio-button>\r\n\r\n </mat-radio-group>\r\n\r\n</ui-simple-layout>\r\n", styles: [":host mat-radio-group{display:flex;flex-direction:column}:host mat-radio-button{margin-top:.2em;margin-bottom:.2em}\n"] }]
38
+ }], ctorParameters: function () { return [{ type: i1.NgControl, decorators: [{
39
+ type: Optional
40
+ }, {
41
+ type: Self
42
+ }] }]; }, propDecorators: { options: [{
43
+ type: Input
44
+ }], displayAttribute: [{
45
+ type: Input
46
+ }], valueAttribute: [{
47
+ type: Input
48
+ }], groupName: [{
49
+ type: Input
50
+ }], optionEnabled: [{
51
+ type: Input
52
+ }] } });
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFkaW8tZ3JvdXAuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkvc3JjL2xpYi9yYWRpby1ncm91cC9yYWRpby1ncm91cC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL3JhZGlvLWdyb3VwL3JhZGlvLWdyb3VwLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFxQixRQUFRLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUNuRyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQzs7Ozs7O0FBZWxFLE1BQU0sT0FBTyxtQkFBb0IsU0FBUSxpQkFBaUI7SUFheEQsWUFBdUMsT0FBa0I7UUFDdkQsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBRHNCLFlBQU8sR0FBUCxPQUFPLENBQVc7UUFWekQsT0FBRSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxHQUFHLE1BQU0sQ0FBQyxDQUFDO1FBRy9CLHFCQUFnQixHQUFHLE1BQU0sQ0FBQztRQUcxQixjQUFTLEdBQUcsUUFBUSxHQUFHLElBQUksQ0FBQyxFQUFFLENBQUM7UUFFL0Isa0JBQWEsR0FBRyxDQUFDLE1BQVcsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDO0lBSS9DLENBQUM7SUFFRCxxQkFBcUI7SUFDckIsc0JBQXNCO0lBQ3RCLElBQUk7SUFFSixXQUFXLENBQUMsT0FBc0I7UUFDaEMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUMzQixJQUFJLE9BQU8sQ0FBQyxPQUFPLEVBQUU7WUFDbkIsSUFBSSxDQUFDLElBQUksR0FBRyxFQUFFLENBQUM7WUFDZixPQUFPLENBQUMsT0FBTyxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLEVBQUU7Z0JBQ3hDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDO29CQUNiLEtBQUssRUFBRSxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFO29CQUN6RCxLQUFLLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQztpQkFDakMsQ0FBQyxDQUFBO1lBQ0osQ0FBQyxDQUFDLENBQUM7U0FDSjtJQUNILENBQUM7O2dIQWhDVSxtQkFBbUI7b0dBQW5CLG1CQUFtQixrUUNoQmhDLHNUQVNBOzJGRE9hLG1CQUFtQjtrQkFaL0IsU0FBUzsrQkFDRSxnQkFBZ0I7OzBCQXdCYixRQUFROzswQkFBSSxJQUFJOzRDQVJwQixPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csZ0JBQWdCO3NCQUF4QixLQUFLO2dCQUNHLGNBQWM7c0JBQXRCLEtBQUs7Z0JBRUcsU0FBUztzQkFBakIsS0FBSztnQkFFRyxhQUFhO3NCQUFyQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25DaGFuZ2VzLCBPbkluaXQsIE9wdGlvbmFsLCBTZWxmLCBTaW1wbGVDaGFuZ2VzIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBVaVNpbXBsZUNvbXBvbmVudCB9IGZyb20gJy4uL3NpbXBsZS91aS1zaW1wbGUuY29tcG9uZW50JztcbmltcG9ydCB7IE5nQ29udHJvbCB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndWktcmFkaW8tZ3JvdXAnLFxuICB0ZW1wbGF0ZVVybDogJy4vcmFkaW8tZ3JvdXAuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9yYWRpby1ncm91cC5jb21wb25lbnQuc2NzcyddLFxuICAvLyBwcm92aWRlcnM6IFtcbiAgLy8gICB7XG4gIC8vICAgICBwcm92aWRlOiBOR19WQUxJREFUT1JTLFxuICAvLyAgICAgbXVsdGk6IHRydWUsXG4gIC8vICAgICB1c2VFeGlzdGluZzogQ2hlY2tib3hHcm91cENvbXBvbmVudFxuICAvLyAgIH1cbiAgLy8gXVxufSlcbmV4cG9ydCBjbGFzcyBSYWRpb0dyb3VwQ29tcG9uZW50IGV4dGVuZHMgVWlTaW1wbGVDb21wb25lbnQgaW1wbGVtZW50cyAvKk9uSW5pdCwgKi9PbkNoYW5nZXMge1xuXG4gIGNieHM6IGFueTtcbiAgaWQgPSBNYXRoLnJvdW5kKE1hdGgucmFuZG9tKCkgKiA5OTk5OTkpO1xuXG4gIEBJbnB1dCgpIG9wdGlvbnM7XG4gIEBJbnB1dCgpIGRpc3BsYXlBdHRyaWJ1dGUgPSAnbmFtZSc7XG4gIEBJbnB1dCgpIHZhbHVlQXR0cmlidXRlO1xuXG4gIEBJbnB1dCgpIGdyb3VwTmFtZSA9ICdyYWRpby0nICsgdGhpcy5pZDtcblxuICBASW5wdXQoKSBvcHRpb25FbmFibGVkID0gKG9wdGlvbjogYW55KSA9PiB0cnVlO1xuXG4gIGNvbnN0cnVjdG9yKEBPcHRpb25hbCgpIEBTZWxmKCkgcHVibGljIGNvbnRyb2w6IE5nQ29udHJvbCkge1xuICAgIHN1cGVyKGNvbnRyb2wpO1xuICB9XG5cbiAgLy8gbmdPbkluaXQoKTogdm9pZCB7XG4gIC8vICAgc3VwZXIubmdPbkluaXQoKTtcbiAgLy8gfVxuXG4gIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpIHtcbiAgICBzdXBlci5uZ09uQ2hhbmdlcyhjaGFuZ2VzKTtcbiAgICBpZiAoY2hhbmdlcy5vcHRpb25zKSB7XG4gICAgICB0aGlzLmNieHMgPSBbXTtcbiAgICAgIGNoYW5nZXMub3B0aW9ucy5jdXJyZW50VmFsdWUuZm9yRWFjaChjdiA9PiB7XG4gICAgICAgIHRoaXMuY2J4cy5wdXNoKHtcbiAgICAgICAgICB2YWx1ZTogdGhpcy52YWx1ZUF0dHJpYnV0ZSA/IGN2W3RoaXMudmFsdWVBdHRyaWJ1dGVdIDogY3YsXG4gICAgICAgICAgbGFiZWw6IGN2W3RoaXMuZGlzcGxheUF0dHJpYnV0ZV1cbiAgICAgICAgfSlcbiAgICAgIH0pO1xuICAgIH1cbiAgfVxuXG4gIC8vIHdyaXRlVmFsdWUob2JqOiBhbnkpOiB2b2lkIHtcbiAgLy8gICBpZiAodGhpcy5jb21wb25lbnRGb3JtQ29udHJvbCkge1xuICAvLyAgICAgdGhpcy5jb21wb25lbnRGb3JtQ29udHJvbC5zZXRWYWx1ZShvYmopO1xuICAvLyAgIH1cbiAgLy8gfVxufVxuIiwiPHVpLXNpbXBsZS1sYXlvdXQgW2N0eF09XCJ0aGlzXCI+XHJcblxyXG4gIDxtYXQtcmFkaW8tZ3JvdXAgW2Zvcm1Db250cm9sXT1cImNvbXBvbmVudEZvcm1Db250cm9sXCIgW25hbWVdPVwiZ3JvdXBOYW1lXCIgW2NsYXNzXT1cInNpemVcIj5cclxuXHJcbiAgICA8bWF0LXJhZGlvLWJ1dHRvbiAqbmdGb3I9XCJsZXQgY2J4IG9mIGNieHNcIiBbdmFsdWVdPVwiY2J4LnZhbHVlXCIgPnt7Y2J4LmxhYmVsfX08L21hdC1yYWRpby1idXR0b24+XHJcblxyXG4gIDwvbWF0LXJhZGlvLWdyb3VwPlxyXG5cclxuPC91aS1zaW1wbGUtbGF5b3V0PlxyXG4iXX0=
@@ -0,0 +1,91 @@
1
+ import { Component, Inject, Input, Optional, Self, ViewChild } from '@angular/core';
2
+ import { UiSimpleComponent } from '../simple/ui-simple.component';
3
+ import { UI_TRANSLATESERVICE } from '../services/ui-translate.service';
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/select";
9
+ import * as i5 from "@angular/material/core";
10
+ import * as i6 from "../button/button.component";
11
+ import * as i7 from "../simple/ui-simple-layout.component";
12
+ export class SelectComponent extends UiSimpleComponent {
13
+ constructor(ngControl, translateService) {
14
+ super(ngControl);
15
+ this.ngControl = ngControl;
16
+ this.translateService = translateService;
17
+ this.multiple = false;
18
+ this.options = [];
19
+ this.allowEmptySelection = false;
20
+ this.lastCount = -1;
21
+ this.overoption = false;
22
+ this.optionToValue = (o) => this.valueAttribute ? o[this.valueAttribute] : o;
23
+ }
24
+ ngOnInit() {
25
+ super.ngOnInit();
26
+ if (this.optionFormatter === undefined) {
27
+ this.optionFormatter = o => this.displayAttribute ? o[this.displayAttribute] : o;
28
+ }
29
+ if (this.multiple && this.componentFormControl) {
30
+ this.lastCount = this.componentFormControl.value.length;
31
+ this.componentFormControl.valueChanges.subscribe(v => {
32
+ if (v.length === 1 && this.lastCount === 0 && this.overoption) {
33
+ this.select.selectionChange.emit(this.optionToValue(v));
34
+ this.select.close();
35
+ }
36
+ this.lastCount = v.length;
37
+ });
38
+ }
39
+ }
40
+ selectOption(o, select) {
41
+ select.selectionChange.emit(this.optionToValue(o));
42
+ select.close();
43
+ }
44
+ selectAll() {
45
+ this.componentFormControl.setValue(this.options.map(o => this.optionToValue(o)));
46
+ }
47
+ clearAll() {
48
+ this.componentFormControl.setValue([]);
49
+ }
50
+ setDisabledState(isDisabled) {
51
+ }
52
+ }
53
+ SelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: SelectComponent, deps: [{ token: i1.NgControl, optional: true, self: true }, { token: UI_TRANSLATESERVICE }], target: i0.ɵɵFactoryTarget.Component });
54
+ SelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.5", type: SelectComponent, selector: "ui-select", inputs: { multiple: "multiple", triggerFormatter: "triggerFormatter", valueAttribute: "valueAttribute", resetText: "resetText", displayAttribute: "displayAttribute", options: "options", optionFormatter: "optionFormatter", optionTemplateRef: "optionTemplateRef", triggerTemplateRef: "triggerTemplateRef", panelClass: "panelClass", allowEmptySelection: "allowEmptySelection" }, viewQueries: [{ propertyName: "select", first: true, predicate: ["select"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<ui-simple-layout [ctx]=\"this\">\r\n\r\n<mat-select class=\"control-container\" #select [panelClass]=\"panelClass\" [placeholder]=\"placeholder\" [formControl]=\"componentFormControl\" [multiple]=\"multiple\">\r\n\r\n <mat-select-trigger *ngIf=\"triggerTemplateRef\">\r\n <ng-template [ngTemplateOutlet]=\"triggerTemplateRef\" [ngTemplateOutletContext]=\"{option:componentFormControl?.value}\" ></ng-template>\r\n </mat-select-trigger>\r\n\r\n <mat-select-trigger *ngIf=\"triggerFormatter\">{{componentFormControl?.value ? triggerFormatter(componentFormControl?.value) : ''}}</mat-select-trigger>\r\n\r\n <mat-option *ngIf=\"resetText\">{{resetText}}</mat-option>\r\n\r\n <mat-option *ngFor=\"let o of options\" [value]=\"optionToValue(o)\" >\r\n\r\n <div class=\"option-container\" (mouseenter)=\"overoption = true;\" (mouseleave)=\"overoption = false\">\r\n\r\n <ng-container *ngIf=\"optionTemplateRef\">\r\n <ng-template [ngTemplateOutlet]=\"optionTemplateRef\" [ngTemplateOutletContext]=\"{option:o}\" ></ng-template>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!optionTemplateRef\">\r\n {{optionFormatter(o)}}\r\n </ng-container>\r\n\r\n <mat-icon class=\"select-one\" *ngIf=\"multiple && componentFormControl?.value?.length === 0\" (click)=\"selectOption(o, select)\">north_west</mat-icon>\r\n </div>\r\n\r\n </mat-option>\r\n\r\n <div class=\"buttons\" *ngIf=\"multiple\">\r\n <ui-button style=\"margin-right: auto;\" [kind]=\"'basic'\" [size]=\"'smaller'\" [label]=\"translateService.instant('ui.controls.ui-select.clear-selection')\" (click)=\"clearAll()\"></ui-button>\r\n <ui-button [size]=\"'smaller'\" [label]=\"translateService.instant('ui.controls.ui-select.all')\" (click)=\"selectAll()\"></ui-button>\r\n <ui-button [size]=\"'smaller'\" style=\"padding-left: 0.2em;\" [disabled]=\"componentFormControl?.value?.length === 0 && !allowEmptySelection\" [label]=\"translateService.instant('ui.controls.ui-select.apply-selection') + (componentFormControl?.value?.length > 0 ? ' (' + componentFormControl.value.length + ')' : '')\" (click)=\"select.close()\"></ui-button>\r\n </div>\r\n\r\n</mat-select>\r\n\r\n</ui-simple-layout>\r\n", styles: [":host{width:100%}:host .control-container{width:100%;position:relative}:host ::ng-deep [slot=suffix]{position:absolute;cursor:pointer;user-select:none;transition:color .25s;top:calc(50% - .5em);right:.2em;width:1em;height:1em;font-size:1.5em}:host ::ng-deep [slot=prefix]{position:absolute;cursor:pointer;user-select:none;transition:color .25s;top:calc(50% - .5em);left:.2em;width:1em;height:1em;font-size:1.5em}:host ::ng-deep input,:host ::ng-deep textarea,:host ::ng-deep ::ng-deep .mat-select-trigger,:host ::ng-deep ::ng-deep .mat-mdc-select-trigger{resize:none;width:100%;line-height:1.2em;font-size:1em;outline:none;border-style:solid;transition:border-color 333ms}:host ::ng-deep input.has-suffix,:host ::ng-deep textarea.has-suffix,:host ::ng-deep ::ng-deep .mat-select-trigger.has-suffix,:host ::ng-deep ::ng-deep .mat-mdc-select-trigger.has-suffix{padding-right:1.8em}:host ::ng-deep input.centered,:host ::ng-deep textarea.centered,:host ::ng-deep ::ng-deep .mat-select-trigger.centered,:host ::ng-deep ::ng-deep .mat-mdc-select-trigger.centered{text-align:center}: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", "::ng-deep .mat-mdc-select-panel{padding:0!important}::ng-deep .mat-mdc-select-arrow-wrapper{height:1px!important}::ng-deep .mat-select-panel .select-one,::ng-deep .mat-mdc-select-panel .select-one{position:absolute;right:0;top:.3em;display:none}::ng-deep .mat-select-panel .mat-option-text:hover .select-one,::ng-deep .mat-select-panel .mat-mdc-option:hover .select-one,::ng-deep .mat-mdc-select-panel .mat-option-text:hover .select-one,::ng-deep .mat-mdc-select-panel .mat-mdc-option:hover .select-one{display:block}::ng-deep .mat-select-panel .buttons,::ng-deep .mat-mdc-select-panel .buttons{padding:.2em;background-color:#fff;display:flex;position:sticky;bottom:0}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { 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: "component", type: i4.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator"], exportAs: ["matSelect"] }, { kind: "directive", type: i4.MatSelectTrigger, selector: "mat-select-trigger" }, { kind: "component", type: i5.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "component", type: i6.ButtonComponent, selector: "ui-button", inputs: ["type", "matIconPrefix", "label", "disabled", "busy", "kind", "color", "size", "formInvalid"] }, { kind: "component", type: i7.UiSimpleLayoutComponent, selector: "ui-simple-layout", inputs: ["ctx"] }] });
55
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: SelectComponent, decorators: [{
56
+ type: Component,
57
+ args: [{ selector: 'ui-select', template: "<ui-simple-layout [ctx]=\"this\">\r\n\r\n<mat-select class=\"control-container\" #select [panelClass]=\"panelClass\" [placeholder]=\"placeholder\" [formControl]=\"componentFormControl\" [multiple]=\"multiple\">\r\n\r\n <mat-select-trigger *ngIf=\"triggerTemplateRef\">\r\n <ng-template [ngTemplateOutlet]=\"triggerTemplateRef\" [ngTemplateOutletContext]=\"{option:componentFormControl?.value}\" ></ng-template>\r\n </mat-select-trigger>\r\n\r\n <mat-select-trigger *ngIf=\"triggerFormatter\">{{componentFormControl?.value ? triggerFormatter(componentFormControl?.value) : ''}}</mat-select-trigger>\r\n\r\n <mat-option *ngIf=\"resetText\">{{resetText}}</mat-option>\r\n\r\n <mat-option *ngFor=\"let o of options\" [value]=\"optionToValue(o)\" >\r\n\r\n <div class=\"option-container\" (mouseenter)=\"overoption = true;\" (mouseleave)=\"overoption = false\">\r\n\r\n <ng-container *ngIf=\"optionTemplateRef\">\r\n <ng-template [ngTemplateOutlet]=\"optionTemplateRef\" [ngTemplateOutletContext]=\"{option:o}\" ></ng-template>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!optionTemplateRef\">\r\n {{optionFormatter(o)}}\r\n </ng-container>\r\n\r\n <mat-icon class=\"select-one\" *ngIf=\"multiple && componentFormControl?.value?.length === 0\" (click)=\"selectOption(o, select)\">north_west</mat-icon>\r\n </div>\r\n\r\n </mat-option>\r\n\r\n <div class=\"buttons\" *ngIf=\"multiple\">\r\n <ui-button style=\"margin-right: auto;\" [kind]=\"'basic'\" [size]=\"'smaller'\" [label]=\"translateService.instant('ui.controls.ui-select.clear-selection')\" (click)=\"clearAll()\"></ui-button>\r\n <ui-button [size]=\"'smaller'\" [label]=\"translateService.instant('ui.controls.ui-select.all')\" (click)=\"selectAll()\"></ui-button>\r\n <ui-button [size]=\"'smaller'\" style=\"padding-left: 0.2em;\" [disabled]=\"componentFormControl?.value?.length === 0 && !allowEmptySelection\" [label]=\"translateService.instant('ui.controls.ui-select.apply-selection') + (componentFormControl?.value?.length > 0 ? ' (' + componentFormControl.value.length + ')' : '')\" (click)=\"select.close()\"></ui-button>\r\n </div>\r\n\r\n</mat-select>\r\n\r\n</ui-simple-layout>\r\n", styles: [":host{width:100%}:host .control-container{width:100%;position:relative}:host ::ng-deep [slot=suffix]{position:absolute;cursor:pointer;user-select:none;transition:color .25s;top:calc(50% - .5em);right:.2em;width:1em;height:1em;font-size:1.5em}:host ::ng-deep [slot=prefix]{position:absolute;cursor:pointer;user-select:none;transition:color .25s;top:calc(50% - .5em);left:.2em;width:1em;height:1em;font-size:1.5em}:host ::ng-deep input,:host ::ng-deep textarea,:host ::ng-deep ::ng-deep .mat-select-trigger,:host ::ng-deep ::ng-deep .mat-mdc-select-trigger{resize:none;width:100%;line-height:1.2em;font-size:1em;outline:none;border-style:solid;transition:border-color 333ms}:host ::ng-deep input.has-suffix,:host ::ng-deep textarea.has-suffix,:host ::ng-deep ::ng-deep .mat-select-trigger.has-suffix,:host ::ng-deep ::ng-deep .mat-mdc-select-trigger.has-suffix{padding-right:1.8em}:host ::ng-deep input.centered,:host ::ng-deep textarea.centered,:host ::ng-deep ::ng-deep .mat-select-trigger.centered,:host ::ng-deep ::ng-deep .mat-mdc-select-trigger.centered{text-align:center}: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", "::ng-deep .mat-mdc-select-panel{padding:0!important}::ng-deep .mat-mdc-select-arrow-wrapper{height:1px!important}::ng-deep .mat-select-panel .select-one,::ng-deep .mat-mdc-select-panel .select-one{position:absolute;right:0;top:.3em;display:none}::ng-deep .mat-select-panel .mat-option-text:hover .select-one,::ng-deep .mat-select-panel .mat-mdc-option:hover .select-one,::ng-deep .mat-mdc-select-panel .mat-option-text:hover .select-one,::ng-deep .mat-mdc-select-panel .mat-mdc-option:hover .select-one{display:block}::ng-deep .mat-select-panel .buttons,::ng-deep .mat-mdc-select-panel .buttons{padding:.2em;background-color:#fff;display:flex;position:sticky;bottom:0}\n"] }]
58
+ }], ctorParameters: function () { return [{ type: i1.NgControl, decorators: [{
59
+ type: Optional
60
+ }, {
61
+ type: Self
62
+ }] }, { type: undefined, decorators: [{
63
+ type: Inject,
64
+ args: [UI_TRANSLATESERVICE]
65
+ }] }]; }, propDecorators: { multiple: [{
66
+ type: Input
67
+ }], triggerFormatter: [{
68
+ type: Input
69
+ }], valueAttribute: [{
70
+ type: Input
71
+ }], resetText: [{
72
+ type: Input
73
+ }], displayAttribute: [{
74
+ type: Input
75
+ }], options: [{
76
+ type: Input
77
+ }], optionFormatter: [{
78
+ type: Input
79
+ }], optionTemplateRef: [{
80
+ type: Input
81
+ }], triggerTemplateRef: [{
82
+ type: Input
83
+ }], panelClass: [{
84
+ type: Input
85
+ }], allowEmptySelection: [{
86
+ type: Input
87
+ }], select: [{
88
+ type: ViewChild,
89
+ args: ['select']
90
+ }] } });
91
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../projects/ui/src/lib/select/select.component.ts","../../../../../projects/ui/src/lib/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, Input, OnInit, Optional, Self, TemplateRef, ViewChild } from '@angular/core';\r\nimport { NgControl } from '@angular/forms';\r\nimport { UiSimpleComponent } from '../simple/ui-simple.component';\r\nimport { MatSelect } from '@angular/material/select';\r\nimport { IUiTranslateService, UI_TRANSLATESERVICE } from '../services/ui-translate.service';\r\n\r\n@Component({\r\n  selector: 'ui-select',\r\n  templateUrl: './select.component.html',\r\n  styleUrls: [ '../simple/ui-simple-layout.component.scss', './select.component.scss' ]\r\n})\r\n\r\nexport class SelectComponent extends UiSimpleComponent implements OnInit {\r\n\r\n  @Input() multiple = false;\r\n  @Input() triggerFormatter: any;\r\n  @Input() valueAttribute: string | undefined;\r\n  @Input() resetText: string | undefined;\r\n  @Input() displayAttribute: string | undefined;\r\n\r\n  @Input() options: any[] = [];\r\n  @Input() optionFormatter: ((arg: any) => string | undefined) | undefined;\r\n  @Input() optionTemplateRef?: TemplateRef<any>;\r\n  @Input() triggerTemplateRef?: TemplateRef<any>;\r\n  @Input() panelClass;\r\n  @Input() allowEmptySelection = false;\r\n\r\n  @ViewChild('select') select: MatSelect;\r\n\r\n  lastCount = -1;\r\n  overoption = false;\r\n\r\n  constructor(@Optional() @Self() public ngControl: NgControl,\r\n              @Inject(UI_TRANSLATESERVICE) public translateService: IUiTranslateService) {\r\n    super(ngControl);\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    super.ngOnInit();\r\n    if (this.optionFormatter === undefined) {\r\n      this.optionFormatter = o => this.displayAttribute ? o[this.displayAttribute] : o;\r\n    }\r\n    if (this.multiple && this.componentFormControl) {\r\n      this.lastCount = this.componentFormControl.value.length;\r\n      this.componentFormControl.valueChanges.subscribe(v => {\r\n        if (v.length === 1 && this.lastCount === 0 && this.overoption) {\r\n          this.select.selectionChange.emit(this.optionToValue(v));\r\n          this.select.close();\r\n        }\r\n        this.lastCount = v.length;\r\n      });\r\n    }\r\n  }\r\n\r\n  optionToValue = (o: any) => this.valueAttribute ? o[this.valueAttribute] : o;\r\n\r\n  selectOption(o: any, select: MatSelect) {\r\n    select.selectionChange.emit(this.optionToValue(o));\r\n    select.close();\r\n  }\r\n\r\n  selectAll() {\r\n    this.componentFormControl.setValue(this.options.map(o => this.optionToValue(o)));\r\n  }\r\n\r\n  clearAll() {\r\n    this.componentFormControl.setValue([]);\r\n  }\r\n\r\n  setDisabledState(isDisabled: boolean): void {\r\n  }\r\n}\r\n","<ui-simple-layout [ctx]=\"this\">\r\n\r\n<mat-select class=\"control-container\" #select [panelClass]=\"panelClass\" [placeholder]=\"placeholder\" [formControl]=\"componentFormControl\" [multiple]=\"multiple\">\r\n\r\n  <mat-select-trigger *ngIf=\"triggerTemplateRef\">\r\n    <ng-template [ngTemplateOutlet]=\"triggerTemplateRef\" [ngTemplateOutletContext]=\"{option:componentFormControl?.value}\" ></ng-template>\r\n  </mat-select-trigger>\r\n\r\n  <mat-select-trigger *ngIf=\"triggerFormatter\">{{componentFormControl?.value ? triggerFormatter(componentFormControl?.value) : ''}}</mat-select-trigger>\r\n\r\n  <mat-option *ngIf=\"resetText\">{{resetText}}</mat-option>\r\n\r\n  <mat-option *ngFor=\"let o of options\" [value]=\"optionToValue(o)\" >\r\n\r\n    <div class=\"option-container\" (mouseenter)=\"overoption = true;\" (mouseleave)=\"overoption = false\">\r\n\r\n      <ng-container *ngIf=\"optionTemplateRef\">\r\n        <ng-template [ngTemplateOutlet]=\"optionTemplateRef\" [ngTemplateOutletContext]=\"{option:o}\" ></ng-template>\r\n      </ng-container>\r\n\r\n      <ng-container *ngIf=\"!optionTemplateRef\">\r\n        {{optionFormatter(o)}}\r\n      </ng-container>\r\n\r\n      <mat-icon class=\"select-one\" *ngIf=\"multiple && componentFormControl?.value?.length === 0\" (click)=\"selectOption(o, select)\">north_west</mat-icon>\r\n    </div>\r\n\r\n  </mat-option>\r\n\r\n  <div class=\"buttons\" *ngIf=\"multiple\">\r\n    <ui-button style=\"margin-right: auto;\" [kind]=\"'basic'\" [size]=\"'smaller'\" [label]=\"translateService.instant('ui.controls.ui-select.clear-selection')\" (click)=\"clearAll()\"></ui-button>\r\n    <ui-button [size]=\"'smaller'\" [label]=\"translateService.instant('ui.controls.ui-select.all')\" (click)=\"selectAll()\"></ui-button>\r\n    <ui-button [size]=\"'smaller'\" style=\"padding-left: 0.2em;\" [disabled]=\"componentFormControl?.value?.length === 0 && !allowEmptySelection\" [label]=\"translateService.instant('ui.controls.ui-select.apply-selection') + (componentFormControl?.value?.length > 0 ? ' (' + componentFormControl.value.length + ')' : '')\" (click)=\"select.close()\"></ui-button>\r\n  </div>\r\n\r\n</mat-select>\r\n\r\n</ui-simple-layout>\r\n"]}