@rlucan/ui 14.2.4 → 14.2.6

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 (107) hide show
  1. package/esm2022/lib/action-button/action-button.component.mjs +99 -0
  2. package/esm2022/lib/action-icon/action-icon.component.mjs +37 -0
  3. package/esm2022/lib/autocomplete/autocomplete.component.mjs +391 -0
  4. package/esm2022/lib/avatar/avatar.component.mjs +34 -0
  5. package/esm2022/lib/button/button.component.mjs +57 -0
  6. package/esm2022/lib/checkbox/checkbox.component.mjs +39 -0
  7. package/{esm2020 → esm2022}/lib/checkbox-group/checkbox-group.component.mjs +91 -91
  8. package/esm2022/lib/currency/currency.component.mjs +151 -0
  9. package/esm2022/lib/date/date.component.mjs +68 -0
  10. package/{esm2020 → esm2022}/lib/dialog/dialog.component.mjs +37 -37
  11. package/esm2022/lib/directives/force-visibility/force-visibility.directive.mjs +104 -0
  12. package/esm2022/lib/editor/editor.component.mjs +119 -0
  13. package/{esm2020 → esm2022}/lib/elements/burger/burger.component.mjs +21 -21
  14. package/{esm2020 → esm2022}/lib/elements/expander/expander.component.mjs +28 -28
  15. package/{esm2020 → esm2022}/lib/elements/validation-message/validation-message.component.mjs +47 -47
  16. package/esm2022/lib/file/file.component.mjs +145 -0
  17. package/esm2022/lib/file-uploader/ui-file-uploader.component.mjs +405 -0
  18. package/esm2022/lib/input/input.component.mjs +265 -0
  19. package/esm2022/lib/input-autocomplete/input-autocomplete.component.mjs +277 -0
  20. package/esm2022/lib/layouts/base/ui-base-layout.component.mjs +22 -0
  21. package/esm2022/lib/layouts/base/ui-base.component.mjs +74 -0
  22. package/esm2022/lib/layouts/simple/ui-simple-layout.component.mjs +18 -0
  23. package/esm2022/lib/layouts/simple/ui-simple.component.mjs +166 -0
  24. package/{esm2020 → esm2022}/lib/radio/radio.component.mjs +21 -21
  25. package/esm2022/lib/radio-group/radio-group.component.mjs +53 -0
  26. package/esm2022/lib/select/select.component.mjs +115 -0
  27. package/esm2022/lib/services/message-box.service.mjs +149 -0
  28. package/{esm2020 → esm2022}/lib/services/toast.service.mjs +23 -23
  29. package/{esm2020 → esm2022}/lib/services/ui-file.service.mjs +71 -71
  30. package/{esm2020 → esm2022}/lib/services/ui-translate.service.mjs +32 -32
  31. package/{esm2020 → esm2022}/lib/submit-button/submit-button.component.mjs +72 -72
  32. package/esm2022/lib/table/table.component.mjs +97 -0
  33. package/esm2022/lib/text-area/text-area.component.mjs +46 -0
  34. package/{esm2020 → esm2022}/lib/ui.model.mjs +1 -1
  35. package/esm2022/lib/ui.module.mjs +269 -0
  36. package/esm2022/public-api.mjs +35 -0
  37. package/{esm2020 → esm2022}/rlucan-ui.mjs +4 -4
  38. package/fesm2022/rlucan-ui.mjs +3442 -0
  39. package/fesm2022/rlucan-ui.mjs.map +1 -0
  40. package/index.d.ts +5 -5
  41. package/lib/action-button/action-button.component.d.ts +32 -33
  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 -30
  49. package/lib/date/date.component.d.ts +24 -23
  50. package/lib/dialog/dialog.component.d.ts +13 -13
  51. package/lib/directives/force-visibility/force-visibility.directive.d.ts +22 -20
  52. package/lib/editor/editor.component.d.ts +24 -0
  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 +35 -29
  57. package/lib/file-uploader/ui-file-uploader.component.d.ts +102 -102
  58. package/lib/input/input.component.d.ts +42 -29
  59. package/lib/input-autocomplete/input-autocomplete.component.d.ts +44 -0
  60. package/lib/{base → layouts/base}/ui-base-layout.component.d.ts +8 -8
  61. package/lib/{base → layouts/base}/ui-base.component.d.ts +23 -23
  62. package/lib/{simple → layouts/simple}/ui-simple-layout.component.d.ts +8 -7
  63. package/lib/{simple → layouts/simple}/ui-simple.component.d.ts +40 -39
  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 +35 -33
  67. package/lib/services/message-box.service.d.ts +58 -42
  68. package/lib/services/toast.service.d.ts +13 -13
  69. package/lib/services/ui-file.service.d.ts +33 -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 -56
  76. package/package.json +22 -24
  77. package/public-api.d.ts +29 -27
  78. package/scss/ui-defaults.scss +19 -4
  79. package/src/js/editorjs.mjs +9634 -0
  80. package/ui.scss +70 -20
  81. package/esm2020/lib/action-button/action-button.component.mjs +0 -96
  82. package/esm2020/lib/action-icon/action-icon.component.mjs +0 -37
  83. package/esm2020/lib/autocomplete/autocomplete.component.mjs +0 -391
  84. package/esm2020/lib/avatar/avatar.component.mjs +0 -34
  85. package/esm2020/lib/base/ui-base-layout.component.mjs +0 -22
  86. package/esm2020/lib/base/ui-base.component.mjs +0 -74
  87. package/esm2020/lib/button/button.component.mjs +0 -57
  88. package/esm2020/lib/checkbox/checkbox.component.mjs +0 -39
  89. package/esm2020/lib/currency/currency.component.mjs +0 -148
  90. package/esm2020/lib/date/date.component.mjs +0 -64
  91. package/esm2020/lib/directives/force-visibility/force-visibility.directive.mjs +0 -96
  92. package/esm2020/lib/file/file.component.mjs +0 -88
  93. package/esm2020/lib/file-uploader/ui-file-uploader.component.mjs +0 -394
  94. package/esm2020/lib/input/input.component.mjs +0 -258
  95. package/esm2020/lib/radio-group/radio-group.component.mjs +0 -53
  96. package/esm2020/lib/select/select.component.mjs +0 -91
  97. package/esm2020/lib/services/message-box.service.mjs +0 -113
  98. package/esm2020/lib/simple/ui-simple-layout.component.mjs +0 -15
  99. package/esm2020/lib/simple/ui-simple.component.mjs +0 -154
  100. package/esm2020/lib/table/table.component.mjs +0 -97
  101. package/esm2020/lib/text-area/text-area.component.mjs +0 -46
  102. package/esm2020/lib/ui.module.mjs +0 -255
  103. package/esm2020/public-api.mjs +0 -33
  104. package/fesm2015/rlucan-ui.mjs +0 -2918
  105. package/fesm2015/rlucan-ui.mjs.map +0 -1
  106. package/fesm2020/rlucan-ui.mjs +0 -2886
  107. package/fesm2020/rlucan-ui.mjs.map +0 -1
@@ -0,0 +1,391 @@
1
+ import { Component, Host, Input, Optional, SkipSelf, ViewChild } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR, UntypedFormControl } from '@angular/forms';
3
+ import { debounceTime } from 'rxjs/operators';
4
+ import { UiBaseComponent } from '../layouts/base/ui-base.component';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/forms";
7
+ import * as i2 from "@angular/common";
8
+ import * as i3 from "@angular/material/icon";
9
+ import * as i4 from "@angular/material/checkbox";
10
+ import * as i5 from "@angular/cdk/overlay";
11
+ import * as i6 from "../button/button.component";
12
+ import * as i7 from "../input/input.component";
13
+ import * as i8 from "../directives/force-visibility/force-visibility.directive";
14
+ export class AutocompleteComponent extends UiBaseComponent {
15
+ constructor(controlContainer,
16
+ // @Optional() @Self() public ngControl: NgControl,
17
+ cdr) {
18
+ super();
19
+ this.controlContainer = controlContainer;
20
+ this.cdr = cdr;
21
+ this.SHOWN_USERS_DELTA = 10;
22
+ this.multiple = true;
23
+ this.allowNew = false;
24
+ this.displayAttribute = 'name';
25
+ this.idAttribute = 'id';
26
+ this.filteredOptions = [];
27
+ this.filteredMaxItemsShown = this.SHOWN_USERS_DELTA;
28
+ // skipBlur = false;
29
+ // typingStarted = false;
30
+ this.messageShown = false;
31
+ this.alreadyAdded = false;
32
+ this.optionsVisible = false;
33
+ this.inputFocused = false;
34
+ this.inputControl = new UntypedFormControl('');
35
+ this.checkboxSelection = new Set();
36
+ this.optionDisabled = () => false;
37
+ this.optionFormatter = (o) => o[this.displayAttribute];
38
+ }
39
+ buildSearchableOptions() {
40
+ return this.options.map(o => ({
41
+ ...o,
42
+ unselectable: this.optionDisabled(o),
43
+ searchString: `${this.optionFormatter(o)}`.toLowerCase()
44
+ }));
45
+ }
46
+ filterOptions(text) {
47
+ this.filteredMaxItemsShown = this.SHOWN_USERS_DELTA;
48
+ return this.searchableOptions.filter(u => u.searchString.includes(text));
49
+ }
50
+ ngOnInit() {
51
+ // console.log('ngoninit');
52
+ super.ngOnInit();
53
+ // if (this.formControlName && this.controlContainer.control) {
54
+ // this.control = this.controlContainer.control.get(this.formControlName) as FormControl;
55
+ // }
56
+ //
57
+ // this.user = this.control.value;
58
+ // this.value = this.control.value;
59
+ this.searchableOptions = this.buildSearchableOptions();
60
+ // if (this.control.disabled) {
61
+ // this.inputControl.disable();
62
+ // }
63
+ // this.control.statusChanges.subscribe(v => {
64
+ // if (v === 'DISABLED') {
65
+ // this.inputControl.disable();
66
+ // }
67
+ // if (v === 'VALID') {
68
+ // this.inputControl.enable();
69
+ // }
70
+ // });
71
+ this.inputControl.valueChanges.pipe(debounceTime(200)).subscribe(v => {
72
+ const lcv = v.toLowerCase();
73
+ this.filteredOptions = this.filterOptions(lcv);
74
+ if (this.filteredOptions.length > 0) {
75
+ this.focusedOption = this.filteredOptions[0];
76
+ }
77
+ else {
78
+ this.focusedOption = undefined;
79
+ }
80
+ if (v === '') {
81
+ this.focusedOption = undefined;
82
+ this.selectedOption = undefined;
83
+ }
84
+ // if (v !== '') {
85
+ // if (this.newUsername === v) {
86
+ // this.selectedUser = {id: null, fullName: v};
87
+ // this.initialUser = this.selectedUser;
88
+ // } else {
89
+ // if (this.filteredGroupsAndUsers.length > 0) {
90
+ // this.focusedGroup = this.filteredGroupsAndUsers[0];
91
+ // this.focusedUser = this.focusedGroup.filteredUsers[0];
92
+ // } else {
93
+ // this.focusedGroup = null;
94
+ // this.focusedUser = null;
95
+ // }
96
+ // if ((this.focusedUser && !this.focusedUser.unselectable) || this.focusedUser === this.initialUser) {
97
+ // this.selectedUser = this.focusedUser;
98
+ // } else {
99
+ // this.selectedUser = null;
100
+ // }
101
+ // }
102
+ // } else {
103
+ // this.selectedUser = null;
104
+ // this.focusedUser = null;
105
+ // this.focusedGroup = null;
106
+ // }
107
+ // this.onChange(v);
108
+ });
109
+ // if (this.user !== null) {
110
+ // let selectedUser = null;
111
+ // this.groupsAndUsers.find(g => g.users.find(u => {
112
+ // if (u.id === this.user.id) {
113
+ // selectedUser = u;
114
+ // return true;
115
+ // } else {
116
+ // return false;
117
+ // }
118
+ // }));
119
+ //
120
+ // if (selectedUser) {
121
+ // this.inputControl.setValue(selectedUser.fullName);
122
+ // this.selectedUser = selectedUser;
123
+ // } else {
124
+ // this.newUsername = this.user.fullName;
125
+ // this.inputControl.setValue(this.user.fullName);
126
+ // this.selectedUser = { id: null, fullName: this.newUsername };
127
+ // }
128
+ // } else {
129
+ // this.selectedUser = null;
130
+ // this.inputControl.setValue('');
131
+ // }
132
+ // this.initialUser = this.selectedUser;
133
+ // }
134
+ }
135
+ inputFocusChanged(focused) {
136
+ if (focused) {
137
+ this.optionsVisible = true;
138
+ }
139
+ }
140
+ // setTimeout(() => {
141
+ // if (!focused && this.skipBlur) {
142
+ // this.skipBlur = false;
143
+ // return;
144
+ // }
145
+ // if (!this.typingStarted && focused) {
146
+ // this.inputControl.setValue(this.inputControl.value);
147
+ // this.typingStarted = true;
148
+ // }
149
+ // if (!this.messageShown) {
150
+ // this.inputFocused = focused;
151
+ // if (!focused) {
152
+ // this.emitSelection('focus lost');
153
+ // }
154
+ // }
155
+ // }, 250);
156
+ // }
157
+ get hasCheckboxSelected() {
158
+ return this.checkboxSelection.size > 0;
159
+ }
160
+ optionChecked(u) {
161
+ return this.checkboxSelection.has(u[this.idAttribute]);
162
+ }
163
+ select(u) {
164
+ if (this.hasCheckboxSelected || u.unselectable) {
165
+ return;
166
+ }
167
+ if (!u.unselectable) {
168
+ this.selectedOption = u;
169
+ this.initialOption = u;
170
+ this.toggleDropdown();
171
+ }
172
+ }
173
+ toggleOptionCheckboxed(u) {
174
+ if (!u.unselectable) {
175
+ this.checkboxSelection.has(u[this.idAttribute]) ?
176
+ this.checkboxSelection.delete(u[this.idAttribute]) : this.checkboxSelection.add(u[this.idAttribute]);
177
+ }
178
+ this.input?.focus();
179
+ }
180
+ // get optionsVisible(): boolean {
181
+ // return this.inputFocused && this.typingStarted;
182
+ // }
183
+ keyPressed(keyEvent) {
184
+ this.lastEmittedId = -1;
185
+ this.optionsVisible = true;
186
+ // this.typingStarted = keyEvent.key !== 'Tab' && keyEvent.key !== 'Escape';
187
+ if (keyEvent.key === 'Escape') {
188
+ keyEvent.stopPropagation();
189
+ keyEvent.preventDefault();
190
+ this.optionsVisible = false;
191
+ return;
192
+ }
193
+ if (keyEvent.key === 'Enter' && this.hasCheckboxSelected) {
194
+ if (this.focusedOption && !this.focusedOption.unselectable) {
195
+ this.toggleOptionCheckboxed(this.focusedOption);
196
+ }
197
+ keyEvent.stopPropagation();
198
+ keyEvent.preventDefault();
199
+ return;
200
+ }
201
+ // if (keyEvent.key === 'Enter' && this.filteredGroupsAndUsers.length === 0 && this.focusedUser === null && !this.alreadyAdded) {
202
+ // this.newUser();
203
+ // keyEvent.stopPropagation();
204
+ // keyEvent.preventDefault();
205
+ // return;
206
+ // }
207
+ if (keyEvent.key === 'Enter') {
208
+ this.selectedOption = this.focusedOption;
209
+ keyEvent.stopPropagation();
210
+ keyEvent.preventDefault();
211
+ this.toggleDropdown();
212
+ return;
213
+ }
214
+ if ((keyEvent.key === 'ArrowDown' || keyEvent.key === 'ArrowUp') && !this.focusedOption) {
215
+ if (this.filteredOptions.length > 0) {
216
+ this.focusedOption = this.filteredOptions[0];
217
+ // if (!this.focusedUser.unselectable || this.focusedUser === this.initialUser) {
218
+ // this.selectedUser = this.focusedUser;
219
+ // }
220
+ this.selectedOption = this.focusedOption;
221
+ return;
222
+ }
223
+ }
224
+ if (keyEvent.key === 'ArrowDown' && this.focusedOption) {
225
+ const idx = this.filteredOptions.indexOf(this.focusedOption);
226
+ if (idx === this.filteredMaxItemsShown - 1) {
227
+ this.filteredMaxItemsShown += this.SHOWN_USERS_DELTA;
228
+ }
229
+ if (idx < this.filteredOptions.length - 1) {
230
+ this.focusedOption = this.filteredOptions[idx + 1];
231
+ this.selectedOption = this.focusedOption;
232
+ }
233
+ }
234
+ if (keyEvent.key === 'ArrowUp' && this.focusedOption) {
235
+ const idx = this.filteredOptions.indexOf(this.focusedOption);
236
+ if (idx > 0) {
237
+ this.focusedOption = this.filteredOptions[idx - 1];
238
+ this.selectedOption = this.focusedOption;
239
+ }
240
+ }
241
+ this.cdr.detectChanges();
242
+ }
243
+ toggleDropdown() {
244
+ this.optionsVisible = false;
245
+ this.emitSelection('toggle');
246
+ }
247
+ emitSelection(src) {
248
+ this.initialOption = this.selectedOption;
249
+ if (this.selectedOption) {
250
+ const checkId = this.selectedOption.id === null ? 0 : this.selectedOption.id;
251
+ if (this.lastEmittedId !== checkId) {
252
+ this.lastEmittedId = checkId;
253
+ this.onChange(this.options.find(o => o[this.idAttribute] === this.selectedOption[this.idAttribute]));
254
+ this.inputControl.setValue(this.selectedOption[this.displayAttribute]);
255
+ }
256
+ }
257
+ else {
258
+ // this.control.setValue(null);
259
+ this.onChange(null);
260
+ this.inputControl.setValue('', { emitEvent: false });
261
+ }
262
+ // if (this.selectedOption) {
263
+ // const checkId = this.selectedUser.id === null ? 0 : this.selectedUser.id;
264
+ // if (this.lastEmittedId !== checkId) {
265
+ // this.inputControl.setValue(this.selectedUser.fullName, {emitEvent: false});
266
+ // if (this.selectedUser.id) {
267
+ // this.groupsAndUsers.find(g => g.users.find(u => {
268
+ // if (u.id === this.selectedUser.id) {
269
+ // this.control.setValue(u);
270
+ // return true;
271
+ // } else {
272
+ // return false;
273
+ // }
274
+ // }));
275
+ // } else {
276
+ // this.control.setValue(this.selectedUser);
277
+ // }
278
+ // this.lastEmittedId = checkId;
279
+ // }
280
+ // } else {
281
+ // if (this.lastEmittedId !== null || this.lastEmittedId === -1/* || this.selectedUser?.unselectable*/) {
282
+ // this.control?.setValue(null);
283
+ // this.inputControl.setValue('', {emitEvent: false});
284
+ // this.lastEmittedId = null;
285
+ // }
286
+ // }
287
+ // this.typingStarted = false;
288
+ }
289
+ cancelCheckboxSelection() {
290
+ this.checkboxSelection.clear();
291
+ // this.skipBlur = true;
292
+ // this.input?.focus();
293
+ }
294
+ useCheckboxSelection() {
295
+ // this.newUsername = '';
296
+ // const users = [];
297
+ // this.groupsAndUsers.forEach(g => g.users.forEach(u => {
298
+ // if (!users.includes(u) && this.checkboxSelection.has(u.id)) {
299
+ // users.push(u);
300
+ // }
301
+ // }));
302
+ const outputOptions = this.options.filter(o => this.checkboxSelection.has(o[this.idAttribute]) && !this.optionDisabled(o));
303
+ if (outputOptions.length > 0) {
304
+ this.selectedOption = outputOptions[0];
305
+ this.inputControl.setValue(this.selectedOption[this.displayAttribute], { emitEvent: false });
306
+ this.onChange(outputOptions);
307
+ this.toggleDropdown();
308
+ // this.control?.setValue(outputOptions);
309
+ // this.typingStarted = false;
310
+ // this.skipBlur = true;
311
+ }
312
+ this.checkboxSelection.clear();
313
+ }
314
+ newOption() {
315
+ }
316
+ loadMore(visible) {
317
+ if (visible) {
318
+ this.filteredMaxItemsShown += this.SHOWN_USERS_DELTA;
319
+ }
320
+ }
321
+ focus() {
322
+ this.input?.focus();
323
+ }
324
+ registerOnChange(fn) {
325
+ this.onChange = fn;
326
+ }
327
+ registerOnTouched(fn) {
328
+ }
329
+ setDisabledState(isDisabled) {
330
+ isDisabled ? this.inputControl.disable() : this.inputControl.enable();
331
+ }
332
+ writeValue(obj) {
333
+ if (obj) {
334
+ if (obj.id) {
335
+ this.filteredOptions = this.searchableOptions.filter(so => so.id === obj.id);
336
+ }
337
+ else {
338
+ this.filteredOptions = this.filterOptions(obj[this.displayAttribute].toLowerCase());
339
+ }
340
+ if (this.filteredOptions.length === 1) {
341
+ this.selectedOption = this.filteredOptions[0];
342
+ this.focusedOption = this.filteredOptions[0];
343
+ }
344
+ this.inputControl.setValue(obj[this.displayAttribute]);
345
+ }
346
+ else {
347
+ this.filteredOptions = this.filterOptions('');
348
+ }
349
+ }
350
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: AutocompleteComponent, deps: [{ token: i1.ControlContainer, host: true, optional: true, skipSelf: true }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
351
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.11", type: AutocompleteComponent, selector: "ui-autocomplete", inputs: { options: "options", multiple: "multiple", allowNew: "allowNew", displayAttribute: "displayAttribute", idAttribute: "idAttribute", optionDisabled: "optionDisabled", optionFormatter: "optionFormatter" }, providers: [{
352
+ provide: NG_VALUE_ACCESSOR,
353
+ multi: true,
354
+ useExisting: AutocompleteComponent
355
+ }], viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }, { propertyName: "optionsTrigger", first: true, predicate: ["trigger"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"wrapper\" #wrapper>\r\n <div *ngIf=\"optionsVisible\" (click)=\"toggleDropdown()\" class=\"overlay\"></div>\r\n <ui-input [formControl]=\"inputControl\" #input #trigger=\"cdkOverlayOrigin\" cdkOverlayOrigin (focusChanged)=\"inputFocusChanged($event)\" (keyPressed)=\"keyPressed($event)\" [placeholder]=\"placeholder\" [useInputMessages]=\"'never'\">\r\n <div slot=\"prefix\"><ng-content select=\"[slot=acprefix]\"></ng-content></div>\r\n </ui-input>\r\n\r\n <ng-template cdkConnectedOverlay [cdkConnectedOverlayOrigin]=\"trigger\" [cdkConnectedOverlayOpen]=\"optionsVisible\">\r\n <div class=\"options-box\" style=\"display: flex; flex-direction: column\" [ngStyle]=\"{width: wrapper.offsetWidth + 'px'}\">\r\n <div class=\"options\" #options>\r\n\r\n <ng-container *ngFor=\"let option of filteredOptions; index as i\">\r\n <div *ngIf=\"i < filteredMaxItemsShown\" class=\"option-container\" [ngClass]=\"{selected: focusedOption === option}\">\r\n <mat-checkbox [checked]=\"optionChecked(option) || option.unselectable\" [disabled]=\"option.unselectable\" (change)=\"toggleOptionCheckboxed(option)\">\r\n <div class=\"option-container-inner\" (click)=\"select(option)\">\r\n <div class=\"option-option\" uiForceVisibility [visibilityWithin]=\"options\" [visibilityPadding]=\"4\" *ngIf=\"focusedOption === option\" [ngClass]=\"{unselectable: option.unselectable}\">\r\n {{optionFormatter(option)}}\r\n </div>\r\n <div class=\"option-option\" *ngIf=\"focusedOption !== option\" [ngClass]=\"{unselectable: option.unselectable}\">\r\n {{optionFormatter(option)}}\r\n </div>\r\n <mat-icon *ngIf=\"!hasCheckboxSelected && !option.unselectable\">north_west</mat-icon>\r\n </div>\r\n </mat-checkbox>\r\n </div>\r\n </ng-container>\r\n\r\n <div *ngIf=\"filteredOptions.length >= filteredMaxItemsShown\" class=\"option-container\" uiForceVisibility [visibilityWithin]=\"options\" [visibilityEmitChange]=\"true\" (visibilityChanged)=\"loadMore($event)\">\r\n &nbsp;\r\n </div>\r\n\r\n\r\n <div *ngIf=\"filteredOptions.length === 0 && !focusedOption\" class=\"new-user\">\r\n <ng-container *ngIf=\"alreadyAdded\">\r\n <div style=\"text-align: center\">U\u017Eivatel {{inputControl.value}} u\u017E je mezi dlu\u017En\u00EDky</div>\r\n </ng-container>\r\n <ng-container *ngIf=\"!alreadyAdded\">\r\n <div style=\"text-align: center; padding: 1em 0\">U\u017Eivatele <strong>{{inputControl.value}}</strong> nezn\u00E1me</div>\r\n <ui-button *ngIf=\"allowNew\" style=\"margin-top: 6px;\" [size]=\"'small'\" [label]=\"'P\u0159idat jej?'\" (click)=\"newOption()\"></ui-button>\r\n </ng-container>\r\n </div>\r\n <div *ngIf=\"filteredOptions.length === 0 && focusedOption\" class=\"new-user\">\r\n <div style=\"text-align: center\">Nezn\u00E1m\u00FD u\u017Eivatel {{inputControl.value}}</div>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"hasCheckboxSelected && filteredOptions.length > 0\" class=\"checkbox-buttons\">\r\n <ui-button [size]=\"'small'\" [kind]=\"'basic'\" [label]=\"'Zru\u0161it v\u00FDb\u011Br'\" (click)=\"cancelCheckboxSelection()\"></ui-button>\r\n <ui-button [size]=\"'small'\" [label]=\"'Pou\u017E\u00EDt v\u00FDb\u011Br (' + checkboxSelection.size + ')'\" (click)=\"useCheckboxSelection()\"></ui-button>\r\n </div>\r\n </div>\r\n </ng-template>\r\n</div>\r\n\r\n", styles: [":host .wrapper{position:relative;outline:none;display:flex}:host .overlay{position:fixed;inset:0}.options-box{max-height:248px;min-width:310px;box-shadow:0 2px 4px -1px #07254833,0 4px 5px #07254824,0 1px 10px #0725481f}.options-box .checkbox-buttons{display:flex;padding:8px 4px 4px;justify-content:space-between}.options-box .options{padding:4px;overflow:auto;scroll-behavior:smooth;display:flex;flex-direction:column}.options-box .options .option-container{padding:0 0 0 12px;display:flex;align-items:center}.options-box .options .option-container:hover{cursor:pointer}.options-box .options .option-container mat-checkbox{width:100%}.options-box .options .option-container mat-checkbox ::ng-deep .mdc-form-field{width:100%}.options-box .options .option-container mat-checkbox ::ng-deep .mdc-form-field label{display:flex;width:100%}.options-box .options .option-container-inner{flex:1 1 100%;display:flex;align-items:center}.options-box .options .option-container-inner .option-option{flex:1 1 100%;padding:10px 0 10px 8px}.options-box .options .option-container-inner mat-icon{display:none;font-size:20px;height:20px;margin-right:8px}.options-box .options .option-container-inner:hover mat-icon{display:block}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { 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.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i4.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex"], exportAs: ["matCheckbox"] }, { 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: i5.CdkConnectedOverlay, selector: "[cdk-connected-overlay], [connected-overlay], [cdkConnectedOverlay]", inputs: ["cdkConnectedOverlayOrigin", "cdkConnectedOverlayPositions", "cdkConnectedOverlayPositionStrategy", "cdkConnectedOverlayOffsetX", "cdkConnectedOverlayOffsetY", "cdkConnectedOverlayWidth", "cdkConnectedOverlayHeight", "cdkConnectedOverlayMinWidth", "cdkConnectedOverlayMinHeight", "cdkConnectedOverlayBackdropClass", "cdkConnectedOverlayPanelClass", "cdkConnectedOverlayViewportMargin", "cdkConnectedOverlayScrollStrategy", "cdkConnectedOverlayOpen", "cdkConnectedOverlayDisableClose", "cdkConnectedOverlayTransformOriginOn", "cdkConnectedOverlayHasBackdrop", "cdkConnectedOverlayLockPosition", "cdkConnectedOverlayFlexibleDimensions", "cdkConnectedOverlayGrowAfterOpen", "cdkConnectedOverlayPush"], outputs: ["backdropClick", "positionChange", "attach", "detach", "overlayKeydown", "overlayOutsideClick"], exportAs: ["cdkConnectedOverlay"] }, { kind: "directive", type: i5.CdkOverlayOrigin, selector: "[cdk-overlay-origin], [overlay-origin], [cdkOverlayOrigin]", exportAs: ["cdkOverlayOrigin"] }, { kind: "component", type: i6.ButtonComponent, selector: "ui-button", inputs: ["type", "matIconPrefix", "label", "disabled", "busy", "kind", "color", "size", "formInvalid"] }, { kind: "component", type: i7.InputComponent, selector: "ui-input", inputs: ["prefixIcon", "suffixIcon", "type", "clearButton", "activeIcons", "forceHasPrefix", "forceHasSuffix", "textAlign"], outputs: ["focusChanged", "keyPressed"] }, { kind: "directive", type: i8.ForceVisibilityDirective, selector: "[uiForceVisibility]", inputs: ["visibilityWithin", "visibilityPadding", "visibilityOnRequestOnly", "visibilityEmitChange", "visibilityFromTop", "visibilityCheckEnabled"], outputs: ["visibilityChanged"], exportAs: ["ForceVisibilityDirective"] }] }); }
356
+ }
357
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: AutocompleteComponent, decorators: [{
358
+ type: Component,
359
+ args: [{ selector: 'ui-autocomplete', providers: [{
360
+ provide: NG_VALUE_ACCESSOR,
361
+ multi: true,
362
+ useExisting: AutocompleteComponent
363
+ }], template: "<div class=\"wrapper\" #wrapper>\r\n <div *ngIf=\"optionsVisible\" (click)=\"toggleDropdown()\" class=\"overlay\"></div>\r\n <ui-input [formControl]=\"inputControl\" #input #trigger=\"cdkOverlayOrigin\" cdkOverlayOrigin (focusChanged)=\"inputFocusChanged($event)\" (keyPressed)=\"keyPressed($event)\" [placeholder]=\"placeholder\" [useInputMessages]=\"'never'\">\r\n <div slot=\"prefix\"><ng-content select=\"[slot=acprefix]\"></ng-content></div>\r\n </ui-input>\r\n\r\n <ng-template cdkConnectedOverlay [cdkConnectedOverlayOrigin]=\"trigger\" [cdkConnectedOverlayOpen]=\"optionsVisible\">\r\n <div class=\"options-box\" style=\"display: flex; flex-direction: column\" [ngStyle]=\"{width: wrapper.offsetWidth + 'px'}\">\r\n <div class=\"options\" #options>\r\n\r\n <ng-container *ngFor=\"let option of filteredOptions; index as i\">\r\n <div *ngIf=\"i < filteredMaxItemsShown\" class=\"option-container\" [ngClass]=\"{selected: focusedOption === option}\">\r\n <mat-checkbox [checked]=\"optionChecked(option) || option.unselectable\" [disabled]=\"option.unselectable\" (change)=\"toggleOptionCheckboxed(option)\">\r\n <div class=\"option-container-inner\" (click)=\"select(option)\">\r\n <div class=\"option-option\" uiForceVisibility [visibilityWithin]=\"options\" [visibilityPadding]=\"4\" *ngIf=\"focusedOption === option\" [ngClass]=\"{unselectable: option.unselectable}\">\r\n {{optionFormatter(option)}}\r\n </div>\r\n <div class=\"option-option\" *ngIf=\"focusedOption !== option\" [ngClass]=\"{unselectable: option.unselectable}\">\r\n {{optionFormatter(option)}}\r\n </div>\r\n <mat-icon *ngIf=\"!hasCheckboxSelected && !option.unselectable\">north_west</mat-icon>\r\n </div>\r\n </mat-checkbox>\r\n </div>\r\n </ng-container>\r\n\r\n <div *ngIf=\"filteredOptions.length >= filteredMaxItemsShown\" class=\"option-container\" uiForceVisibility [visibilityWithin]=\"options\" [visibilityEmitChange]=\"true\" (visibilityChanged)=\"loadMore($event)\">\r\n &nbsp;\r\n </div>\r\n\r\n\r\n <div *ngIf=\"filteredOptions.length === 0 && !focusedOption\" class=\"new-user\">\r\n <ng-container *ngIf=\"alreadyAdded\">\r\n <div style=\"text-align: center\">U\u017Eivatel {{inputControl.value}} u\u017E je mezi dlu\u017En\u00EDky</div>\r\n </ng-container>\r\n <ng-container *ngIf=\"!alreadyAdded\">\r\n <div style=\"text-align: center; padding: 1em 0\">U\u017Eivatele <strong>{{inputControl.value}}</strong> nezn\u00E1me</div>\r\n <ui-button *ngIf=\"allowNew\" style=\"margin-top: 6px;\" [size]=\"'small'\" [label]=\"'P\u0159idat jej?'\" (click)=\"newOption()\"></ui-button>\r\n </ng-container>\r\n </div>\r\n <div *ngIf=\"filteredOptions.length === 0 && focusedOption\" class=\"new-user\">\r\n <div style=\"text-align: center\">Nezn\u00E1m\u00FD u\u017Eivatel {{inputControl.value}}</div>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"hasCheckboxSelected && filteredOptions.length > 0\" class=\"checkbox-buttons\">\r\n <ui-button [size]=\"'small'\" [kind]=\"'basic'\" [label]=\"'Zru\u0161it v\u00FDb\u011Br'\" (click)=\"cancelCheckboxSelection()\"></ui-button>\r\n <ui-button [size]=\"'small'\" [label]=\"'Pou\u017E\u00EDt v\u00FDb\u011Br (' + checkboxSelection.size + ')'\" (click)=\"useCheckboxSelection()\"></ui-button>\r\n </div>\r\n </div>\r\n </ng-template>\r\n</div>\r\n\r\n", styles: [":host .wrapper{position:relative;outline:none;display:flex}:host .overlay{position:fixed;inset:0}.options-box{max-height:248px;min-width:310px;box-shadow:0 2px 4px -1px #07254833,0 4px 5px #07254824,0 1px 10px #0725481f}.options-box .checkbox-buttons{display:flex;padding:8px 4px 4px;justify-content:space-between}.options-box .options{padding:4px;overflow:auto;scroll-behavior:smooth;display:flex;flex-direction:column}.options-box .options .option-container{padding:0 0 0 12px;display:flex;align-items:center}.options-box .options .option-container:hover{cursor:pointer}.options-box .options .option-container mat-checkbox{width:100%}.options-box .options .option-container mat-checkbox ::ng-deep .mdc-form-field{width:100%}.options-box .options .option-container mat-checkbox ::ng-deep .mdc-form-field label{display:flex;width:100%}.options-box .options .option-container-inner{flex:1 1 100%;display:flex;align-items:center}.options-box .options .option-container-inner .option-option{flex:1 1 100%;padding:10px 0 10px 8px}.options-box .options .option-container-inner mat-icon{display:none;font-size:20px;height:20px;margin-right:8px}.options-box .options .option-container-inner:hover mat-icon{display:block}\n"] }]
364
+ }], ctorParameters: function () { return [{ type: i1.ControlContainer, decorators: [{
365
+ type: Optional
366
+ }, {
367
+ type: Host
368
+ }, {
369
+ type: SkipSelf
370
+ }] }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { options: [{
371
+ type: Input
372
+ }], multiple: [{
373
+ type: Input
374
+ }], allowNew: [{
375
+ type: Input
376
+ }], displayAttribute: [{
377
+ type: Input
378
+ }], idAttribute: [{
379
+ type: Input
380
+ }], input: [{
381
+ type: ViewChild,
382
+ args: ['input']
383
+ }], optionsTrigger: [{
384
+ type: ViewChild,
385
+ args: ['trigger']
386
+ }], optionDisabled: [{
387
+ type: Input
388
+ }], optionFormatter: [{
389
+ type: Input
390
+ }] } });
391
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b2NvbXBsZXRlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL3NyYy9saWIvYXV0b2NvbXBsZXRlL2F1dG9jb21wbGV0ZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL2F1dG9jb21wbGV0ZS9hdXRvY29tcGxldGUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFxQixTQUFTLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBVSxRQUFRLEVBQUUsUUFBUSxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqSCxPQUFPLEVBQTBDLGlCQUFpQixFQUFFLGtCQUFrQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDL0csT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzlDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQzs7Ozs7Ozs7OztBQWNwRSxNQUFNLE9BQU8scUJBQXNCLFNBQVEsZUFBZTtJQUl4RCxZQUFzRCxnQkFBa0M7SUFDNUUsbURBQW1EO0lBQzNDLEdBQXNCO1FBQ3hDLEtBQUssRUFBRSxDQUFDO1FBSDRDLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7UUFFcEUsUUFBRyxHQUFILEdBQUcsQ0FBbUI7UUFKbEMsc0JBQWlCLEdBQUcsRUFBRSxDQUFDO1FBU3RCLGFBQVEsR0FBRyxJQUFJLENBQUM7UUFDaEIsYUFBUSxHQUFHLEtBQUssQ0FBQztRQUNqQixxQkFBZ0IsR0FBRyxNQUFNLENBQUM7UUFDMUIsZ0JBQVcsR0FBRyxJQUFJLENBQUM7UUFJNUIsb0JBQWUsR0FBVSxFQUFFLENBQUM7UUFDNUIsMEJBQXFCLEdBQUcsSUFBSSxDQUFDLGlCQUFpQixDQUFDO1FBRS9DLG9CQUFvQjtRQUNwQix5QkFBeUI7UUFDekIsaUJBQVksR0FBRyxL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Q0wsSUFBSSxDQUFDLGVBQWUsR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1NBQy9DO0lBQ0gsQ0FBQzsrR0F4WVUscUJBQXFCO21HQUFyQixxQkFBcUIsOFBBTnJCLENBQUM7Z0JBQ1YsT0FBTyxFQUFFLGlCQUFpQjtnQkFDMUIsS0FBSyxFQUFFLElBQUk7Z0JBQ1gsV0FBVyxFQUFFLHFCQUFxQjthQUNuQyxDQUFDLDZPQ2ZKLDBqSEFxREE7OzRGRHBDYSxxQkFBcUI7a0JBVmpDLFNBQVM7K0JBQ0UsaUJBQWlCLGFBR2hCLENBQUM7NEJBQ1YsT0FBTyxFQUFFLGlCQUFpQjs0QkFDMUIsS0FBSyxFQUFFLElBQUk7NEJBQ1gsV0FBVyx1QkFBdUI7eUJBQ25DLENBQUM7OzBCQU1XLFFBQVE7OzBCQUFJLElBQUk7OzBCQUFJLFFBQVE7NEVBTWhDLE9BQU87c0JBQWYsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csZ0JBQWdCO3NCQUF4QixLQUFLO2dCQUNHLFdBQVc7c0JBQW5CLEtBQUs7Z0JBaUJjLEtBQUs7c0JBQXhCLFNBQVM7dUJBQUMsT0FBTztnQkFDSSxjQUFjO3NCQUFuQyxTQUFTO3VCQUFDLFNBQVM7Z0JBUVgsY0FBYztzQkFBdEIsS0FBSztnQkFDRyxlQUFlO3NCQUF2QixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0b3JSZWYsIENvbXBvbmVudCwgSG9zdCwgSW5wdXQsIE9uSW5pdCwgT3B0aW9uYWwsIFNraXBTZWxmLCBWaWV3Q2hpbGQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29udHJvbENvbnRhaW5lciwgQ29udHJvbFZhbHVlQWNjZXNzb3IsIE5HX1ZBTFVFX0FDQ0VTU09SLCBVbnR5cGVkRm9ybUNvbnRyb2wgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IGRlYm91bmNlVGltZSB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcclxuaW1wb3J0IHsgVWlCYXNlQ29tcG9uZW50IH0gZnJvbSAnLi4vbGF5b3V0cy9iYXNlL3VpLWJhc2UuY29tcG9uZW50JztcclxuaW1wb3J0IHsgSW5wdXRDb21wb25lbnQgfSBmcm9tICcuLi9pbnB1dC9pbnB1dC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBDZGtPdmVybGF5T3JpZ2luIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICd1aS1hdXRvY29tcGxldGUnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9hdXRvY29tcGxldGUuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2F1dG9jb21wbGV0ZS5jb21wb25lbnQuc2NzcyddLFxyXG4gIHByb3ZpZGVyczogW3tcclxuICAgIHByb3ZpZGU6IE5HX1ZBTFVFX0FDQ0VTU09SLFxyXG4gICAgbXVsdGk6IHRydWUsXHJcbiAgICB1c2VFeGlzdGluZzogQXV0b2NvbXBsZXRlQ29tcG9uZW50XHJcbiAgfV1cclxufSlcclxuZXhwb3J0IGNsYXNzIEF1dG9jb21wbGV0ZUNvbXBvbmVudCBleHRlbmRzIFVpQmFzZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgQ29udHJvbFZhbHVlQWNjZXNzb3Ige1xyXG5cclxuICBwcml2YXRlIFNIT1dOX1VTRVJTX0RFTFRBID0gMTA7XHJcblxyXG4gIGNvbnN0cnVjdG9yKEBPcHRpb25hbCgpIEBIb3N0KCkgQFNraXBTZWxmKCkgcHJvdGVjdGVkIGNvbnRyb2xDb250YWluZXI6IENvbnRyb2xDb250YWluZXIsXHJcbiAgICAgICAgICAgICAgLy8gQE9wdGlvbmFsKCkgQFNlbGYoKSBwdWJsaWMgbmdDb250cm9sOiBOZ0NvbnRyb2wsXHJcbiAgICAgICAgICAgICAgcHJpdmF0ZSBjZHI6IENoYW5nZURldGVjdG9yUmVmKSB7XHJcbiAgICBzdXBlcigpO1xyXG4gIH1cclxuXHJcbiAgQElucHV0KCkgb3B0aW9ucz86IGFueVtdO1xyXG4gIEBJbnB1dCgpIG11bHRpcGxlID0gdHJ1ZTtcclxuICBASW5wdXQoKSBhbGxvd05ldyA9IGZhbHNlO1xyXG4gIEBJbnB1dCgpIGRpc3BsYXlBdHRyaWJ1dGUgPSAnbmFtZSc7XHJcbiAgQElucHV0KCkgaWRBdHRyaWJ1dGUgPSAnaWQnO1xyXG5cclxuICAvLyB2YWx1ZT86IGFueTtcclxuICBzZWFyY2hhYmxlT3B0aW9ucz86IGFueVtdO1xyXG4gIGZpbHRlcmVkT3B0aW9uczogYW55W10gPSBbXTtcclxuICBmaWx0ZXJlZE1heEl0ZW1zU2hvd24gPSB0aGlzLlNIT1dOX1VTRVJTX0RFTFRBO1xyXG5cclxuICAvLyBza2lwQmx1ciA9IGZhbHNlO1xyXG4gIC8vIHR5cGluZ1N0YXJ0ZWQgPSBmYWxzZTtcclxuICBtZXNzYWdlU2hvd24gPSBmYWxzZTtcclxuICBpbml0aWFsT3B0aW9uPzogYW55O1xyXG4gIHNlbGVjdGVkT3B0aW9uPzogYW55O1xyXG4gIGxhc3RFbWl0dGVkSWQ/OiBhbnk7XHJcbiAgZm9jdXNlZE9wdGlvbj86IGFueTtcclxuICBhbHJlYWR5QWRkZWQgPSBmYWxzZTtcclxuICBvcHRpb25zVmlzaWJsZSA9IGZhbHNlO1xyXG5cclxuICBAVmlld0NoaWxkKCdpbnB1dCcpIGlucHV0PzogSW5wdXRDb21wb25lbnQ7XHJcbiAgQFZpZXdDaGlsZCgndHJpZ2dlcicpIG9wdGlvbnNUcmlnZ2VyOiBDZGtPdmVybGF5T3JpZ2luO1xyXG5cclxuICBpbnB1dEZvY3VzZWQgPSBmYWxzZTtcclxuICBpbnB1dENvbnRyb2wgPSBuZXcgVW50eXBlZEZvcm1Db250cm9sKCcnKTtcclxuICBjaGVja2JveFNlbGVjdGlvbjogU2V0PGFueT4gPSBuZXcgU2V0PGFueT4oKTtcclxuXHJcbiAgb25DaGFuZ2U6ICh2YWx1ZSkgPT4gdm9pZDtcclxuXHJcbiAgQElucHV0KCkgb3B0aW9uRGlzYWJsZWQ6IChhbnkpID0+IGJvb2xlYW4gPSAoKSA9PiBmYWxzZTtcclxuICBASW5wdXQoKSBvcHRpb25Gb3JtYXR0ZXI6IChhbnkpID0+IHN0cmluZyA9IChvKSA9PiBvW3RoaXMuZGlzcGxheUF0dHJpYnV0ZV07XHJcblxyXG4gIHByb3RlY3RlZCBidWlsZFNlYXJjaGFibGVPcHRpb25zKCkge1xyXG4gICAgcmV0dXJuIHRoaXMub3B0aW9ucy5tYXAobyA9PiAoe1xyXG4gICAgICAuLi5vLFxyXG4gICAgICB1bnNlbGVjdGFibGU6IHRoaXMub3B0aW9uRGlzYWJsZWQobyksXHJcbiAgICAgIHNlYXJjaFN0cmluZzogYCR7dGhpcy5vcHRpb25Gb3JtYXR0ZXIobyl9YC50b0xvd2VyQ2FzZSgpXHJcbiAgICB9KSk7XHJcbiAgfVxyXG5cclxuICBwcm90ZWN0ZWQgZmlsdGVyT3B0aW9ucyh0ZXh0OiBzdHJpbmcpIHtcclxuICAgIHRoaXMuZmlsdGVyZWRNYXhJdGVtc1Nob3duID0gdGhpcy5TSE9XTl9VU0VSU19ERUxUQTtcclxuICAgIHJldHVybiB0aGlzLnNlYXJjaGFibGVPcHRpb25zLmZpbHRlcih1ID0+IHUuc2VhcmNoU3RyaW5nLmluY2x1ZGVzKHRleHQpKTtcclxuICB9XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG5cclxuICAgIC8vIGNvbnNvbGUubG9nKCduZ29uaW5pdCcpO1xyXG5cclxuICAgIHN1cGVyLm5nT25Jbml0KCk7XHJcblxyXG4gICAgLy8gaWYgKHRoaXMuZm9ybUNvbnRyb2xOYW1lICYmIHRoaXMuY29udHJvbENvbnRhaW5lci5jb250cm9sKSB7XHJcbiAgICAvLyAgIHRoaXMuY29udHJvbCA9IHRoaXMuY29udHJvbENvbnRhaW5lci5jb250cm9sLmdldCh0aGlzLmZvcm1Db250cm9sTmFtZSkgYXMgRm9ybUNvbnRyb2w7XHJcbiAgICAvLyB9XHJcbiAgICAvL1xyXG4gICAgLy8gdGhpcy51c2VyID0gdGhpcy5jb250cm9sLnZhbHVlO1xyXG5cclxuICAgIC8vIHRoaXMudmFsdWUgPSB0aGlzLmNvbnRyb2wudmFsdWU7XHJcblxyXG4gICAgdGhpcy5zZWFyY2hhYmxlT3B0aW9ucyA9IHRoaXMuYnVpbGRTZWFyY2hhYmxlT3B0aW9ucygpO1xyXG5cclxuICAgIC8vIGlmICh0aGlzLmNvbnRyb2wuZGlzYWJsZWQpIHtcclxuICAgIC8vICAgdGhpcy5pbnB1dENvbnRyb2wuZGlzYWJsZSgpO1xyXG4gICAgLy8gfVxyXG5cclxuICAgIC8vIHRoaXMuY29udHJvbC5zdGF0dXNDaGFuZ2VzLnN1YnNjcmliZSh2ID0+IHtcclxuICAgIC8vICAgaWYgKHYgPT09ICdESVNBQkxFRCcpIHtcclxuICAgIC8vICAgICB0aGlzLmlucHV0Q29udHJvbC5kaXNhYmxlKCk7XHJcbiAgICAvLyAgIH1cclxuICAgIC8vICAgaWYgKHYgPT09ICdWQUxJRCcpIHtcclxuICAgIC8vICAgICB0aGlzLmlucHV0Q29udHJvbC5lbmFibGUoKTtcclxuICAgIC8vICAgfVxyXG4gICAgLy8gfSk7XHJcblxyXG5cclxuXHJcbiAgICB0aGlzLmlucHV0Q29udHJvbC52YWx1ZUNoYW5nZXMucGlwZShkZWJvdW5jZVRpbWUoMjAwKSkuc3Vic2NyaWJlKHYgPT4ge1xyXG4gICAgICBjb25zdCBsY3YgPSB2LnRvTG93ZXJDYXNlKCk7XHJcblxyXG4gICAgICB0aGlzLmZpbHRlcmVkT3B0aW9ucyA9IHRoaXMuZmlsdGVyT3B0aW9ucyhsY3YpO1xyXG5cclxuICAgICAgaWYgKHRoaXMuZmlsdGVyZWRPcHRpb25zLmxlbmd0aCA+IDApIHtcclxuICAgICAgICB0aGlzLmZvY3VzZWRPcHRpb24gPSB0aGlzLmZpbHRlcmVkT3B0aW9uc1swXTtcclxuICAgICAgfSBlbHNlIHtcclxuICAgICAgICB0aGlzLmZvY3VzZWRPcHRpb24gPSB1bmRlZmluZWQ7XHJcbiAgICAgIH1cclxuXHJcbiAgICAgIGlmICh2ID09PSAnJykge1xyXG4gICAgICAgIHRoaXMuZm9jdXNlZE9wdGlvbiA9IHVuZGVmaW5lZDtcclxuICAgICAgICB0aGlzLnNlbGVjdGVkT3B0aW9uID0gdW5kZWZpbmVkO1xyXG4gICAgICB9XHJcblxyXG4gICAgICAvLyBpZiAodiAhPT0gJycpIHtcclxuICAgICAgLy8gICBpZiAodGhpcy5uZXdVc2VybmFtZSA9PT0gdikge1xyXG4gICAgICAvLyAgICAgdGhpcy5zZWxlY3RlZFVzZXIgPSB7aWQ6IG51bGwsIGZ1bGxOYW1lOiB2fTtcclxuICAgICAgLy8gICAgIHRoaXMuaW5pdGlhbFVzZXIgPSB0aGlzLnNlbGVjdGVkVXNlcjtcclxuICAgICAgLy8gICB9IGVsc2Uge1xyXG4gICAgICAvLyAgICAgaWYgKHRoaXMuZmlsdGVyZWRHcm91cHNBbmRVc2Vycy5sZW5ndGggPiAwKSB7XHJcbiAgICAgIC8vICAgICAgIHRoaXMuZm9jdXNlZEdyb3VwID0gdGhpcy5maWx0ZXJlZEdyb3Vwc0FuZFVzZXJzWzBdO1xyXG4gICAgICAvLyAgICAgICB0aGlzLmZvY3VzZWRVc2VyID0gdGhpcy5mb2N1c2VkR3JvdXAuZmlsdGVyZWRVc2Vyc1swXTtcclxuICAgICAgLy8gICAgIH0gZWxzZSB7XHJcbiAgICAgIC8vICAgICAgIHRoaXMuZm9jdXNlZEdyb3VwID0gbnVsbDtcclxuICAgICAgLy8gICAgICAgdGhpcy5mb2N1c2VkVXNlciA9IG51bGw7XHJcbiAgICAgIC8vICAgICB9XHJcbiAgICAgIC8vICAgICBpZiAoKHRoaXMuZm9jdXNlZFVzZXIgJiYgIXRoaXMuZm9jdXNlZFVzZXIudW5zZWxlY3RhYmxlKSB8fCB0aGlzLmZvY3VzZWRVc2VyID09PSB0aGlzLmluaXRpYWxVc2VyKSB7XHJcbiAgICAgIC8vICAgICAgIHRoaXMuc2VsZWN0ZWRVc2VyID0gdGhpcy5mb2N1c2VkVXNlcjtcclxuICAgICAgLy8gICAgIH0gZWxzZSB7XHJcbiAgICAgIC8vICAgICAgIHRoaXMuc2VsZWN0ZWRVc2VyID0gbnVsbDtcclxuICAgICAgLy8gICAgIH1cclxuICAgICAgLy8gICB9XHJcbiAgICAgIC8vIH0gZWxzZSB7XHJcbiAgICAgIC8vICAgdGhpcy5zZWxlY3RlZFVzZXIgPSBudWxsO1xyXG4gICAgICAvLyAgIHRoaXMuZm9jdXNlZFVzZXIgPSBudWxsO1xyXG4gICAgICAvLyAgIHRoaXMuZm9jdXNlZEdyb3VwID0gbnVsbDtcclxuICAgICAgLy8gfVxyXG5cclxuICAgICAgLy8gdGhpcy5vbkNoYW5nZSh2KTtcclxuICAgIH0pO1xyXG5cclxuICAgIC8vICAgaWYgKHRoaXMudXNlciAhPT0gbnVsbCkge1xyXG4gICAgLy8gICAgIGxldCBzZWxlY3RlZFVzZXIgPSBudWxsO1xyXG4gICAgLy8gICAgIHRoaXMuZ3JvdXBzQW5kVXNlcnMuZmluZChnID0+IGcudXNlcnMuZmluZCh1ID0+IHtcclxuICAgIC8vICAgICAgIGlmICh1LmlkID09PSB0aGlzLnVzZXIuaWQpIHtcclxuICAgIC8vICAgICAgICAgc2VsZWN0ZWRVc2VyID0gdTtcclxuICAgIC8vICAgICAgICAgcmV0dXJuIHRydWU7XHJcbiAgICAvLyAgICAgICB9IGVsc2Uge1xyXG4gICAgLy8gICAgICAgICByZXR1cm4gZmFsc2U7XHJcbiAgICAvLyAgICAgICB9XHJcbiAgICAvLyAgICAgfSkpO1xyXG4gICAgLy9cclxuICAgIC8vICAgICBpZiAoc2VsZWN0ZWRVc2VyKSB7XHJcbiAgICAvLyAgICAgICB0aGlzLmlucHV0Q29udHJvbC5zZXRWYWx1ZShzZWxlY3RlZFVzZXIuZnVsbE5hbWUpO1xyXG4gICAgLy8gICAgICAgdGhpcy5zZWxlY3RlZFVzZXIgPSBzZWxlY3RlZFVzZXI7XHJcbiAgICAvLyAgICAgfSBlbHNlIHtcclxuICAgIC8vICAgICAgIHRoaXMubmV3VXNlcm5hbWUgPSB0aGlzLnVzZXIuZnVsbE5hbWU7XHJcbiAgICAvLyAgICAgICB0aGlzLmlucHV0Q29udHJvbC5zZXRWYWx1ZSh0aGlzLnVzZXIuZnVsbE5hbWUpO1xyXG4gICAgLy8gICAgICAgdGhpcy5zZWxlY3RlZFVzZXIgPSB7IGlkOiBudWxsLCBmdWxsTmFtZTogdGhpcy5uZXdVc2VybmFtZSB9O1xyXG4gICAgLy8gICAgIH1cclxuICAgIC8vICAgfSBlbHNlIHtcclxuICAgIC8vICAgICB0aGlzLnNlbGVjdGVkVXNlciA9IG51bGw7XHJcbiAgICAvLyAgICAgdGhpcy5pbnB1dENvbnRyb2wuc2V0VmFsdWUoJycpO1xyXG4gICAgLy8gICB9XHJcbiAgICAvLyAgIHRoaXMuaW5pdGlhbFVzZXIgPSB0aGlzLnNlbGVjdGVkVXNlcjtcclxuICAgIC8vIH1cclxuICB9XHJcblxyXG4gIGlucHV0Rm9jdXNDaGFuZ2VkKGZvY3VzZWQ6IGJvb2xlYW4pOiB2b2lkIHtcclxuICAgIGlmIChmb2N1c2VkKSB7XHJcbiAgICAgIHRoaXMub3B0aW9uc1Zpc2libGUgPSB0cnVlO1xyXG4gICAgfVxyXG4gIH1cclxuICAvLyAgIHNldFRpbWVvdXQoKCkgPT4ge1xyXG4gIC8vICAgICBpZiAoIWZvY3VzZWQgJiYgdGhpcy5za2lwQmx1cikge1xyXG4gIC8vICAgICAgIHRoaXMuc2tpcEJsdXIgPSBmYWxzZTtcclxuICAvLyAgICAgICByZXR1cm47XHJcbiAgLy8gICAgIH1cclxuICAvLyAgICAgaWYgKCF0aGlzLnR5cGluZ1N0YXJ0ZWQgJiYgZm9jdXNlZCkge1xyXG4gIC8vICAgICAgIHRoaXMuaW5wdXRDb250cm9sLnNldFZhbHVlKHRoaXMuaW5wdXRDb250cm9sLnZhbHVlKTtcclxuICAvLyAgICAgICB0aGlzLnR5cGluZ1N0YXJ0ZWQgPSB0cnVlO1xyXG4gIC8vICAgICB9XHJcbiAgLy8gICAgIGlmICghdGhpcy5tZXNzYWdlU2hvd24pIHtcclxuICAvLyAgICAgICB0aGlzLmlucHV0Rm9jdXNlZCA9IGZvY3VzZWQ7XHJcbiAgLy8gICAgICAgaWYgKCFmb2N1c2VkKSB7XHJcbiAgLy8gICAgICAgICB0aGlzLmVtaXRTZWxlY3Rpb24oJ2ZvY3VzIGxvc3QnKTtcclxuICAvLyAgICAgICB9XHJcbiAgLy8gICAgIH1cclxuICAvLyAgIH0sIDI1MCk7XHJcbiAgLy8gfVxyXG5cclxuICBnZXQgaGFzQ2hlY2tib3hTZWxlY3RlZCgpOiBib29sZWFuIHtcclxuICAgIHJldHVybiB0aGlzLmNoZWNrYm94U2VsZWN0aW9uLnNpemUgPiAwO1xyXG4gIH1cclxuXHJcbiAgb3B0aW9uQ2hlY2tlZCh1OiBhbnkpOiBib29sZWFuIHtcclxuICAgIHJldHVybiB0aGlzLmNoZWNrYm94U2VsZWN0aW9uLmhhcyh1W3RoaXMuaWRBdHRyaWJ1dGVdKTtcclxuICB9XHJcblxyXG4gIHNlbGVjdCh1OiBhbnkpOiB2b2lkIHtcclxuICAgIGlmICh0aGlzLmhhc0NoZWNrYm94U2VsZWN0ZWQgfHwgdS51bnNlbGVjdGFibGUpIHtcclxuICAgICAgcmV0dXJuO1xyXG4gICAgfVxyXG4gICAgaWYgKCF1LnVuc2VsZWN0YWJsZSkge1xyXG4gICAgICB0aGlzLnNlbGVjdGVkT3B0aW9uID0gdTtcclxuICAgICAgdGhpcy5pbml0aWFsT3B0aW9uID0gdTtcclxuICAgICAgdGhpcy50b2dnbGVEcm9wZG93bigpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgdG9nZ2xlT3B0aW9uQ2hlY2tib3hlZCh1OiBhbnkpOiB2b2lkIHtcclxuICAgIGlmICghdS51bnNlbGVjdGFibGUpIHtcclxuICAgICAgdGhpcy5jaGVja2JveFNlbGVjdGlvbi5oYXModVt0aGlzLmlkQXR0cmlidXRlXSkgP1xyXG4gICAgICAgIHRoaXMuY2hlY2tib3hTZWxlY3Rpb24uZGVsZXRlKHVbdGhpcy5pZEF0dHJpYnV0ZV0pIDogdGhpcy5jaGVja2JveFNlbGVjdGlvbi5hZGQodVt0aGlzLmlkQXR0cmlidXRlXSk7XHJcbiAgICB9XHJcbiAgICB0aGlzLmlucHV0Py5mb2N1cygpO1xyXG4gIH1cclxuXHJcblxyXG4gIC8vIGdldCBvcHRpb25zVmlzaWJsZSgpOiBib29sZWFuIHtcclxuICAvLyAgIHJldHVybiB0aGlzLmlucHV0Rm9jdXNlZCAmJiB0aGlzLnR5cGluZ1N0YXJ0ZWQ7XHJcbiAgLy8gfVxyXG5cclxuICBrZXlQcmVzc2VkKGtleUV2ZW50OiBLZXlib2FyZEV2ZW50KTogdm9pZCB7XHJcbiAgICB0aGlzLmxhc3RFbWl0dGVkSWQgPSAtMTtcclxuICAgIHRoaXMub3B0aW9uc1Zpc2libGUgPSB0cnVlO1xyXG4gICAgLy8gdGhpcy50eXBpbmdTdGFydGVkID0ga2V5RXZlbnQua2V5ICE9PSAnVGFiJyAmJiBrZXlFdmVudC5rZXkgIT09ICdFc2NhcGUnO1xyXG4gICAgaWYgKGtleUV2ZW50LmtleSA9PT0gJ0VzY2FwZScpIHtcclxuICAgICAga2V5RXZlbnQuc3RvcFByb3BhZ2F0aW9uKCk7XHJcbiAgICAgIGtleUV2ZW50LnByZXZlbnREZWZhdWx0KCk7XHJcbiAgICAgIHRoaXMub3B0aW9uc1Zpc2libGUgPSBmYWxzZTtcclxuICAgICAgcmV0dXJuO1xyXG4gICAgfVxyXG4gICAgaWYgKGtleUV2ZW50LmtleSA9PT0gJ0VudGVyJyAmJiB0aGlzLmhhc0NoZWNrYm94U2VsZWN0ZWQpIHtcclxuICAgICAgaWYgKHRoaXMuZm9jdXNlZE9wdGlvbiAmJiAhdGhpcy5mb2N1c2VkT3B0aW9uLnVuc2VsZWN0YWJsZSkge1xyXG4gICAgICAgIHRoaXMudG9nZ2xlT3B0aW9uQ2hlY2tib3hlZCh0aGlzLmZvY3VzZWRPcHRpb24pO1xyXG4gICAgICB9XHJcbiAgICAgIGtleUV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xyXG4gICAgICBrZXlFdmVudC5wcmV2ZW50RGVmYXVsdCgpO1xyXG4gICAgICByZXR1cm47XHJcbiAgICB9XHJcbiAgICAvLyBpZiAoa2V5RXZlbnQua2V5ID09PSAnRW50ZXInICYmIHRoaXMuZmlsdGVyZWRHcm91cHNBbmRVc2Vycy5sZW5ndGggPT09IDAgJiYgdGhpcy5mb2N1c2VkVXNlciA9PT0gbnVsbCAmJiAhdGhpcy5hbHJlYWR5QWRkZWQpIHtcclxuICAgIC8vICAgdGhpcy5uZXdVc2VyKCk7XHJcbiAgICAvLyAgIGtleUV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xyXG4gICAgLy8gICBrZXlFdmVudC5wcmV2ZW50RGVmYXVsdCgpO1xyXG4gICAgLy8gICByZXR1cm47XHJcbiAgICAvLyB9XHJcbiAgICBpZiAoa2V5RXZlbnQua2V5ID09PSAnRW50ZXInKSB7XHJcbiAgICAgIHRoaXMuc2VsZWN0ZWRPcHRpb24gPSB0aGlzLmZvY3VzZWRPcHRpb247XHJcbiAgICAgIGtleUV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xyXG4gICAgICBrZXlFdmVudC5wcmV2ZW50RGVmYXVsdCgpO1xyXG4gICAgICB0aGlzLnRvZ2dsZURyb3Bkb3duKCk7XHJcbiAgICAgIHJldHVybjtcclxuICAgIH1cclxuICAgIGlmICgoa2V5RXZlbnQua2V5ID09PSAnQXJyb3dEb3duJyB8fCBrZXlFdmVudC5rZXkgPT09ICdBcnJvd1VwJykgJiYgIXRoaXMuZm9jdXNlZE9wdGlvbikge1xyXG4gICAgICBpZiAodGhpcy5maWx0ZXJlZE9wdGlvbnMubGVuZ3RoID4gMCkge1xyXG4gICAgICAgIHRoaXMuZm9jdXNlZE9wdGlvbiA9IHRoaXMuZmlsdGVyZWRPcHRpb25zWzBdO1xyXG4gICAgICAgIC8vIGlmICghdGhpcy5mb2N1c2VkVXNlci51bnNlbGVjdGFibGUgfHwgdGhpcy5mb2N1c2VkVXNlciA9PT0gdGhpcy5pbml0aWFsVXNlcikge1xyXG4gICAgICAgIC8vICAgdGhpcy5zZWxlY3RlZFVzZXIgPSB0aGlzLmZvY3VzZWRVc2VyO1xyXG4gICAgICAgIC8vIH1cclxuICAgICAgICB0aGlzLnNlbGVjdGVkT3B0aW9uID0gdGhpcy5mb2N1c2VkT3B0aW9uO1xyXG4gICAgICAgIHJldHVybjtcclxuICAgICAgfVxyXG4gICAgfVxyXG4gICAgaWYgKGtleUV2ZW50LmtleSA9PT0gJ0Fycm93RG93bicgJiYgdGhpcy5mb2N1c2VkT3B0aW9uKSB7XHJcbiAgICAgIGNvbnN0IGlkeCA9IHRoaXMuZmlsdGVyZWRPcHRpb25zLmluZGV4T2YodGhpcy5mb2N1c2VkT3B0aW9uKTtcclxuICAgICAgaWYgKGlkeCA9PT0gdGhpcy5maWx0ZXJlZE1heEl0ZW1zU2hvd24gLSAxKSB7XHJcbiAgICAgICAgdGhpcy5maWx0ZXJlZE1heEl0ZW1zU2hvd24gKz0gdGhpcy5TSE9XTl9VU0VSU19ERUxUQTtcclxuICAgICAgfVxyXG4gICAgICBpZiAoaWR4IDwgdGhpcy5maWx0ZXJlZE9wdGlvbnMubGVuZ3RoIC0gMSkge1xyXG4gICAgICAgIHRoaXMuZm9jdXNlZE9wdGlvbiA9IHRoaXMuZmlsdGVyZWRPcHRpb25zW2lkeCArIDFdO1xyXG4gICAgICAgIHRoaXMuc2VsZWN0ZWRPcHRpb24gPSB0aGlzLmZvY3VzZWRPcHRpb247XHJcbiAgICAgIH1cclxuICAgIH1cclxuICAgIGlmIChrZXlFdmVudC5rZXkgPT09ICdBcnJvd1VwJyAmJiB0aGlzLmZvY3VzZWRPcHRpb24pIHtcclxuICAgICAgY29uc3QgaWR4ID0gdGhpcy5maWx0ZXJlZE9wdGlvbnMuaW5kZXhPZih0aGlzLmZvY3VzZWRPcHRpb24pO1xyXG4gICAgICBpZiAoaWR4ID4gMCkge1xyXG4gICAgICAgIHRoaXMuZm9jdXNlZE9wdGlvbiA9IHRoaXMuZmlsdGVyZWRPcHRpb25zW2lkeCAtIDFdO1xyXG4gICAgICAgIHRoaXMuc2VsZWN0ZWRPcHRpb24gPSB0aGlzLmZvY3VzZWRPcHRpb247XHJcbiAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICB0aGlzLmNkci5kZXRlY3RDaGFuZ2VzKCk7XHJcbiAgfVxyXG5cclxuICB0b2dnbGVEcm9wZG93bigpIHtcclxuICAgIHRoaXMub3B0aW9uc1Zpc2libGUgPSBmYWxzZTtcclxuICAgIHRoaXMuZW1pdFNlbGVjdGlvbigndG9nZ2xlJyk7XHJcbiAgfVxyXG5cclxuICBlbWl0U2VsZWN0aW9uKHNyYz86IHN0cmluZyk6IHZvaWQge1xyXG4gICAgdGhpcy5pbml0aWFsT3B0aW9uID0gdGhpcy5zZWxlY3RlZE9wdGlvbjtcclxuXHJcbiAgICBpZiAodGhpcy5zZWxlY3RlZE9wdGlvbikge1xyXG4gICAgICBjb25zdCBjaGVja0lkID0gdGhpcy5zZWxlY3RlZE9wdGlvbi5pZCA9PT0gbnVsbCA/IDAgOiB0aGlzLnNlbGVjdGVkT3B0aW9uLmlkO1xyXG4gICAgICBpZiAodGhpcy5sYXN0RW1pdHRlZElkICE9PSBjaGVja0lkKSB7XHJcbiAgICAgICAgdGhpcy5sYXN0RW1pdHRlZElkID0gY2hlY2tJZDtcclxuICAgICAgICB0aGlzLm9uQ2hhbmdlKHRoaXMub3B0aW9ucy5maW5kKG8gPT4gb1t0aGlzLmlkQXR0cmlidXRlXSA9PT0gdGhpcy5zZWxlY3RlZE9wdGlvblt0aGlzLmlkQXR0cmlidXRlXSkpO1xyXG4gICAgICAgIHRoaXMuaW5wdXRDb250cm9sLnNldFZhbHVlKHRoaXMuc2VsZWN0ZWRPcHRpb25bdGhpcy5kaXNwbGF5QXR0cmlidXRlXSk7XHJcbiAgICAgIH1cclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIC8vIHRoaXMuY29udHJvbC5zZXRWYWx1ZShudWxsKTtcclxuICAgICAgdGhpcy5vbkNoYW5nZShudWxsKTtcclxuICAgICAgdGhpcy5pbnB1dENvbnRyb2wuc2V0VmFsdWUoJycsIHtlbWl0RXZlbnQ6IGZhbHNlfSk7XHJcbiAgICB9XHJcblxyXG5cclxuXHJcbiAgICAvLyBpZiAodGhpcy5zZWxlY3RlZE9wdGlvbikge1xyXG4gICAgLy8gICBjb25zdCBjaGVja0lkID0gdGhpcy5zZWxlY3RlZFVzZXIuaWQgPT09IG51bGwgPyAwIDogdGhpcy5zZWxlY3RlZFVzZXIuaWQ7XHJcbiAgICAvLyAgIGlmICh0aGlzLmxhc3RFbWl0dGVkSWQgIT09IGNoZWNrSWQpIHtcclxuICAgIC8vICAgICB0aGlzLmlucHV0Q29udHJvbC5zZXRWYWx1ZSh0aGlzLnNlbGVjdGVkVXNlci5mdWxsTmFtZSwge2VtaXRFdmVudDogZmFsc2V9KTtcclxuICAgIC8vICAgICBpZiAodGhpcy5zZWxlY3RlZFVzZXIuaWQpIHtcclxuICAgIC8vICAgICAgIHRoaXMuZ3JvdXBzQW5kVXNlcnMuZmluZChnID0+IGcudXNlcnMuZmluZCh1ID0+IHtcclxuICAgIC8vICAgICAgICAgaWYgKHUuaWQgPT09IHRoaXMuc2VsZWN0ZWRVc2VyLmlkKSB7XHJcbiAgICAvLyAgICAgICAgICAgdGhpcy5jb250cm9sLnNldFZhbHVlKHUpO1xyXG4gICAgLy8gICAgICAgICAgIHJldHVybiB0cnVlO1xyXG4gICAgLy8gICAgICAgICB9IGVsc2Uge1xyXG4gICAgLy8gICAgICAgICAgIHJldHVybiBmYWxzZTtcclxuICAgIC8vICAgICAgICAgfVxyXG4gICAgLy8gICAgICAgfSkpO1xyXG4gICAgLy8gICAgIH0gZWxzZSB7XHJcbiAgICAvLyAgICAgICB0aGlzLmNvbnRyb2wuc2V0VmFsdWUodGhpcy5zZWxlY3RlZFVzZXIpO1xyXG4gICAgLy8gICAgIH1cclxuICAgIC8vICAgICB0aGlzLmxhc3RFbWl0dGVkSWQgPSBjaGVja0lkO1xyXG4gICAgLy8gICB9XHJcbiAgICAvLyB9IGVsc2Uge1xyXG4gICAgLy8gICBpZiAodGhpcy5sYXN0RW1pdHRlZElkICE9PSBudWxsIHx8IHRoaXMubGFzdEVtaXR0ZWRJZCA9PT0gLTEvKiB8fCB0aGlzLnNlbGVjdGVkVXNlcj8udW5zZWxlY3RhYmxlKi8pIHtcclxuICAgIC8vICAgICB0aGlzLmNvbnRyb2w/LnNldFZhbHVlKG51bGwpO1xyXG4gICAgLy8gICAgIHRoaXMuaW5wdXRDb250cm9sLnNldFZhbHVlKCcnLCB7ZW1pdEV2ZW50OiBmYWxzZX0pO1xyXG4gICAgLy8gICAgIHRoaXMubGFzdEVtaXR0ZWRJZCA9IG51bGw7XHJcbiAgICAvLyAgIH1cclxuICAgIC8vIH1cclxuICAgIC8vIHRoaXMudHlwaW5nU3RhcnRlZCA9IGZhbHNlO1xyXG4gIH1cclxuXHJcbiAgY2FuY2VsQ2hlY2tib3hTZWxlY3Rpb24oKTogdm9pZCB7XHJcbiAgICB0aGlzLmNoZWNrYm94U2VsZWN0aW9uLmNsZWFyKCk7XHJcbiAgICAvLyB0aGlzLnNraXBCbHVyID0gdHJ1ZTtcclxuICAgIC8vIHRoaXMuaW5wdXQ/LmZvY3VzKCk7XHJcbiAgfVxyXG5cclxuICB1c2VDaGVja2JveFNlbGVjdGlvbigpOiB2b2lkIHtcclxuICAgIC8vIHRoaXMubmV3VXNlcm5hbWUgPSAnJztcclxuICAgIC8vIGNvbnN0IHVzZXJzID0gW107XHJcbiAgICAvLyB0aGlzLmdyb3Vwc0FuZFVzZXJzLmZvckVhY2goZyA9PiBnLnVzZXJzLmZvckVhY2godSA9PiB7XHJcbiAgICAvLyAgIGlmICghdXNlcnMuaW5jbHVkZXModSkgJiYgdGhpcy5jaGVja2JveFNlbGVjdGlvbi5oYXModS5pZCkpIHtcclxuICAgIC8vICAgICB1c2Vycy5wdXNoKHUpO1xyXG4gICAgLy8gICB9XHJcbiAgICAvLyB9KSk7XHJcbiAgICBjb25zdCBvdXRwdXRPcHRpb25zID0gdGhpcy5vcHRpb25zLmZpbHRlcihvID0+IHRoaXMuY2hlY2tib3hTZWxlY3Rpb24uaGFzKG9bdGhpcy5pZEF0dHJpYnV0ZV0pICYmICF0aGlzLm9wdGlvbkRpc2FibGVkKG8pKTtcclxuICAgIGlmIChvdXRwdXRPcHRpb25zLmxlbmd0aCA+IDApIHtcclxuICAgICAgdGhpcy5zZWxlY3RlZE9wdGlvbiA9IG91dHB1dE9wdGlvbnNbMF07XHJcbiAgICAgIHRoaXMuaW5wdXRDb250cm9sLnNldFZhbHVlKHRoaXMuc2VsZWN0ZWRPcHRpb25bdGhpcy5kaXNwbGF5QXR0cmlidXRlXSwge2VtaXRFdmVudDogZmFsc2V9KTtcclxuICAgICAgdGhpcy5vbkNoYW5nZShvdXRwdXRPcHRpb25zKTtcclxuICAgICAgdGhpcy50b2dnbGVEcm9wZG93bigpO1xyXG4gICAgICAvLyB0aGlzLmNvbnRyb2w/LnNldFZhbHVlKG91dHB1dE9wdGlvbnMpO1xyXG4gICAgICAvLyB0aGlzLnR5cGluZ1N0YXJ0ZWQgPSBmYWxzZTtcclxuICAgICAgLy8gdGhpcy5za2lwQmx1ciA9IHRydWU7XHJcbiAgICB9XHJcbiAgICB0aGlzLmNoZWNrYm94U2VsZWN0aW9uLmNsZWFyKCk7XHJcbiAgfVxyXG5cclxuICBuZXdPcHRpb24oKSB7XHJcblxyXG4gIH1cclxuXHJcbiAgbG9hZE1vcmUodmlzaWJsZTogYm9vbGVhbikge1xyXG4gICAgaWYgKHZpc2libGUpIHtcclxuICAgICAgdGhpcy5maWx0ZXJlZE1heEl0ZW1zU2hvd24gKz0gdGhpcy5TSE9XTl9VU0VSU19ERUxUQTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIHB1YmxpYyBmb2N1cygpIHtcclxuICAgIHRoaXMuaW5wdXQ/LmZvY3VzKCk7XHJcbiAgfVxyXG5cclxuICByZWdpc3Rlck9uQ2hhbmdlKGZuOiBhbnkpOiB2b2lkIHtcclxuICAgIHRoaXMub25DaGFuZ2UgPSBmbjtcclxuICB9XHJcblxyXG4gIHJlZ2lzdGVyT25Ub3VjaGVkKGZuOiBhbnkpOiB2b2lkIHtcclxuICB9XHJcblxyXG4gIHNldERpc2FibGVkU3RhdGUoaXNEaXNhYmxlZDogYm9vbGVhbik6IHZvaWQge1xyXG4gICAgaXNEaXNhYmxlZCA/IHRoaXMuaW5wdXRDb250cm9sLmRpc2FibGUoKSA6IHRoaXMuaW5wdXRDb250cm9sLmVuYWJsZSgpO1xyXG4gIH1cclxuXHJcbiAgd3JpdGVWYWx1ZShvYmo6IGFueSk6IHZvaWQge1xyXG4gICAgaWYgKG9iaikge1xyXG4gICAgICBpZiAob2JqLmlkKSB7XHJcbiAgICAgICAgdGhpcy5maWx0ZXJlZE9wdGlvbnMgPSB0aGlzLnNlYXJjaGFibGVPcHRpb25zLmZpbHRlcihzbyA9PiBzby5pZCA9PT0gb2JqLmlkKTtcclxuICAgICAgfSBlbHNlIHtcclxuICAgICAgICB0aGlzLmZpbHRlcmVkT3B0aW9ucyA9IHRoaXMuZmlsdGVyT3B0aW9ucyhvYmpbdGhpcy5kaXNwbGF5QXR0cmlidXRlXS50b0xvd2VyQ2FzZSgpKTtcclxuICAgICAgfVxyXG4gICAgICBpZiAodGhpcy5maWx0ZXJlZE9wdGlvbnMubGVuZ3RoID09PSAxKSB7XHJcbiAgICAgICAgdGhpcy5zZWxlY3RlZE9wdGlvbiA9IHRoaXMuZmlsdGVyZWRPcHRpb25zWzBdO1xyXG4gICAgICAgIHRoaXMuZm9jdXNlZE9wdGlvbiA9IHRoaXMuZmlsdGVyZWRPcHRpb25zWzBdO1xyXG4gICAgICB9XHJcbiAgICAgIHRoaXMuaW5wdXRDb250cm9sLnNldFZhbHVlKG9ialt0aGlzLmRpc3BsYXlBdHRyaWJ1dGVdKTtcclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIHRoaXMuZmlsdGVyZWRPcHRpb25zID0gdGhpcy5maWx0ZXJPcHRpb25zKCcnKTtcclxuICAgIH1cclxuICB9XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cIndyYXBwZXJcIiAjd3JhcHBlcj5cclxuICA8ZGl2ICpuZ0lmPVwib3B0aW9uc1Zpc2libGVcIiAoY2xpY2spPVwidG9nZ2xlRHJvcGRvd24oKVwiIGNsYXNzPVwib3ZlcmxheVwiPjwvZGl2PlxyXG4gIDx1aS1pbnB1dCBbZm9ybUNvbnRyb2xdPVwiaW5wdXRDb250cm9sXCIgI2lucHV0ICN0cmlnZ2VyPVwiY2RrT3ZlcmxheU9yaWdpblwiIGNka092ZXJsYXlPcmlnaW4gKGZvY3VzQ2hhbmdlZCk9XCJpbnB1dEZvY3VzQ2hhbmdlZCgkZXZlbnQpXCIgKGtleVByZXNzZWQpPVwia2V5UHJlc3NlZCgkZXZlbnQpXCIgW3BsYWNlaG9sZGVyXT1cInBsYWNlaG9sZGVyXCIgW3VzZUlucHV0TWVzc2FnZXNdPVwiJ25ldmVyJ1wiPlxyXG4gICAgPGRpdiBzbG90PVwicHJlZml4XCI+PG5nLWNvbnRlbnQgc2VsZWN0PVwiW3Nsb3Q9YWNwcmVmaXhdXCI+PC9uZy1jb250ZW50PjwvZGl2PlxyXG4gIDwvdWktaW5wdXQ+XHJcblxyXG4gIDxuZy10ZW1wbGF0ZSBjZGtDb25uZWN0ZWRPdmVybGF5IFtjZGtDb25uZWN0ZWRPdmVybGF5T3JpZ2luXT1cInRyaWdnZXJcIiBbY2RrQ29ubmVjdGVkT3ZlcmxheU9wZW5dPVwib3B0aW9uc1Zpc2libGVcIj5cclxuICAgIDxkaXYgY2xhc3M9XCJvcHRpb25zLWJveFwiIHN0eWxlPVwiZGlzcGxheTogZmxleDsgZmxleC1kaXJlY3Rpb246IGNvbHVtblwiIFtuZ1N0eWxlXT1cInt3aWR0aDogd3JhcHBlci5vZmZzZXRXaWR0aCArICdweCd9XCI+XHJcbiAgICAgIDxkaXYgY2xhc3M9XCJvcHRpb25zXCIgI29wdGlvbnM+XHJcblxyXG4gICAgICAgIDxuZy1jb250YWluZXIgKm5nRm9yPVwibGV0IG9wdGlvbiBvZiBmaWx0ZXJlZE9wdGlvbnM7IGluZGV4IGFzIGlcIj5cclxuICAgICAgICAgIDxkaXYgKm5nSWY9XCJpIDwgZmlsdGVyZWRNYXhJdGVtc1Nob3duXCIgY2xhc3M9XCJvcHRpb24tY29udGFpbmVyXCIgW25nQ2xhc3NdPVwie3NlbGVjdGVkOiBmb2N1c2VkT3B0aW9uID09PSBvcHRpb259XCI+XHJcbiAgICAgICAgICAgIDxtYXQtY2hlY2tib3ggW2NoZWNrZWRdPVwib3B0aW9uQ2hlY2tlZChvcHRpb24pIHx8IG9wdGlvbi51bnNlbGVjdGFibGVcIiBbZGlzYWJsZWRdPVwib3B0aW9uLnVuc2VsZWN0YWJsZVwiIChjaGFuZ2UpPVwidG9nZ2xlT3B0aW9uQ2hlY2tib3hlZChvcHRpb24pXCI+XHJcbiAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cIm9wdGlvbi1jb250YWluZXItaW5uZXJcIiAoY2xpY2spPVwic2VsZWN0KG9wdGlvbilcIj5cclxuICAgICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJvcHRpb24tb3B0aW9uXCIgdWlGb3JjZVZpc2liaWxpdHkgW3Zpc2liaWxpdHlXaXRoaW5dPVwib3B0aW9uc1wiIFt2aXNpYmlsaXR5UGFkZGluZ109XCI0XCIgKm5nSWY9XCJmb2N1c2VkT3B0aW9uID09PSBvcHRpb25cIiBbbmdDbGFzc109XCJ7dW5zZWxlY3RhYmxlOiBvcHRpb24udW5zZWxlY3RhYmxlfVwiPlxyXG4gICAgICAgICAgICAgICAgICB7e29wdGlvbkZvcm1hdHRlcihvcHRpb24pfX1cclxuICAgICAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cIm9wdGlvbi1vcHRpb25cIiAqbmdJZj1cImZvY3VzZWRPcHRpb24gIT09IG9wdGlvblwiIFtuZ0NsYXNzXT1cInt1bnNlbGVjdGFibGU6IG9wdGlvbi51bnNlbGVjdGFibGV9XCI+XHJcbiAgICAgICAgICAgICAgICAgIHt7b3B0aW9uRm9ybWF0dGVyKG9wdGlvbil9fVxyXG4gICAgICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICAgICAgICA8bWF0LWljb24gKm5nSWY9XCIhaGFzQ2hlY2tib3hTZWxlY3RlZCAmJiAhb3B0aW9uLnVuc2VsZWN0YWJsZVwiPm5vcnRoX3dlc3Q8L21hdC1pY29uPlxyXG4gICAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgICA8L21hdC1jaGVja2JveD5cclxuICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgIDwvbmctY29udGFpbmVyPlxyXG5cclxuICAgICAgICA8ZGl2ICpuZ0lmPVwiZmlsdGVyZWRPcHRpb25zLmxlbmd0aCA+PSBmaWx0ZXJlZE1heEl0ZW1zU2hvd25cIiBjbGFzcz1cIm9wdGlvbi1jb250YWluZXJcIiB1aUZvcmNlVmlzaWJpbGl0eSBbdmlzaWJpbGl0eVdpdGhpbl09XCJvcHRpb25zXCIgW3Zpc2liaWxpdHlFbWl0Q2hhbmdlXT1cInRydWVcIiAodmlzaWJpbGl0eUNoYW5nZWQpPVwibG9hZE1vcmUoJGV2ZW50KVwiPlxyXG4gICAgICAgICAgJm5ic3A7XHJcbiAgICAgICAgPC9kaXY+XHJcblxyXG5cclxuICAgICAgICA8ZGl2ICpuZ0lmPVwiZmlsdGVyZWRPcHRpb25zLmxlbmd0aCA9PT0gMCAmJiAhZm9jdXNlZE9wdGlvblwiIGNsYXNzPVwibmV3LXVzZXJcIj5cclxuICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJhbHJlYWR5QWRkZWRcIj5cclxuICAgICAgICAgICAgPGRpdiBzdHlsZT1cInRleHQtYWxpZ246IGNlbnRlclwiPlXFvml2YXRlbCB7e2lucHV0Q29udHJvbC52YWx1ZX19IHXFviBqZSBtZXppIGRsdcW+bsOta3k8L2Rpdj5cclxuICAgICAgICAgIDwvbmctY29udGFpbmVyPlxyXG4gICAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cIiFhbHJlYWR5QWRkZWRcIj5cclxuICAgICAgICAgICAgPGRpdiBzdHlsZT1cInRleHQtYWxpZ246IGNlbnRlcjsgcGFkZGluZzogMWVtIDBcIj5Vxb5pdmF0ZWxlIDxzdHJvbmc+e3tpbnB1dENvbnRyb2wudmFsdWV9fTwvc3Ryb25nPiBuZXpuw6FtZTwvZGl2PlxyXG4gICAgICAgICAgICA8dWktYnV0dG9uICpuZ0lmPVwiYWxsb3dOZXdcIiBzdHlsZT1cIm1hcmdpbi10b3A6IDZweDtcIiBbc2l6ZV09XCInc21hbGwnXCIgW2xhYmVsXT1cIidQxZlpZGF0IGplaj8nXCIgKGNsaWNrKT1cIm5ld09wdGlvbigpXCI+PC91aS1idXR0b24+XHJcbiAgICAgICAgICA8L25nLWNvbnRhaW5lcj5cclxuICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8ZGl2ICpuZ0lmPVwiZmlsdGVyZWRPcHRpb25zLmxlbmd0aCA9PT0gMCAmJiBmb2N1c2VkT3B0aW9uXCIgY2xhc3M9XCJuZXctdXNlclwiPlxyXG4gICAgICAgICAgPGRpdiBzdHlsZT1cInRleHQtYWxpZ246IGNlbnRlclwiPk5lem7DoW3DvSB1xb5pdmF0ZWwge3tpbnB1dENvbnRyb2wudmFsdWV9fTwvZGl2PlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgICA8L2Rpdj5cclxuXHJcbiAgICAgIDxkaXYgKm5nSWY9XCJoYXNDaGVja2JveFNlbGVjdGVkICYmIGZpbHRlcmVkT3B0aW9ucy5sZW5ndGggPiAwXCIgY2xhc3M9XCJjaGVja2JveC1idXR0b25zXCI+XHJcbiAgICAgICAgPHVpLWJ1dHRvbiBbc2l6ZV09XCInc21hbGwnXCIgW2tpbmRdPVwiJ2Jhc2ljJ1wiIFtsYWJlbF09XCInWnJ1xaFpdCB2w71ixJtyJ1wiIChjbGljayk9XCJjYW5jZWxDaGVja2JveFNlbGVjdGlvbigpXCI+PC91aS1idXR0b24+XHJcbiAgICAgICAgPHVpLWJ1dHRvbiBbc2l6ZV09XCInc21hbGwnXCIgW2xhYmVsXT1cIidQb3XFvsOtdCB2w71ixJtyICgnICsgY2hlY2tib3hTZWxlY3Rpb24uc2l6ZSArICcpJ1wiIChjbGljayk9XCJ1c2VDaGVja2JveFNlbGVjdGlvbigpXCI+PC91aS1idXR0b24+XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgPC9kaXY+XHJcbiAgPC9uZy10ZW1wbGF0ZT5cclxuPC9kaXY+XHJcblxyXG4iXX0=
@@ -0,0 +1,34 @@
1
+ import { Component, HostBinding, Input } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@angular/common";
4
+ import * as i2 from "../file/file.component";
5
+ export class AvatarComponent {
6
+ get contrast() {
7
+ const hexCode = this.user.shortColour.substring(1, 7);
8
+ const hexR = parseInt(hexCode.substring(0, 2), 16);
9
+ const hexG = parseInt(hexCode.substring(2, 4), 16);
10
+ const hexB = parseInt(hexCode.substring(4, 6), 16);
11
+ const contrastRatio = hexR * 0.299 + hexG * 0.587 + hexB * 0.114;
12
+ return contrastRatio >= 200 ? 'black' : 'white';
13
+ }
14
+ constructor() {
15
+ this.user = {};
16
+ this.size = 'normal';
17
+ }
18
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: AvatarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
19
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.11", type: AvatarComponent, selector: "ui-avatar", inputs: { user: "user", srcOptions: "srcOptions", size: "size" }, host: { properties: { "class": "this.size" } }, ngImport: i0, template: "<ui-file *ngIf=\"user.avatar || (!user.avatar && !user.shortName)\" [fileSize]=\"'avatar-' + size\" [srcData]=\"user.avatar || { mimeType: 'image/png'}\" [srcOptions]=\"srcOptions\" ></ui-file>\r\n<div *ngIf=\"!user.avatar && user.shortName\" [ngStyle]=\"{backgroundColor: user.shortColour, color: contrast}\">\r\n {{ user.shortName }}\r\n</div>\r\n", styles: [":host{display:block;flex:0 0 auto}:host.mini{height:16px;width:16px}:host.mini div{font-size:10px}:host.small{height:24px;width:24px}:host.small div{font-size:13px}:host.smaller{height:50px;width:50px}:host.smaller div{font-size:1.5em}:host.normal{height:74px;width:74px}:host.normal div{font-size:37px}:host.bigger{height:100px;width:100px}:host.bigger div{font-size:50px}:host.big{height:150px;width:150px}:host.big div{font-size:75px}:host ui-file ::ng-deep img{border-radius:50%}:host div{display:flex;align-items:center;justify-content:center;width:100%;font-weight:700;color:#fff;background-size:cover;height:100%;border-radius:50%}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i2.FileComponent, selector: "ui-file", inputs: ["fileSize", "srcOptions", "srcData", "srcUrl"] }] }); }
20
+ }
21
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: AvatarComponent, decorators: [{
22
+ type: Component,
23
+ args: [{ selector: 'ui-avatar', template: "<ui-file *ngIf=\"user.avatar || (!user.avatar && !user.shortName)\" [fileSize]=\"'avatar-' + size\" [srcData]=\"user.avatar || { mimeType: 'image/png'}\" [srcOptions]=\"srcOptions\" ></ui-file>\r\n<div *ngIf=\"!user.avatar && user.shortName\" [ngStyle]=\"{backgroundColor: user.shortColour, color: contrast}\">\r\n {{ user.shortName }}\r\n</div>\r\n", styles: [":host{display:block;flex:0 0 auto}:host.mini{height:16px;width:16px}:host.mini div{font-size:10px}:host.small{height:24px;width:24px}:host.small div{font-size:13px}:host.smaller{height:50px;width:50px}:host.smaller div{font-size:1.5em}:host.normal{height:74px;width:74px}:host.normal div{font-size:37px}:host.bigger{height:100px;width:100px}:host.bigger div{font-size:50px}:host.big{height:150px;width:150px}:host.big div{font-size:75px}:host ui-file ::ng-deep img{border-radius:50%}:host div{display:flex;align-items:center;justify-content:center;width:100%;font-weight:700;color:#fff;background-size:cover;height:100%;border-radius:50%}\n"] }]
24
+ }], ctorParameters: function () { return []; }, propDecorators: { user: [{
25
+ type: Input
26
+ }], srcOptions: [{
27
+ type: Input
28
+ }], size: [{
29
+ type: HostBinding,
30
+ args: ['class']
31
+ }, {
32
+ type: Input
33
+ }] } });
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXZhdGFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL3NyYy9saWIvYXZhdGFyL2F2YXRhci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL2F2YXRhci9hdmF0YXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7O0FBTzlELE1BQU0sT0FBTyxlQUFlO0lBUzFCLElBQUksUUFBUTtRQUNWLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFFdEQsTUFBTSxJQUFJLEdBQUcsUUFBUSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQ25ELE1BQU0sSUFBSSxHQUFHLFFBQVEsQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUNuRCxNQUFNLElBQUksR0FBRyxRQUFRLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFDbkQsTUFBTSxhQUFhLEdBQUcsSUFBSSxHQUFHLEtBQUssR0FBRyxJQUFJLEdBQUcsS0FBSyxHQUFHLElBQUksR0FBRyxLQUFLLENBQUM7UUFFakUsT0FBTyxhQUFhLElBQUksR0FBRyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQztJQUNsRCxDQUFDO0lBRUQ7UUFsQlMsU0FBSSxHQUFxRSxFQUFFLENBQUM7UUFLNUUsU0FBSSxHQUErRCxRQUFRLENBQUM7SUFhckUsQ0FBQzsrR0FwQk4sZUFBZTttR0FBZixlQUFlLG1LQ1A1QixnV0FJQTs7NEZER2EsZUFBZTtrQkFMM0IsU0FBUzsrQkFDRSxXQUFXOzBFQU1aLElBQUk7c0JBQVosS0FBSztnQkFFRyxVQUFVO3NCQUFsQixLQUFLO2dCQUdHLElBQUk7c0JBRFosV0FBVzt1QkFBQyxPQUFPOztzQkFDbkIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3VpLWF2YXRhcicsXG4gIHRlbXBsYXRlVXJsOiAnLi9hdmF0YXIuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9hdmF0YXIuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBBdmF0YXJDb21wb25lbnQge1xuXG4gIEBJbnB1dCgpIHVzZXI6IFBhcnRpYWw8eyBhdmF0YXI6IGFueSwgc2hvcnROYW1lOiBzdHJpbmcsIHNob3J0Q29sb3VyOiBzdHJpbmcgfT4gPSB7fTtcblxuICBASW5wdXQoKSBzcmNPcHRpb25zO1xuXG4gIEBIb3N0QmluZGluZygnY2xhc3MnKVxuICBASW5wdXQoKSBzaXplOiAnYmlnJyB8ICdiaWdnZXInIHwgJ25vcm1hbCcgfCAnc21hbGxlcicgfCAnc21hbGwnIHwgJ21pbmknID0gJ25vcm1hbCc7XG5cbiAgZ2V0IGNvbnRyYXN0KCk6IHN0cmluZyB7XG4gICAgY29uc3QgaGV4Q29kZSA9IHRoaXMudXNlci5zaG9ydENvbG91ci5zdWJzdHJpbmcoMSwgNyk7XG5cbiAgICBjb25zdCBoZXhSID0gcGFyc2VJbnQoaGV4Q29kZS5zdWJzdHJpbmcoMCwgMiksIDE2KTtcbiAgICBjb25zdCBoZXhHID0gcGFyc2VJbnQoaGV4Q29kZS5zdWJzdHJpbmcoMiwgNCksIDE2KTtcbiAgICBjb25zdCBoZXhCID0gcGFyc2VJbnQoaGV4Q29kZS5zdWJzdHJpbmcoNCwgNiksIDE2KTtcbiAgICBjb25zdCBjb250cmFzdFJhdGlvID0gaGV4UiAqIDAuMjk5ICsgaGV4RyAqIDAuNTg3ICsgaGV4QiAqIDAuMTE0O1xuXG4gICAgcmV0dXJuIGNvbnRyYXN0UmF0aW8gPj0gMjAwID8gJ2JsYWNrJyA6ICd3aGl0ZSc7XG4gIH1cblxuICBjb25zdHJ1Y3RvcigpIHsgfVxuXG59XG4iLCI8dWktZmlsZSAqbmdJZj1cInVzZXIuYXZhdGFyIHx8ICghdXNlci5hdmF0YXIgJiYgIXVzZXIuc2hvcnROYW1lKVwiIFtmaWxlU2l6ZV09XCInYXZhdGFyLScgKyBzaXplXCIgW3NyY0RhdGFdPVwidXNlci5hdmF0YXIgfHwgeyBtaW1lVHlwZTogJ2ltYWdlL3BuZyd9XCIgW3NyY09wdGlvbnNdPVwic3JjT3B0aW9uc1wiID48L3VpLWZpbGU+XHJcbjxkaXYgKm5nSWY9XCIhdXNlci5hdmF0YXIgJiYgdXNlci5zaG9ydE5hbWVcIiBbbmdTdHlsZV09XCJ7YmFja2dyb3VuZENvbG9yOiB1c2VyLnNob3J0Q29sb3VyLCBjb2xvcjogY29udHJhc3R9XCI+XHJcbiAge3sgdXNlci5zaG9ydE5hbWUgfX1cclxuPC9kaXY+XHJcbiJdfQ==
@@ -0,0 +1,57 @@
1
+ import { Component, HostBinding, Input } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@angular/common";
4
+ import * as i2 from "@angular/material/icon";
5
+ import * as i3 from "@angular/material/progress-bar";
6
+ import * as i4 from "@angular/material/core";
7
+ export class ButtonComponent {
8
+ get class() {
9
+ return this.kind +
10
+ (this.color ? ' ' + this.color : '') +
11
+ (this.size ? ' ' + this.size : '') +
12
+ ((this.disabled || this.busy) ? ' disabled' : '');
13
+ }
14
+ constructor() {
15
+ this.type = 'button';
16
+ this.disabled = false;
17
+ this.busy = false;
18
+ this.kind = 'flat';
19
+ this.color = 'primary';
20
+ this.size = 'normal';
21
+ this.formInvalid = false;
22
+ }
23
+ get isDisabled() {
24
+ return this.disabled || this.busy;
25
+ }
26
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: ButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
27
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.11", type: ButtonComponent, selector: "ui-button", inputs: { type: "type", matIconPrefix: "matIconPrefix", label: "label", disabled: "disabled", busy: "busy", kind: "kind", color: "color", size: "size", formInvalid: "formInvalid" }, host: { properties: { "class": "this.class", "class.formInvalid": "this.formInvalid" } }, ngImport: i0, template: "<button matRipple [type]=\"type\" [disabled]=\"isDisabled || busy\" [ngClass]=\"{busy: busy}\" [class]=\"class\">\r\n <mat-icon *ngIf=\"matIconPrefix\">{{matIconPrefix}}</mat-icon>\r\n {{label}}\r\n <mat-progress-bar *ngIf=\"busy\" mode=\"indeterminate\" [color]=\"color\"></mat-progress-bar>\r\n</button>\r\n", styles: [":host{display:flex;align-items:center}:host button{font-size:1em;width:100%;cursor:pointer;outline:none;position:relative;display:flex;align-items:center;justify-content:center;border:1px solid transparent;transition:all .15s ease-in-out}:host button mat-progress-bar{position:absolute;bottom:1px;height:2px;border-bottom-left-radius:10px;border-bottom-right-radius:10px}:host button mat-icon{margin-right:4px;height:16px;width:16px;font-size:16px}:host.small button mat-icon{width:14px;height:14px;font-size:14px;margin-right:2px}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i3.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { kind: "directive", type: i4.MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }] }); }
28
+ }
29
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: ButtonComponent, decorators: [{
30
+ type: Component,
31
+ args: [{ selector: 'ui-button', template: "<button matRipple [type]=\"type\" [disabled]=\"isDisabled || busy\" [ngClass]=\"{busy: busy}\" [class]=\"class\">\r\n <mat-icon *ngIf=\"matIconPrefix\">{{matIconPrefix}}</mat-icon>\r\n {{label}}\r\n <mat-progress-bar *ngIf=\"busy\" mode=\"indeterminate\" [color]=\"color\"></mat-progress-bar>\r\n</button>\r\n", styles: [":host{display:flex;align-items:center}:host button{font-size:1em;width:100%;cursor:pointer;outline:none;position:relative;display:flex;align-items:center;justify-content:center;border:1px solid transparent;transition:all .15s ease-in-out}:host button mat-progress-bar{position:absolute;bottom:1px;height:2px;border-bottom-left-radius:10px;border-bottom-right-radius:10px}:host button mat-icon{margin-right:4px;height:16px;width:16px;font-size:16px}:host.small button mat-icon{width:14px;height:14px;font-size:14px;margin-right:2px}\n"] }]
32
+ }], ctorParameters: function () { return []; }, propDecorators: { type: [{
33
+ type: Input
34
+ }], matIconPrefix: [{
35
+ type: Input
36
+ }], label: [{
37
+ type: Input
38
+ }], disabled: [{
39
+ type: Input
40
+ }], busy: [{
41
+ type: Input
42
+ }], kind: [{
43
+ type: Input
44
+ }], color: [{
45
+ type: Input
46
+ }], size: [{
47
+ type: Input
48
+ }], class: [{
49
+ type: HostBinding,
50
+ args: ['class']
51
+ }], formInvalid: [{
52
+ type: HostBinding,
53
+ args: ['class.formInvalid']
54
+ }, {
55
+ type: Input
56
+ }] } });
57
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL3NyYy9saWIvYnV0dG9uL2J1dHRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL2J1dHRvbi9idXR0b24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7Ozs7QUFROUQsTUFBTSxPQUFPLGVBQWU7SUFXMUIsSUFDSSxLQUFLO1FBQ1AsT0FBTyxJQUFJLENBQUMsSUFBSTtZQUNkLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsR0FBRyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztZQUNwQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEdBQUcsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7WUFDbEMsQ0FBQyxDQUFDLElBQUksQ0FBQyxRQUFRLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQ3RELENBQUM7SUFLRDtRQXBCUyxTQUFJLEdBQXdCLFFBQVEsQ0FBQztRQUdyQyxhQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ2pCLFNBQUksR0FBRyxLQUFLLENBQUM7UUFDYixTQUFJLEdBQWlDLE1BQU0sQ0FBQztRQUM1QyxVQUFLLEdBQWlCLFNBQVMsQ0FBQztRQUNoQyxTQUFJLEdBQWdCLFFBQVEsQ0FBQztRQVc3QixnQkFBVyxHQUFHLEtBQUssQ0FBQztJQUViLENBQUM7SUFFakIsSUFBSSxVQUFVO1FBQ1osT0FBTyxJQUFJLENBQUMsUUFBUSxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUM7SUFDcEMsQ0FBQzsrR0ExQlUsZUFBZTttR0FBZixlQUFlLGlVQ1I1QiwwVEFLQTs7NEZER2EsZUFBZTtrQkFMM0IsU0FBUzsrQkFDRSxXQUFXOzBFQU1aLElBQUk7c0JBQVosS0FBSztnQkFDRyxhQUFhO3NCQUFyQixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSztnQkFDRyxJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSztnQkFHRixLQUFLO3NCQURSLFdBQVc7dUJBQUMsT0FBTztnQkFTWCxXQUFXO3NCQURuQixXQUFXO3VCQUFDLG1CQUFtQjs7c0JBQy9CLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEhvc3RCaW5kaW5nLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb250cm9sQ29sb3IsIENvbnRyb2xTaXplIH0gZnJvbSAnLi4vdWkubW9kZWwnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICd1aS1idXR0b24nLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9idXR0b24uY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2J1dHRvbi5jb21wb25lbnQuc2NzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBCdXR0b25Db21wb25lbnQge1xyXG5cclxuICBASW5wdXQoKSB0eXBlOiAnc3VibWl0JyB8ICdidXR0b24nID0gJ2J1dHRvbic7XHJcbiAgQElucHV0KCkgbWF0SWNvblByZWZpeDogYW55O1xyXG4gIEBJbnB1dCgpIGxhYmVsOiBzdHJpbmcgfCB1bmRlZmluZWQ7XHJcbiAgQElucHV0KCkgZGlzYWJsZWQgPSBmYWxzZTtcclxuICBASW5wdXQoKSBidXN5ID0gZmFsc2U7XHJcbiAgQElucHV0KCkga2luZDogJ2Jhc2ljJyB8ICdmbGF0JyB8ICdzdHJva2VkJyA9ICdmbGF0JztcclxuICBASW5wdXQoKSBjb2xvcjogQ29udHJvbENvbG9yID0gJ3ByaW1hcnknO1xyXG4gIEBJbnB1dCgpIHNpemU6IENvbnRyb2xTaXplID0gJ25vcm1hbCc7XHJcblxyXG4gIEBIb3N0QmluZGluZygnY2xhc3MnKVxyXG4gIGdldCBjbGFzcygpOiBzdHJpbmcge1xyXG4gICAgcmV0dXJuIHRoaXMua2luZCArXHJcbiAgICAgICh0aGlzLmNvbG9yID8gJyAnICsgdGhpcy5jb2xvciA6ICcnKSArXHJcbiAgICAgICh0aGlzLnNpemUgPyAnICcgKyB0aGlzLnNpemUgOiAnJykgK1xyXG4gICAgICAoKHRoaXMuZGlzYWJsZWQgfHwgdGhpcy5idXN5KSA/ICcgZGlzYWJsZWQnIDogJycpO1xyXG4gIH1cclxuXHJcbiAgQEhvc3RCaW5kaW5nKCdjbGFzcy5mb3JtSW52YWxpZCcpXHJcbiAgQElucHV0KCkgZm9ybUludmFsaWQgPSBmYWxzZTtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcbiAgZ2V0IGlzRGlzYWJsZWQoKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gdGhpcy5kaXNhYmxlZCB8fCB0aGlzLmJ1c3k7XHJcbiAgfVxyXG5cclxufVxyXG4iLCI8YnV0dG9uIG1hdFJpcHBsZSBbdHlwZV09XCJ0eXBlXCIgW2Rpc2FibGVkXT1cImlzRGlzYWJsZWQgfHwgYnVzeVwiIFtuZ0NsYXNzXT1cIntidXN5OiBidXN5fVwiIFtjbGFzc109XCJjbGFzc1wiPlxyXG4gIDxtYXQtaWNvbiAqbmdJZj1cIm1hdEljb25QcmVmaXhcIj57e21hdEljb25QcmVmaXh9fTwvbWF0LWljb24+XHJcbiAge3tsYWJlbH19XHJcbiAgPG1hdC1wcm9ncmVzcy1iYXIgKm5nSWY9XCJidXN5XCIgbW9kZT1cImluZGV0ZXJtaW5hdGVcIiBbY29sb3JdPVwiY29sb3JcIj48L21hdC1wcm9ncmVzcy1iYXI+XHJcbjwvYnV0dG9uPlxyXG4iXX0=