tnx-shared 5.3.242 → 5.3.243

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.
@@ -0,0 +1,708 @@
1
+ import { animate, style, transition, trigger } from '@angular/animations';
2
+ import { CommonModule } from '@angular/common';
3
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChildren, ElementRef, EventEmitter, Input, IterableDiffers, NgModule, Output, QueryList, Renderer2, ViewChild, ViewEncapsulation, forwardRef } from '@angular/core';
4
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
5
+ import { PrimeTemplate, SharedModule } from 'tn-custom-primeng/api';
6
+ import { ButtonModule } from 'tn-custom-primeng/button';
7
+ import { ConnectedOverlayScrollHandler, DomHandler } from 'tn-custom-primeng/dom';
8
+ import { InputTextModule } from 'tn-custom-primeng/inputtext';
9
+ import { RippleModule } from 'tn-custom-primeng/ripple';
10
+ import { ObjectUtils, UniqueComponentId } from 'tn-custom-primeng/utils';
11
+ export const AUTOCOMPLETE_VALUE_ACCESSOR = {
12
+ provide: NG_VALUE_ACCESSOR,
13
+ useExisting: forwardRef(() => AutoComplete),
14
+ multi: true
15
+ };
16
+ export class AutoComplete {
17
+ constructor(el, renderer, cd, differs) {
18
+ this.el = el;
19
+ this.renderer = renderer;
20
+ this.cd = cd;
21
+ this.differs = differs;
22
+ this.minLength = 1;
23
+ this.delay = 300;
24
+ this.type = 'text';
25
+ this.autoZIndex = true;
26
+ this.baseZIndex = 0;
27
+ this.dropdownIcon = "pi pi-chevron-down";
28
+ this.unique = true;
29
+ this.completeOnFocus = false;
30
+ this.completeMethod = new EventEmitter();
31
+ this.onSelect = new EventEmitter();
32
+ this.onUnselect = new EventEmitter();
33
+ this.onFocus = new EventEmitter();
34
+ this.onBlur = new EventEmitter();
35
+ this.onDropdownClick = new EventEmitter();
36
+ this.onClear = new EventEmitter();
37
+ this.onKeyUp = new EventEmitter();
38
+ this.onShow = new EventEmitter();
39
+ this.onHide = new EventEmitter();
40
+ this.scrollHeight = '200px';
41
+ this.dropdownMode = 'blank';
42
+ this.showTransitionOptions = '.12s cubic-bezier(0, 0, 0.2, 1)';
43
+ this.hideTransitionOptions = '.1s linear';
44
+ this.autocomplete = 'off';
45
+ this.onModelChange = () => { };
46
+ this.onModelTouched = () => { };
47
+ this.showCountItem = false;
48
+ this.overlayVisible = false;
49
+ this.focus = false;
50
+ this.inputFieldValue = null;
51
+ this.differ = differs.find([]).create(null);
52
+ this.listId = UniqueComponentId() + '_list';
53
+ }
54
+ set maxRowItem(value) {
55
+ const rowHeight = 27;
56
+ const padding = 7;
57
+ this._maxHeighContainerItem = Math.round(value * 30.5) + 7;
58
+ this._maxHeighContainerItemStr = this._maxHeighContainerItem.toString() + 'px';
59
+ }
60
+ get suggestions() {
61
+ return this._suggestions;
62
+ }
63
+ set suggestions(val) {
64
+ this._suggestions = val;
65
+ this.handleSuggestionsChange();
66
+ }
67
+ ngAfterViewChecked() {
68
+ //Use timeouts as since Angular 4.2, AfterViewChecked is broken and not called after panel is updated
69
+ if (this.suggestionsUpdated && this.overlay && this.overlay.offsetParent) {
70
+ setTimeout(() => {
71
+ if (this.overlay) {
72
+ this.alignOverlay();
73
+ }
74
+ }, 1);
75
+ this.suggestionsUpdated = false;
76
+ }
77
+ if (this.highlightOptionChanged) {
78
+ setTimeout(() => {
79
+ if (this.overlay) {
80
+ let listItem = DomHandler.findSingle(this.overlay, 'li.p-highlight');
81
+ if (listItem) {
82
+ DomHandler.scrollInView(this.overlay, listItem);
83
+ }
84
+ }
85
+ }, 1);
86
+ this.highlightOptionChanged = false;
87
+ }
88
+ if (this.multiContainerEL) {
89
+ var lastItemSelected = DomHandler.findSingle(this.multiContainerEL.nativeElement, 'li:first-child');
90
+ this.multiContainerEL.nativeElement.scrollTop = 10000;
91
+ let rectParent = this.multiContainerEL.nativeElement.getBoundingClientRect();
92
+ let rectLastItem = lastItemSelected.getBoundingClientRect();
93
+ if (rectLastItem.y < rectParent.y) {
94
+ this.showCountItem = true;
95
+ }
96
+ else {
97
+ this.showCountItem = false;
98
+ }
99
+ }
100
+ const countItem = DomHandler.findSingle(this.multiContainerEL.nativeElement, '.p-autocomplete-countItem');
101
+ if (this.showCountItem && !countItem) {
102
+ this.focusInput();
103
+ }
104
+ }
105
+ handleSuggestionsChange() {
106
+ if (this._suggestions != null && this.loading) {
107
+ this.highlightOption = null;
108
+ if (this._suggestions.length) {
109
+ this.noResults = false;
110
+ this.show();
111
+ this.suggestionsUpdated = true;
112
+ if (this.autoHighlight) {
113
+ this.highlightOption = this._suggestions[0];
114
+ }
115
+ }
116
+ else {
117
+ this.noResults = true;
118
+ if (this.emptyMessage) {
119
+ this.show();
120
+ this.suggestionsUpdated = true;
121
+ }
122
+ else {
123
+ this.hide();
124
+ }
125
+ }
126
+ this.loading = false;
127
+ }
128
+ }
129
+ ngAfterContentInit() {
130
+ this.templates.forEach((item) => {
131
+ switch (item.getType()) {
132
+ case 'item':
133
+ this.itemTemplate = item.template;
134
+ break;
135
+ case 'selectedItem':
136
+ this.selectedItemTemplate = item.template;
137
+ break;
138
+ default:
139
+ this.itemTemplate = item.template;
140
+ break;
141
+ }
142
+ });
143
+ }
144
+ writeValue(value) {
145
+ this.value = value;
146
+ this.filled = this.value && this.value != '';
147
+ this.updateInputField();
148
+ this.cd.markForCheck();
149
+ }
150
+ registerOnChange(fn) {
151
+ this.onModelChange = fn;
152
+ }
153
+ registerOnTouched(fn) {
154
+ this.onModelTouched = fn;
155
+ }
156
+ setDisabledState(val) {
157
+ this.disabled = val;
158
+ this.cd.markForCheck();
159
+ }
160
+ onInput(event) {
161
+ // When an input element with a placeholder is clicked, the onInput event is invoked in IE.
162
+ if (!this.inputKeyDown && DomHandler.isIE()) {
163
+ return;
164
+ }
165
+ if (this.timeout) {
166
+ clearTimeout(this.timeout);
167
+ }
168
+ let value = event.target.value;
169
+ if (!this.multiple && !this.forceSelection) {
170
+ this.onModelChange(value);
171
+ }
172
+ if (value.length === 0 && !this.multiple) {
173
+ this.hide();
174
+ this.onClear.emit(event);
175
+ this.onModelChange(value);
176
+ }
177
+ if (value.length >= this.minLength) {
178
+ this.timeout = setTimeout(() => {
179
+ this.search(event, value);
180
+ }, this.delay);
181
+ }
182
+ else {
183
+ this.suggestions = null;
184
+ this.hide();
185
+ }
186
+ this.updateFilledState();
187
+ this.inputKeyDown = false;
188
+ }
189
+ onInputClick(event) {
190
+ if (this.documentClickListener) {
191
+ this.inputClick = true;
192
+ }
193
+ }
194
+ search(event, query) {
195
+ //allow empty string but not undefined or null
196
+ if (query === undefined || query === null) {
197
+ return;
198
+ }
199
+ this.loading = true;
200
+ this.completeMethod.emit({
201
+ originalEvent: event,
202
+ query: query
203
+ });
204
+ }
205
+ selectItem(option, focus = true) {
206
+ if (this.forceSelectionUpdateModelTimeout) {
207
+ clearTimeout(this.forceSelectionUpdateModelTimeout);
208
+ this.forceSelectionUpdateModelTimeout = null;
209
+ }
210
+ if (this.multiple) {
211
+ this.multiInputEL.nativeElement.value = '';
212
+ this.value = this.value || [];
213
+ if (!this.isSelected(option) || !this.unique) {
214
+ this.value = [...this.value, option];
215
+ this.onModelChange(this.value);
216
+ }
217
+ }
218
+ else {
219
+ this.inputEL.nativeElement.value = this.field ? ObjectUtils.resolveFieldData(option, this.field) || '' : option;
220
+ this.value = option;
221
+ this.onModelChange(this.value);
222
+ }
223
+ this.onSelect.emit(option);
224
+ this.updateFilledState();
225
+ if (focus) {
226
+ this.itemClicked = true;
227
+ this.focusInput();
228
+ }
229
+ }
230
+ show() {
231
+ if (this.multiInputEL || this.inputEL) {
232
+ let hasFocus = this.multiple ?
233
+ this.multiInputEL.nativeElement.ownerDocument.activeElement == this.multiInputEL.nativeElement :
234
+ this.inputEL.nativeElement.ownerDocument.activeElement == this.inputEL.nativeElement;
235
+ if (!this.overlayVisible && hasFocus) {
236
+ this.overlayVisible = true;
237
+ }
238
+ }
239
+ }
240
+ onOverlayAnimationStart(event) {
241
+ switch (event.toState) {
242
+ case 'visible':
243
+ this.overlay = event.element;
244
+ this.appendOverlay();
245
+ if (this.autoZIndex) {
246
+ this.overlay.style.zIndex = String(this.baseZIndex + (++DomHandler.zindex));
247
+ }
248
+ this.alignOverlay();
249
+ this.bindDocumentClickListener();
250
+ this.bindDocumentResizeListener();
251
+ this.bindScrollListener();
252
+ this.onShow.emit(event);
253
+ break;
254
+ case 'void':
255
+ this.onOverlayHide();
256
+ break;
257
+ }
258
+ }
259
+ onOverlayAnimationDone(event) {
260
+ if (event.toState === 'void') {
261
+ this._suggestions = null;
262
+ }
263
+ }
264
+ appendOverlay() {
265
+ if (this.appendTo) {
266
+ if (this.appendTo === 'body')
267
+ document.body.appendChild(this.overlay);
268
+ else
269
+ DomHandler.appendChild(this.overlay, this.appendTo);
270
+ if (!this.overlay.style.minWidth) {
271
+ this.overlay.style.minWidth = DomHandler.getWidth(this.el.nativeElement.children[0]) + 'px';
272
+ }
273
+ }
274
+ }
275
+ resolveFieldData(value) {
276
+ return this.field ? ObjectUtils.resolveFieldData(value, this.field) : value;
277
+ }
278
+ restoreOverlayAppend() {
279
+ if (this.overlay && this.appendTo) {
280
+ this.el.nativeElement.appendChild(this.overlay);
281
+ }
282
+ }
283
+ alignOverlay() {
284
+ if (this.appendTo)
285
+ DomHandler.absolutePosition(this.overlay, (this.multiple ? this.multiContainerEL.nativeElement : this.inputEL.nativeElement));
286
+ else
287
+ DomHandler.relativePosition(this.overlay, (this.multiple ? this.multiContainerEL.nativeElement : this.inputEL.nativeElement));
288
+ }
289
+ hide() {
290
+ this.overlayVisible = false;
291
+ this.cd.markForCheck();
292
+ }
293
+ handleDropdownClick(event) {
294
+ if (!this.overlayVisible) {
295
+ this.focusInput();
296
+ let queryValue = this.multiple ? this.multiInputEL.nativeElement.value : this.inputEL.nativeElement.value;
297
+ if (this.dropdownMode === 'blank')
298
+ this.search(event, '');
299
+ else if (this.dropdownMode === 'current')
300
+ this.search(event, queryValue);
301
+ this.onDropdownClick.emit({
302
+ originalEvent: event,
303
+ query: queryValue
304
+ });
305
+ }
306
+ else {
307
+ this.hide();
308
+ }
309
+ }
310
+ focusInput() {
311
+ if (this.multiple)
312
+ this.multiInputEL.nativeElement.focus();
313
+ else
314
+ this.inputEL.nativeElement.focus();
315
+ }
316
+ removeItem(item) {
317
+ let itemIndex = DomHandler.index(item);
318
+ let removedValue = this.value[itemIndex];
319
+ this.value = this.value.filter((val, i) => i != itemIndex);
320
+ this.onModelChange(this.value);
321
+ this.updateFilledState();
322
+ this.onUnselect.emit(removedValue);
323
+ }
324
+ onKeydown(event) {
325
+ if (this.overlayVisible) {
326
+ let highlightItemIndex = this.findOptionIndex(this.highlightOption);
327
+ switch (event.which) {
328
+ //down
329
+ case 40:
330
+ if (highlightItemIndex != -1) {
331
+ var nextItemIndex = highlightItemIndex + 1;
332
+ if (nextItemIndex != (this.suggestions.length)) {
333
+ this.highlightOption = this.suggestions[nextItemIndex];
334
+ this.highlightOptionChanged = true;
335
+ }
336
+ }
337
+ else {
338
+ this.highlightOption = this.suggestions[0];
339
+ }
340
+ event.preventDefault();
341
+ break;
342
+ //up
343
+ case 38:
344
+ if (highlightItemIndex > 0) {
345
+ let prevItemIndex = highlightItemIndex - 1;
346
+ this.highlightOption = this.suggestions[prevItemIndex];
347
+ this.highlightOptionChanged = true;
348
+ }
349
+ event.preventDefault();
350
+ break;
351
+ //enter
352
+ case 13:
353
+ if (this.highlightOption) {
354
+ this.selectItem(this.highlightOption);
355
+ this.hide();
356
+ }
357
+ event.preventDefault();
358
+ break;
359
+ //escape
360
+ case 27:
361
+ this.hide();
362
+ event.preventDefault();
363
+ break;
364
+ //tab
365
+ case 9:
366
+ if (this.highlightOption) {
367
+ this.selectItem(this.highlightOption);
368
+ }
369
+ this.hide();
370
+ break;
371
+ }
372
+ }
373
+ else {
374
+ if (event.which === 40 && this.suggestions) {
375
+ this.search(event, event.target.value);
376
+ }
377
+ }
378
+ if (this.multiple) {
379
+ switch (event.which) {
380
+ //backspace
381
+ case 8:
382
+ if (this.value && this.value.length && !this.multiInputEL.nativeElement.value) {
383
+ this.value = [...this.value];
384
+ const removedValue = this.value.pop();
385
+ this.onModelChange(this.value);
386
+ this.updateFilledState();
387
+ this.onUnselect.emit(removedValue);
388
+ }
389
+ break;
390
+ }
391
+ }
392
+ this.inputKeyDown = true;
393
+ }
394
+ onKeyup(event) {
395
+ this.onKeyUp.emit(event);
396
+ }
397
+ onInputFocus(event) {
398
+ if (!this.itemClicked && this.completeOnFocus) {
399
+ let queryValue = this.multiple ? this.multiInputEL.nativeElement.value : this.inputEL.nativeElement.value;
400
+ this.search(event, queryValue);
401
+ }
402
+ this.focus = true;
403
+ this.onFocus.emit(event);
404
+ this.itemClicked = false;
405
+ }
406
+ onInputBlur(event) {
407
+ this.focus = false;
408
+ this.onModelTouched();
409
+ this.onBlur.emit(event);
410
+ }
411
+ onInputChange(event) {
412
+ if (this.forceSelection) {
413
+ let valid = false;
414
+ let inputValue = event.target.value.trim();
415
+ if (this.suggestions) {
416
+ for (let suggestion of this.suggestions) {
417
+ let itemValue = this.field ? ObjectUtils.resolveFieldData(suggestion, this.field) : suggestion;
418
+ if (itemValue && inputValue === itemValue.trim()) {
419
+ valid = true;
420
+ this.forceSelectionUpdateModelTimeout = setTimeout(() => {
421
+ this.selectItem(suggestion, false);
422
+ }, 250);
423
+ break;
424
+ }
425
+ }
426
+ }
427
+ if (!valid) {
428
+ if (this.multiple) {
429
+ this.multiInputEL.nativeElement.value = '';
430
+ }
431
+ else {
432
+ this.value = null;
433
+ this.inputEL.nativeElement.value = '';
434
+ }
435
+ this.onClear.emit(event);
436
+ this.onModelChange(this.value);
437
+ }
438
+ }
439
+ }
440
+ onInputPaste(event) {
441
+ this.onKeydown(event);
442
+ }
443
+ isSelected(val) {
444
+ let selected = false;
445
+ if (this.value && this.value.length) {
446
+ for (let i = 0; i < this.value.length; i++) {
447
+ if (ObjectUtils.equals(this.value[i], val, this.dataKey)) {
448
+ selected = true;
449
+ break;
450
+ }
451
+ }
452
+ }
453
+ return selected;
454
+ }
455
+ findOptionIndex(option) {
456
+ let index = -1;
457
+ if (this.suggestions) {
458
+ for (let i = 0; i < this.suggestions.length; i++) {
459
+ if (ObjectUtils.equals(option, this.suggestions[i])) {
460
+ index = i;
461
+ break;
462
+ }
463
+ }
464
+ }
465
+ return index;
466
+ }
467
+ updateFilledState() {
468
+ if (this.multiple)
469
+ this.filled = (this.value && this.value.length) || (this.multiInputEL && this.multiInputEL.nativeElement && this.multiInputEL.nativeElement.value != '');
470
+ else
471
+ this.filled = (this.inputFieldValue && this.inputFieldValue != '') || (this.inputEL && this.inputEL.nativeElement && this.inputEL.nativeElement.value != '');
472
+ ;
473
+ }
474
+ updateInputField() {
475
+ let formattedValue = this.value ? (this.field ? ObjectUtils.resolveFieldData(this.value, this.field) || '' : this.value) : '';
476
+ this.inputFieldValue = formattedValue;
477
+ if (this.inputEL && this.inputEL.nativeElement) {
478
+ this.inputEL.nativeElement.value = formattedValue;
479
+ }
480
+ this.updateFilledState();
481
+ }
482
+ bindDocumentClickListener() {
483
+ if (!this.documentClickListener) {
484
+ const documentTarget = this.el ? this.el.nativeElement.ownerDocument : 'document';
485
+ this.documentClickListener = this.renderer.listen(documentTarget, 'click', (event) => {
486
+ if (event.which === 3) {
487
+ return;
488
+ }
489
+ if (!this.inputClick && !this.isDropdownClick(event)) {
490
+ this.hide();
491
+ }
492
+ this.inputClick = false;
493
+ this.cd.markForCheck();
494
+ });
495
+ }
496
+ }
497
+ isDropdownClick(event) {
498
+ if (this.dropdown) {
499
+ let target = event.target;
500
+ return (target === this.dropdownButton.nativeElement || target.parentNode === this.dropdownButton.nativeElement);
501
+ }
502
+ else {
503
+ return false;
504
+ }
505
+ }
506
+ unbindDocumentClickListener() {
507
+ if (this.documentClickListener) {
508
+ this.documentClickListener();
509
+ this.documentClickListener = null;
510
+ }
511
+ }
512
+ bindDocumentResizeListener() {
513
+ this.documentResizeListener = this.onWindowResize.bind(this);
514
+ window.addEventListener('resize', this.documentResizeListener);
515
+ }
516
+ unbindDocumentResizeListener() {
517
+ if (this.documentResizeListener) {
518
+ window.removeEventListener('resize', this.documentResizeListener);
519
+ this.documentResizeListener = null;
520
+ }
521
+ }
522
+ onWindowResize() {
523
+ this.hide();
524
+ }
525
+ bindScrollListener() {
526
+ if (!this.scrollHandler) {
527
+ this.scrollHandler = new ConnectedOverlayScrollHandler(this.containerEL.nativeElement, () => {
528
+ if (this.overlayVisible) {
529
+ this.hide();
530
+ }
531
+ });
532
+ }
533
+ this.scrollHandler.bindScrollListener();
534
+ }
535
+ unbindScrollListener() {
536
+ if (this.scrollHandler) {
537
+ this.scrollHandler.unbindScrollListener();
538
+ }
539
+ }
540
+ onOverlayHide() {
541
+ this.unbindDocumentClickListener();
542
+ this.unbindDocumentResizeListener();
543
+ this.unbindScrollListener();
544
+ this.overlay = null;
545
+ this.onHide.emit();
546
+ }
547
+ ngOnDestroy() {
548
+ if (this.forceSelectionUpdateModelTimeout) {
549
+ clearTimeout(this.forceSelectionUpdateModelTimeout);
550
+ this.forceSelectionUpdateModelTimeout = null;
551
+ }
552
+ if (this.scrollHandler) {
553
+ this.scrollHandler.destroy();
554
+ this.scrollHandler = null;
555
+ }
556
+ this.restoreOverlayAppend();
557
+ this.onOverlayHide();
558
+ }
559
+ showMore() {
560
+ this._maxHeighContainerItemStrOld = this._maxHeighContainerItemStr;
561
+ this._maxHeighContainerItemStr = '10000px';
562
+ this.showCountItem = false;
563
+ }
564
+ showLess() {
565
+ this._maxHeighContainerItemStr = this._maxHeighContainerItemStrOld;
566
+ this._maxHeighContainerItemStrOld = null;
567
+ this.showCountItem = true;
568
+ }
569
+ }
570
+ AutoComplete.decorators = [
571
+ { type: Component, args: [{
572
+ selector: 'p-autoComplete',
573
+ template: `
574
+ <span #container [ngClass]="{'p-autocomplete p-component':true,'p-autocomplete-dd':dropdown,'p-autocomplete-multiple':multiple}" [ngStyle]="style" [class]="styleClass">
575
+ <input *ngIf="!multiple" #in [attr.type]="type" [attr.id]="inputId" [ngStyle]="inputStyle" [class]="inputStyleClass" [autocomplete]="autocomplete" [attr.required]="required" [attr.name]="name"
576
+ class="p-autocomplete-input p-inputtext p-component" [ngClass]="{'p-autocomplete-dd-input':dropdown,'p-disabled': disabled}" [value]="inputFieldValue" aria-autocomplete="list" [attr.aria-controls]="listId" role="searchbox" [attr.aria-expanded]="overlayVisible" aria-haspopup="true" [attr.aria-activedescendant]="'p-highlighted-option'"
577
+ (click)="onInputClick($event)" (input)="onInput($event)" (keydown)="onKeydown($event)" (keyup)="onKeyup($event)" [attr.autofocus]="autofocus" (focus)="onInputFocus($event)" (blur)="onInputBlur($event)" (change)="onInputChange($event)" (paste)="onInputPaste($event)"
578
+ [attr.placeholder]="placeholder" [attr.size]="size" [attr.maxlength]="maxlength" [attr.tabindex]="tabindex" [readonly]="readonly" [disabled]="disabled" [attr.aria-label]="ariaLabel" [attr.aria-labelledby]="ariaLabelledBy" [attr.aria-required]="required"
579
+ ><ul *ngIf="multiple" #multiContainer class="p-autocomplete-multiple-container p-component p-inputtext" [ngClass]="{'p-disabled':disabled,'p-focus':focus}" (click)="multiIn.focus()" [style.max-height]="_maxHeighContainerItemStr">
580
+ <li #token *ngFor="let val of value" class="p-autocomplete-token" [class.disabled]="val._disabled">
581
+ <ng-container *ngTemplateOutlet="selectedItemTemplate; context: {$implicit: val}"></ng-container>
582
+ <span *ngIf="!selectedItemTemplate" class="p-autocomplete-token-label">{{resolveFieldData(val)}}</span>
583
+ <span *ngIf="!disabled && !val._disabled" class="p-autocomplete-token-icon pi pi-times-circle" (click)="removeItem(token)"></span>
584
+ </li>
585
+ <li class="p-autocomplete-token p-autocomplete-countItem" *ngIf="showCountItem && value " (click)="showMore()">Có {{value.length}} bản ghi ...</li>
586
+ <!-- <ng-container *ngIf="value?.length > 10">
587
+ <li class="p-autocomplete-token p-autocomplete-countItem" (click)="showMore()">
588
+ Có {{value.length}} bản ghi ...
589
+ </li>
590
+ </ng-container> -->
591
+ <li class="p-autocomplete-token p-autocomplete-countItem" *ngIf="_maxHeighContainerItemStrOld != null" (click)="showLess()"><span><i class="fas fa-arrow-up"></i></span><span>Thu lại</span></li>
592
+ <li class="p-autocomplete-input-token">
593
+ <input #multiIn [attr.type]="type" [attr.id]="inputId" [disabled]="disabled" [attr.placeholder]="(value&&value.length ? null : placeholder)" [attr.tabindex]="tabindex" [attr.maxlength]="maxlength" (input)="onInput($event)" (click)="onInputClick($event)"
594
+ (keydown)="onKeydown($event)" [readonly]="readonly" (keyup)="onKeyup($event)" [attr.autofocus]="autofocus" (focus)="onInputFocus($event)" (blur)="onInputBlur($event)" (change)="onInputChange($event)" (paste)="onInputPaste($event)" [autocomplete]="autocomplete"
595
+ [ngStyle]="inputStyle" [class]="inputStyleClass" [attr.aria-label]="ariaLabel" [attr.aria-labelledby]="ariaLabelledBy" [attr.aria-required]="required"
596
+ aria-autocomplete="list" [attr.aria-controls]="listId" role="searchbox" [attr.aria-expanded]="overlayVisible" aria-haspopup="true" [attr.aria-activedescendant]="'p-highlighted-option'">
597
+ </li>
598
+ </ul>
599
+ <i *ngIf="loading" class="p-autocomplete-loader pi pi-spinner pi-spin"></i><button #ddBtn type="button" pButton [icon]="dropdownIcon" class="p-autocomplete-dropdown" [disabled]="disabled" pRipple
600
+ (click)="handleDropdownClick($event)" *ngIf="dropdown" [attr.tabindex]="tabindex"></button>
601
+ <div #panel *ngIf="overlayVisible" [ngClass]="['p-autocomplete-panel p-component']" [style.max-height]="scrollHeight" [ngStyle]="panelStyle" [class]="panelStyleClass"
602
+ [@overlayAnimation]="{value: 'visible', params: {showTransitionParams: showTransitionOptions, hideTransitionParams: hideTransitionOptions}}" (@overlayAnimation.start)="onOverlayAnimationStart($event)" (@overlayAnimation.done)="onOverlayAnimationDone($event)" >
603
+ <ul role="listbox" [attr.id]="listId" class="p-autocomplete-items">
604
+ <li role="option" *ngFor="let option of suggestions; let idx = index" class="p-autocomplete-item" pRipple [ngClass]="{'p-highlight': (option === highlightOption)}" [id]="highlightOption == option ? 'p-highlighted-option':''" (click)="selectItem(option)">
605
+ <span *ngIf="!itemTemplate">{{resolveFieldData(option)}}</span>
606
+ <ng-container *ngTemplateOutlet="itemTemplate; context: {$implicit: option, index: idx}"></ng-container>
607
+ </li>
608
+ <li *ngIf="noResults && emptyMessage" class="p-autocomplete-emptymessage p-autocomplete-item">{{emptyMessage}}</li>
609
+ </ul>
610
+ </div>
611
+ </span>
612
+ `,
613
+ animations: [
614
+ trigger('overlayAnimation', [
615
+ transition(':enter', [
616
+ style({ opacity: 0, transform: 'scaleY(0.8)' }),
617
+ animate('{{showTransitionParams}}')
618
+ ]),
619
+ transition(':leave', [
620
+ animate('{{hideTransitionParams}}', style({ opacity: 0 }))
621
+ ])
622
+ ])
623
+ ],
624
+ host: {
625
+ '[class.p-inputwrapper-filled]': 'filled',
626
+ '[class.p-inputwrapper-focus]': 'focus && !disabled'
627
+ },
628
+ providers: [AUTOCOMPLETE_VALUE_ACCESSOR],
629
+ changeDetection: ChangeDetectionStrategy.OnPush,
630
+ encapsulation: ViewEncapsulation.None,
631
+ styles: [".p-autocomplete{display:inline-flex;position:relative}.p-autocomplete-loader{position:absolute;top:50%;margin-top:-.5rem}.p-autocomplete-dd .p-autocomplete-input{flex:1 1 auto;width:1%}.p-autocomplete-dd .p-autocomplete-input,.p-autocomplete-dd .p-autocomplete-multiple-container{border-top-right-radius:0;border-bottom-right-radius:0}.p-autocomplete-dd .p-autocomplete-dropdown{border-top-left-radius:0;border-bottom-left-radius:0}.p-autocomplete .p-autocomplete-panel{min-width:100%}.p-autocomplete-panel{position:absolute;overflow:auto}.p-autocomplete-items{margin:0;padding:0;list-style-type:none}.p-autocomplete-item{cursor:pointer;white-space:nowrap;position:relative;overflow:hidden}.p-autocomplete-multiple-container{margin:0;padding:0;list-style-type:none;cursor:text;overflow:hidden;display:flex;align-items:center;flex-wrap:wrap}.p-autocomplete-token{cursor:default;display:inline-flex;align-items:center;flex:0 0 auto;padding:.125em .5em;margin-right:.125em;border:0;font-size:.9em}.p-autocomplete-token-icon{cursor:pointer}.p-autocomplete-input-token{display:inline-block;vertical-align:middle;list-style-type:none;margin:0 0 0 .125em;padding:.25em .25em .25em 0}.p-autocomplete-input-token input{border:0;width:10em;outline:medium none;background-color:transparent;margin:0;padding:0;box-shadow:none;border-radius:0}.p-fluid .p-autocomplete{display:flex}.p-fluid .p-autocomplete-dd .p-autocomplete-input{width:1%}.p-autocomplete-countItem{background-color:#e1e1e1!important;box-sizing:border-box;display:inline-flex;align-items:center;cursor:pointer}"]
632
+ },] }
633
+ ];
634
+ AutoComplete.ctorParameters = () => [
635
+ { type: ElementRef },
636
+ { type: Renderer2 },
637
+ { type: ChangeDetectorRef },
638
+ { type: IterableDiffers }
639
+ ];
640
+ AutoComplete.propDecorators = {
641
+ minLength: [{ type: Input }],
642
+ delay: [{ type: Input }],
643
+ style: [{ type: Input }],
644
+ panelStyle: [{ type: Input }],
645
+ styleClass: [{ type: Input }],
646
+ panelStyleClass: [{ type: Input }],
647
+ inputStyle: [{ type: Input }],
648
+ inputId: [{ type: Input }],
649
+ inputStyleClass: [{ type: Input }],
650
+ placeholder: [{ type: Input }],
651
+ readonly: [{ type: Input }],
652
+ disabled: [{ type: Input }],
653
+ maxlength: [{ type: Input }],
654
+ name: [{ type: Input }],
655
+ required: [{ type: Input }],
656
+ size: [{ type: Input }],
657
+ appendTo: [{ type: Input }],
658
+ autoHighlight: [{ type: Input }],
659
+ forceSelection: [{ type: Input }],
660
+ type: [{ type: Input }],
661
+ autoZIndex: [{ type: Input }],
662
+ baseZIndex: [{ type: Input }],
663
+ ariaLabel: [{ type: Input }],
664
+ ariaLabelledBy: [{ type: Input }],
665
+ dropdownIcon: [{ type: Input }],
666
+ unique: [{ type: Input }],
667
+ completeOnFocus: [{ type: Input }],
668
+ completeMethod: [{ type: Output }],
669
+ onSelect: [{ type: Output }],
670
+ onUnselect: [{ type: Output }],
671
+ onFocus: [{ type: Output }],
672
+ onBlur: [{ type: Output }],
673
+ onDropdownClick: [{ type: Output }],
674
+ onClear: [{ type: Output }],
675
+ onKeyUp: [{ type: Output }],
676
+ onShow: [{ type: Output }],
677
+ onHide: [{ type: Output }],
678
+ field: [{ type: Input }],
679
+ scrollHeight: [{ type: Input }],
680
+ dropdown: [{ type: Input }],
681
+ dropdownMode: [{ type: Input }],
682
+ multiple: [{ type: Input }],
683
+ tabindex: [{ type: Input }],
684
+ dataKey: [{ type: Input }],
685
+ emptyMessage: [{ type: Input }],
686
+ showTransitionOptions: [{ type: Input }],
687
+ hideTransitionOptions: [{ type: Input }],
688
+ autofocus: [{ type: Input }],
689
+ autocomplete: [{ type: Input }],
690
+ maxRowItem: [{ type: Input }],
691
+ containerEL: [{ type: ViewChild, args: ['container',] }],
692
+ inputEL: [{ type: ViewChild, args: ['in',] }],
693
+ multiInputEL: [{ type: ViewChild, args: ['multiIn',] }],
694
+ multiContainerEL: [{ type: ViewChild, args: ['multiContainer',] }],
695
+ dropdownButton: [{ type: ViewChild, args: ['ddBtn',] }],
696
+ templates: [{ type: ContentChildren, args: [PrimeTemplate,] }],
697
+ suggestions: [{ type: Input }]
698
+ };
699
+ export class AutoCompleteModule {
700
+ }
701
+ AutoCompleteModule.decorators = [
702
+ { type: NgModule, args: [{
703
+ imports: [CommonModule, InputTextModule, ButtonModule, SharedModule, RippleModule],
704
+ exports: [AutoComplete, SharedModule],
705
+ declarations: [AutoComplete]
706
+ },] }
707
+ ];
708
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../projects/tnx-shared/src/lib/components/autocomplete/autocomplete.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AnimationEvent, animate, style, transition, trigger } from '@angular/animations';\nimport { CommonModule } from '@angular/common';\nimport { AfterContentInit, AfterViewChecked, ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChildren, ElementRef, EventEmitter, Input, IterableDiffers, NgModule, OnDestroy, Output, QueryList, Renderer2, TemplateRef, ViewChild, ViewEncapsulation, forwardRef } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { PrimeTemplate, SharedModule } from 'tn-custom-primeng/api';\nimport { ButtonModule } from 'tn-custom-primeng/button';\nimport { ConnectedOverlayScrollHandler, DomHandler } from 'tn-custom-primeng/dom';\nimport { InputTextModule } from 'tn-custom-primeng/inputtext';\nimport { RippleModule } from 'tn-custom-primeng/ripple';\nimport { ObjectUtils, UniqueComponentId } from 'tn-custom-primeng/utils';\n\nexport const AUTOCOMPLETE_VALUE_ACCESSOR: any = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => AutoComplete),\n    multi: true\n};\n\n@Component({\n    selector: 'p-autoComplete',\n    template: `\n        <span #container [ngClass]=\"{'p-autocomplete p-component':true,'p-autocomplete-dd':dropdown,'p-autocomplete-multiple':multiple}\" [ngStyle]=\"style\" [class]=\"styleClass\">\n            <input *ngIf=\"!multiple\" #in [attr.type]=\"type\" [attr.id]=\"inputId\" [ngStyle]=\"inputStyle\" [class]=\"inputStyleClass\" [autocomplete]=\"autocomplete\" [attr.required]=\"required\" [attr.name]=\"name\"\n            class=\"p-autocomplete-input p-inputtext p-component\" [ngClass]=\"{'p-autocomplete-dd-input':dropdown,'p-disabled': disabled}\" [value]=\"inputFieldValue\" aria-autocomplete=\"list\" [attr.aria-controls]=\"listId\" role=\"searchbox\" [attr.aria-expanded]=\"overlayVisible\" aria-haspopup=\"true\" [attr.aria-activedescendant]=\"'p-highlighted-option'\"\n            (click)=\"onInputClick($event)\" (input)=\"onInput($event)\" (keydown)=\"onKeydown($event)\" (keyup)=\"onKeyup($event)\" [attr.autofocus]=\"autofocus\" (focus)=\"onInputFocus($event)\" (blur)=\"onInputBlur($event)\" (change)=\"onInputChange($event)\" (paste)=\"onInputPaste($event)\"\n            [attr.placeholder]=\"placeholder\" [attr.size]=\"size\" [attr.maxlength]=\"maxlength\" [attr.tabindex]=\"tabindex\" [readonly]=\"readonly\" [disabled]=\"disabled\" [attr.aria-label]=\"ariaLabel\" [attr.aria-labelledby]=\"ariaLabelledBy\" [attr.aria-required]=\"required\"\n            ><ul *ngIf=\"multiple\" #multiContainer class=\"p-autocomplete-multiple-container p-component p-inputtext\" [ngClass]=\"{'p-disabled':disabled,'p-focus':focus}\" (click)=\"multiIn.focus()\" [style.max-height]=\"_maxHeighContainerItemStr\">\n                <li #token *ngFor=\"let val of value\" class=\"p-autocomplete-token\" [class.disabled]=\"val._disabled\">\n                    <ng-container *ngTemplateOutlet=\"selectedItemTemplate; context: {$implicit: val}\"></ng-container>\n                    <span *ngIf=\"!selectedItemTemplate\" class=\"p-autocomplete-token-label\">{{resolveFieldData(val)}}</span>\n                    <span *ngIf=\"!disabled && !val._disabled\" class=\"p-autocomplete-token-icon pi pi-times-circle\" (click)=\"removeItem(token)\"></span>\n                </li>\n                <li class=\"p-autocomplete-token p-autocomplete-countItem\" *ngIf=\"showCountItem && value \" (click)=\"showMore()\">Có {{value.length}} bản ghi ...</li>\n                <!-- <ng-container *ngIf=\"value?.length > 10\">\n                    <li class=\"p-autocomplete-token p-autocomplete-countItem\" (click)=\"showMore()\">\n                        Có {{value.length}} bản ghi ...\n                    </li>\n                </ng-container>     -->\n                <li class=\"p-autocomplete-token p-autocomplete-countItem\" *ngIf=\"_maxHeighContainerItemStrOld != null\" (click)=\"showLess()\"><span><i class=\"fas fa-arrow-up\"></i></span><span>Thu lại</span></li>\n                <li class=\"p-autocomplete-input-token\">\n                    <input #multiIn [attr.type]=\"type\" [attr.id]=\"inputId\" [disabled]=\"disabled\" [attr.placeholder]=\"(value&&value.length ? null : placeholder)\" [attr.tabindex]=\"tabindex\" [attr.maxlength]=\"maxlength\" (input)=\"onInput($event)\"  (click)=\"onInputClick($event)\"\n                            (keydown)=\"onKeydown($event)\" [readonly]=\"readonly\" (keyup)=\"onKeyup($event)\" [attr.autofocus]=\"autofocus\" (focus)=\"onInputFocus($event)\" (blur)=\"onInputBlur($event)\" (change)=\"onInputChange($event)\" (paste)=\"onInputPaste($event)\" [autocomplete]=\"autocomplete\"\n                            [ngStyle]=\"inputStyle\" [class]=\"inputStyleClass\" [attr.aria-label]=\"ariaLabel\" [attr.aria-labelledby]=\"ariaLabelledBy\" [attr.aria-required]=\"required\"\n                            aria-autocomplete=\"list\" [attr.aria-controls]=\"listId\" role=\"searchbox\" [attr.aria-expanded]=\"overlayVisible\" aria-haspopup=\"true\" [attr.aria-activedescendant]=\"'p-highlighted-option'\">\n                </li>\n            </ul>\n            <i *ngIf=\"loading\" class=\"p-autocomplete-loader pi pi-spinner pi-spin\"></i><button #ddBtn type=\"button\" pButton [icon]=\"dropdownIcon\" class=\"p-autocomplete-dropdown\" [disabled]=\"disabled\" pRipple\n                (click)=\"handleDropdownClick($event)\" *ngIf=\"dropdown\" [attr.tabindex]=\"tabindex\"></button>\n            <div #panel *ngIf=\"overlayVisible\" [ngClass]=\"['p-autocomplete-panel p-component']\" [style.max-height]=\"scrollHeight\" [ngStyle]=\"panelStyle\" [class]=\"panelStyleClass\"\n                [@overlayAnimation]=\"{value: 'visible', params: {showTransitionParams: showTransitionOptions, hideTransitionParams: hideTransitionOptions}}\" (@overlayAnimation.start)=\"onOverlayAnimationStart($event)\" (@overlayAnimation.done)=\"onOverlayAnimationDone($event)\" >\n                <ul role=\"listbox\" [attr.id]=\"listId\" class=\"p-autocomplete-items\">\n                    <li role=\"option\" *ngFor=\"let option of suggestions; let idx = index\" class=\"p-autocomplete-item\" pRipple [ngClass]=\"{'p-highlight': (option === highlightOption)}\" [id]=\"highlightOption == option ? 'p-highlighted-option':''\" (click)=\"selectItem(option)\">\n                        <span *ngIf=\"!itemTemplate\">{{resolveFieldData(option)}}</span>\n                        <ng-container *ngTemplateOutlet=\"itemTemplate; context: {$implicit: option, index: idx}\"></ng-container>\n                    </li>\n                    <li *ngIf=\"noResults && emptyMessage\" class=\"p-autocomplete-emptymessage p-autocomplete-item\">{{emptyMessage}}</li>\n                </ul>\n            </div>\n        </span>\n    `,\n    animations: [\n        trigger('overlayAnimation', [\n            transition(':enter', [\n                style({ opacity: 0, transform: 'scaleY(0.8)' }),\n                animate('{{showTransitionParams}}')\n            ]),\n            transition(':leave', [\n                animate('{{hideTransitionParams}}', style({ opacity: 0 }))\n            ])\n        ])\n    ],\n    host: {\n        '[class.p-inputwrapper-filled]': 'filled',\n        '[class.p-inputwrapper-focus]': 'focus && !disabled'\n    },\n    providers: [AUTOCOMPLETE_VALUE_ACCESSOR],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    styleUrls: ['./autocomplete.component.scss']\n})\nexport class AutoComplete implements AfterViewChecked, AfterContentInit, OnDestroy, ControlValueAccessor {\n\n    @Input() minLength: number = 1;\n\n    @Input() delay: number = 300;\n\n    @Input() style: any;\n\n    @Input() panelStyle: any;\n\n    @Input() styleClass: string;\n\n    @Input() panelStyleClass: string;\n\n    @Input() inputStyle: any;\n\n    @Input() inputId: string;\n\n    @Input() inputStyleClass: string;\n\n    @Input() placeholder: string;\n\n    @Input() readonly: boolean;\n\n    @Input() disabled: boolean;\n\n    @Input() maxlength: number;\n\n    @Input() name: string;\n\n    @Input() required: boolean;\n\n    @Input() size: number;\n\n    @Input() appendTo: any;\n\n    @Input() autoHighlight: boolean;\n\n    @Input() forceSelection: boolean;\n\n    @Input() type: string = 'text';\n\n    @Input() autoZIndex: boolean = true;\n\n    @Input() baseZIndex: number = 0;\n\n    @Input() ariaLabel: string;\n\n    @Input() ariaLabelledBy: string;\n\n    @Input() dropdownIcon: string = \"pi pi-chevron-down\";\n\n    @Input() unique: boolean = true;\n\n    @Input() completeOnFocus: boolean = false;\n\n    @Output() completeMethod: EventEmitter<any> = new EventEmitter();\n\n    @Output() onSelect: EventEmitter<any> = new EventEmitter();\n\n    @Output() onUnselect: EventEmitter<any> = new EventEmitter();\n\n    @Output() onFocus: EventEmitter<any> = new EventEmitter();\n\n    @Output() onBlur: EventEmitter<any> = new EventEmitter();\n\n    @Output() onDropdownClick: EventEmitter<any> = new EventEmitter();\n\n    @Output() onClear: EventEmitter<any> = new EventEmitter();\n\n    @Output() onKeyUp: EventEmitter<any> = new EventEmitter();\n\n    @Output() onShow: EventEmitter<any> = new EventEmitter();\n\n    @Output() onHide: EventEmitter<any> = new EventEmitter();\n\n    @Input() field: string;\n\n    @Input() scrollHeight: string = '200px';\n\n    @Input() dropdown: boolean;\n\n    @Input() dropdownMode: string = 'blank';\n\n    @Input() multiple: boolean;\n\n    @Input() tabindex: number;\n\n    @Input() dataKey: string;\n\n    @Input() emptyMessage: string;\n\n    @Input() showTransitionOptions: string = '.12s cubic-bezier(0, 0, 0.2, 1)';\n\n    @Input() hideTransitionOptions: string = '.1s linear';\n\n    @Input() autofocus: boolean;\n\n    @Input() autocomplete: string = 'off';\n\n    @Input() set maxRowItem(value: number) {\n        const rowHeight = 27;\n        const padding = 7;\n        this._maxHeighContainerItem = Math.round(value * 30.5) + 7;\n        this._maxHeighContainerItemStr = this._maxHeighContainerItem.toString() + 'px';\n    }\n\n    @ViewChild('container') containerEL: ElementRef;\n\n    @ViewChild('in') inputEL: ElementRef;\n\n    @ViewChild('multiIn') multiInputEL: ElementRef;\n\n    @ViewChild('multiContainer') multiContainerEL: ElementRef;\n\n    @ViewChild('ddBtn') dropdownButton: ElementRef;\n\n    @ContentChildren(PrimeTemplate) templates: QueryList<any>;\n\n    overlay: HTMLDivElement;\n\n    itemTemplate: TemplateRef<any>;\n\n    selectedItemTemplate: TemplateRef<any>;\n\n    value: any;\n\n    _suggestions: any[];\n\n    onModelChange: Function = () => { };\n\n    onModelTouched: Function = () => { };\n\n    timeout: any;\n\n    _maxHeighContainerItem: number;\n\n    _maxHeighContainerItemStr: string;\n\n    _maxHeighContainerItemStrOld: string;\n    showCountItem = false;\n\n    overlayVisible: boolean = false;\n\n    documentClickListener: any;\n\n    suggestionsUpdated: boolean;\n\n    highlightOption: any;\n\n    highlightOptionChanged: boolean;\n\n    focus: boolean = false;\n\n    filled: boolean;\n\n    inputClick: boolean;\n\n    inputKeyDown: boolean;\n\n    noResults: boolean;\n\n    differ: any;\n\n    inputFieldValue: string = null;\n\n    loading: boolean;\n\n    scrollHandler: any;\n\n    documentResizeListener: any;\n\n    forceSelectionUpdateModelTimeout: any;\n\n    listId: string;\n\n    itemClicked: boolean;\n    filterValue: any;\n\n    constructor(public el: ElementRef, public renderer: Renderer2, public cd: ChangeDetectorRef, public differs: IterableDiffers) {\n        this.differ = differs.find([]).create(null);\n        this.listId = UniqueComponentId() + '_list';\n    }\n\n    @Input() get suggestions(): any[] {\n        return this._suggestions;\n    }\n\n    set suggestions(val: any[]) {\n        this._suggestions = val;\n        this.handleSuggestionsChange();\n    }\n\n    ngAfterViewChecked() {\n        //Use timeouts as since Angular 4.2, AfterViewChecked is broken and not called after panel is updated\n        if (this.suggestionsUpdated && this.overlay && this.overlay.offsetParent) {\n            setTimeout(() => {\n                if (this.overlay) {\n                    this.alignOverlay();\n                }\n            }, 1);\n            this.suggestionsUpdated = false;\n        }\n\n        if (this.highlightOptionChanged) {\n            setTimeout(() => {\n                if (this.overlay) {\n                    let listItem = DomHandler.findSingle(this.overlay, 'li.p-highlight');\n                    if (listItem) {\n                        DomHandler.scrollInView(this.overlay, listItem);\n                    }\n                }\n            }, 1);\n            this.highlightOptionChanged = false;\n        }\n        if (this.multiContainerEL) {\n            var lastItemSelected = DomHandler.findSingle(this.multiContainerEL.nativeElement, 'li:first-child');\n            this.multiContainerEL.nativeElement.scrollTop = 10000;\n            let rectParent = this.multiContainerEL.nativeElement.getBoundingClientRect();\n            let rectLastItem = lastItemSelected.getBoundingClientRect();\n            if (rectLastItem.y < rectParent.y) {\n                this.showCountItem = true;\n            }\n            else {\n                this.showCountItem = false;\n            }\n        }\n        const countItem = DomHandler.findSingle(this.multiContainerEL.nativeElement, '.p-autocomplete-countItem');\n        if (this.showCountItem && !countItem) {\n            this.focusInput()\n        }\n    }\n\n    handleSuggestionsChange() {\n        if (this._suggestions != null && this.loading) {\n            this.highlightOption = null;\n            if (this._suggestions.length) {\n                this.noResults = false;\n                this.show();\n                this.suggestionsUpdated = true;\n\n                if (this.autoHighlight) {\n                    this.highlightOption = this._suggestions[0];\n                }\n            }\n            else {\n                this.noResults = true;\n\n                if (this.emptyMessage) {\n                    this.show();\n                    this.suggestionsUpdated = true;\n                }\n                else {\n                    this.hide();\n                }\n            }\n\n            this.loading = false;\n        }\n    }\n\n    ngAfterContentInit() {\n        this.templates.forEach((item) => {\n            switch (item.getType()) {\n                case 'item':\n                    this.itemTemplate = item.template;\n                    break;\n\n                case 'selectedItem':\n                    this.selectedItemTemplate = item.template;\n                    break;\n\n                default:\n                    this.itemTemplate = item.template;\n                    break;\n            }\n        });\n    }\n\n    writeValue(value: any): void {\n        this.value = value;\n        this.filled = this.value && this.value != '';\n        this.updateInputField();\n        this.cd.markForCheck();\n    }\n\n    registerOnChange(fn: Function): void {\n        this.onModelChange = fn;\n    }\n\n    registerOnTouched(fn: Function): void {\n        this.onModelTouched = fn;\n    }\n\n    setDisabledState(val: boolean): void {\n        this.disabled = val;\n        this.cd.markForCheck();\n    }\n\n    onInput(event: Event) {\n        // When an input element with a placeholder is clicked, the onInput event is invoked in IE.\n        if (!this.inputKeyDown && DomHandler.isIE()) {\n            return;\n        }\n\n        if (this.timeout) {\n            clearTimeout(this.timeout);\n        }\n\n        let value = (<HTMLInputElement>event.target).value;\n        if (!this.multiple && !this.forceSelection) {\n            this.onModelChange(value);\n        }\n\n        if (value.length === 0 && !this.multiple) {\n            this.hide();\n            this.onClear.emit(event);\n            this.onModelChange(value);\n        }\n\n        if (value.length >= this.minLength) {\n            this.timeout = setTimeout(() => {\n                this.search(event, value);\n            }, this.delay);\n        }\n        else {\n            this.suggestions = null;\n            this.hide();\n        }\n        this.updateFilledState();\n        this.inputKeyDown = false;\n    }\n\n    onInputClick(event: MouseEvent) {\n        if (this.documentClickListener) {\n            this.inputClick = true;\n        }\n    }\n\n    search(event: any, query: string) {\n        //allow empty string but not undefined or null\n        if (query === undefined || query === null) {\n            return;\n        }\n\n        this.loading = true;\n\n        this.completeMethod.emit({\n            originalEvent: event,\n            query: query\n        });\n    }\n\n    selectItem(option: any, focus: boolean = true) {\n        if (this.forceSelectionUpdateModelTimeout) {\n            clearTimeout(this.forceSelectionUpdateModelTimeout);\n            this.forceSelectionUpdateModelTimeout = null;\n        }\n\n        if (this.multiple) {\n            this.multiInputEL.nativeElement.value = '';\n            this.value = this.value || [];\n            if (!this.isSelected(option) || !this.unique) {\n                this.value = [...this.value, option];\n                this.onModelChange(this.value);\n            }\n        }\n        else {\n            this.inputEL.nativeElement.value = this.field ? ObjectUtils.resolveFieldData(option, this.field) || '' : option;\n            this.value = option;\n            this.onModelChange(this.value);\n        }\n\n        this.onSelect.emit(option);\n        this.updateFilledState();\n\n        if (focus) {\n            this.itemClicked = true;\n            this.focusInput();\n        }\n    }\n\n    show() {\n        if (this.multiInputEL || this.inputEL) {\n            let hasFocus = this.multiple ?\n                this.multiInputEL.nativeElement.ownerDocument.activeElement == this.multiInputEL.nativeElement :\n                this.inputEL.nativeElement.ownerDocument.activeElement == this.inputEL.nativeElement;\n\n            if (!this.overlayVisible && hasFocus) {\n                this.overlayVisible = true;\n            }\n        }\n    }\n\n    onOverlayAnimationStart(event: AnimationEvent) {\n        switch (event.toState) {\n            case 'visible':\n                this.overlay = event.element;\n                this.appendOverlay();\n                if (this.autoZIndex) {\n                    this.overlay.style.zIndex = String(this.baseZIndex + (++DomHandler.zindex));\n                }\n                this.alignOverlay();\n                this.bindDocumentClickListener();\n                this.bindDocumentResizeListener();\n                this.bindScrollListener();\n                this.onShow.emit(event);\n                break;\n\n            case 'void':\n                this.onOverlayHide();\n                break;\n        }\n    }\n\n    onOverlayAnimationDone(event: AnimationEvent) {\n        if (event.toState === 'void') {\n            this._suggestions = null;\n        }\n    }\n\n    appendOverlay() {\n        if (this.appendTo) {\n            if (this.appendTo === 'body')\n                document.body.appendChild(this.overlay);\n            else\n                DomHandler.appendChild(this.overlay, this.appendTo);\n\n            if (!this.overlay.style.minWidth) {\n                this.overlay.style.minWidth = DomHandler.getWidth(this.el.nativeElement.children[0]) + 'px';\n            }\n        }\n    }\n\n    resolveFieldData(value) {\n        return this.field ? ObjectUtils.resolveFieldData(value, this.field) : value;\n    }\n\n    restoreOverlayAppend() {\n        if (this.overlay && this.appendTo) {\n            this.el.nativeElement.appendChild(this.overlay);\n        }\n    }\n\n    alignOverlay() {\n        if (this.appendTo)\n            DomHandler.absolutePosition(this.overlay, (this.multiple ? this.multiContainerEL.nativeElement : this.inputEL.nativeElement));\n        else\n            DomHandler.relativePosition(this.overlay, (this.multiple ? this.multiContainerEL.nativeElement : this.inputEL.nativeElement));\n    }\n\n    hide() {\n        this.overlayVisible = false;\n        this.cd.markForCheck();\n    }\n\n    handleDropdownClick(event) {\n        if (!this.overlayVisible) {\n            this.focusInput();\n            let queryValue = this.multiple ? this.multiInputEL.nativeElement.value : this.inputEL.nativeElement.value;\n\n            if (this.dropdownMode === 'blank')\n                this.search(event, '');\n            else if (this.dropdownMode === 'current')\n                this.search(event, queryValue);\n\n            this.onDropdownClick.emit({\n                originalEvent: event,\n                query: queryValue\n            });\n        }\n        else {\n            this.hide();\n        }\n    }\n\n    focusInput() {\n        if (this.multiple)\n            this.multiInputEL.nativeElement.focus();\n        else\n            this.inputEL.nativeElement.focus();\n    }\n\n    removeItem(item: any) {\n        let itemIndex = DomHandler.index(item);\n        let removedValue = this.value[itemIndex];\n        this.value = this.value.filter((val, i) => i != itemIndex);\n        this.onModelChange(this.value);\n        this.updateFilledState();\n        this.onUnselect.emit(removedValue);\n    }\n\n    onKeydown(event) {\n        if (this.overlayVisible) {\n            let highlightItemIndex = this.findOptionIndex(this.highlightOption);\n\n            switch (event.which) {\n                //down\n                case 40:\n                    if (highlightItemIndex != -1) {\n                        var nextItemIndex = highlightItemIndex + 1;\n                        if (nextItemIndex != (this.suggestions.length)) {\n                            this.highlightOption = this.suggestions[nextItemIndex];\n                            this.highlightOptionChanged = true;\n                        }\n                    }\n                    else {\n                        this.highlightOption = this.suggestions[0];\n                    }\n\n                    event.preventDefault();\n                    break;\n\n                //up\n                case 38:\n                    if (highlightItemIndex > 0) {\n                        let prevItemIndex = highlightItemIndex - 1;\n                        this.highlightOption = this.suggestions[prevItemIndex];\n                        this.highlightOptionChanged = true;\n                    }\n\n                    event.preventDefault();\n                    break;\n\n                //enter\n                case 13:\n                    if (this.highlightOption) {\n                        this.selectItem(this.highlightOption);\n                        this.hide();\n                    }\n                    event.preventDefault();\n                    break;\n\n                //escape\n                case 27:\n                    this.hide();\n                    event.preventDefault();\n                    break;\n\n\n                //tab\n                case 9:\n                    if (this.highlightOption) {\n                        this.selectItem(this.highlightOption);\n                    }\n                    this.hide();\n                    break;\n            }\n        } else {\n            if (event.which === 40 && this.suggestions) {\n                this.search(event, event.target.value);\n            }\n        }\n\n        if (this.multiple) {\n            switch (event.which) {\n                //backspace\n                case 8:\n                    if (this.value && this.value.length && !this.multiInputEL.nativeElement.value) {\n                        this.value = [...this.value];\n                        const removedValue = this.value.pop();\n                        this.onModelChange(this.value);\n                        this.updateFilledState();\n                        this.onUnselect.emit(removedValue);\n                    }\n                    break;\n            }\n        }\n\n        this.inputKeyDown = true;\n    }\n\n    onKeyup(event) {\n        this.onKeyUp.emit(event);\n    }\n\n    onInputFocus(event) {\n        if (!this.itemClicked && this.completeOnFocus) {\n            let queryValue = this.multiple ? this.multiInputEL.nativeElement.value : this.inputEL.nativeElement.value;\n            this.search(event, queryValue);\n        }\n\n        this.focus = true;\n        this.onFocus.emit(event);\n        this.itemClicked = false;\n    }\n\n    onInputBlur(event) {\n        this.focus = false;\n        this.onModelTouched();\n        this.onBlur.emit(event);\n    }\n\n    onInputChange(event) {\n        if (this.forceSelection) {\n            let valid = false;\n            let inputValue = event.target.value.trim();\n\n            if (this.suggestions) {\n                for (let suggestion of this.suggestions) {\n                    let itemValue = this.field ? ObjectUtils.resolveFieldData(suggestion, this.field) : suggestion;\n                    if (itemValue && inputValue === itemValue.trim()) {\n                        valid = true;\n                        this.forceSelectionUpdateModelTimeout = setTimeout(() => {\n                            this.selectItem(suggestion, false);\n                        }, 250);\n                        break;\n                    }\n                }\n            }\n\n            if (!valid) {\n                if (this.multiple) {\n                    this.multiInputEL.nativeElement.value = '';\n                }\n                else {\n                    this.value = null;\n                    this.inputEL.nativeElement.value = '';\n                }\n\n                this.onClear.emit(event);\n                this.onModelChange(this.value);\n            }\n        }\n    }\n\n    onInputPaste(event: ClipboardEvent) {\n        this.onKeydown(event);\n    }\n\n    isSelected(val: any): boolean {\n        let selected: boolean = false;\n        if (this.value && this.value.length) {\n            for (let i = 0; i < this.value.length; i++) {\n                if (ObjectUtils.equals(this.value[i], val, this.dataKey)) {\n                    selected = true;\n                    break;\n                }\n            }\n        }\n        return selected;\n    }\n\n    findOptionIndex(option): number {\n        let index: number = -1;\n        if (this.suggestions) {\n            for (let i = 0; i < this.suggestions.length; i++) {\n                if (ObjectUtils.equals(option, this.suggestions[i])) {\n                    index = i;\n                    break;\n                }\n            }\n        }\n\n        return index;\n    }\n\n    updateFilledState() {\n        if (this.multiple)\n            this.filled = (this.value && this.value.length) || (this.multiInputEL && this.multiInputEL.nativeElement && this.multiInputEL.nativeElement.value != '');\n        else\n            this.filled = (this.inputFieldValue && this.inputFieldValue != '') || (this.inputEL && this.inputEL.nativeElement && this.inputEL.nativeElement.value != '');;\n    }\n\n    updateInputField() {\n        let formattedValue = this.value ? (this.field ? ObjectUtils.resolveFieldData(this.value, this.field) || '' : this.value) : '';\n        this.inputFieldValue = formattedValue;\n\n        if (this.inputEL && this.inputEL.nativeElement) {\n            this.inputEL.nativeElement.value = formattedValue;\n        }\n\n        this.updateFilledState();\n    }\n\n    bindDocumentClickListener() {\n        if (!this.documentClickListener) {\n            const documentTarget: any = this.el ? this.el.nativeElement.ownerDocument : 'document';\n\n            this.documentClickListener = this.renderer.listen(documentTarget, 'click', (event) => {\n                if (event.which === 3) {\n                    return;\n                }\n\n                if (!this.inputClick && !this.isDropdownClick(event)) {\n                    this.hide();\n                }\n\n                this.inputClick = false;\n                this.cd.markForCheck();\n            });\n        }\n    }\n\n    isDropdownClick(event) {\n        if (this.dropdown) {\n            let target = event.target;\n            return (target === this.dropdownButton.nativeElement || target.parentNode === this.dropdownButton.nativeElement);\n        }\n        else {\n            return false;\n        }\n    }\n\n    unbindDocumentClickListener() {\n        if (this.documentClickListener) {\n            this.documentClickListener();\n            this.documentClickListener = null;\n        }\n    }\n\n    bindDocumentResizeListener() {\n        this.documentResizeListener = this.onWindowResize.bind(this);\n        window.addEventListener('resize', this.documentResizeListener);\n    }\n\n    unbindDocumentResizeListener() {\n        if (this.documentResizeListener) {\n            window.removeEventListener('resize', this.documentResizeListener);\n            this.documentResizeListener = null;\n        }\n    }\n\n    onWindowResize() {\n        this.hide();\n    }\n\n    bindScrollListener() {\n        if (!this.scrollHandler) {\n            this.scrollHandler = new ConnectedOverlayScrollHandler(this.containerEL.nativeElement, () => {\n                if (this.overlayVisible) {\n                    this.hide();\n                }\n            });\n        }\n\n        this.scrollHandler.bindScrollListener();\n    }\n\n    unbindScrollListener() {\n        if (this.scrollHandler) {\n            this.scrollHandler.unbindScrollListener();\n        }\n    }\n\n    onOverlayHide() {\n        this.unbindDocumentClickListener();\n        this.unbindDocumentResizeListener();\n        this.unbindScrollListener();\n        this.overlay = null;\n        this.onHide.emit();\n    }\n\n    ngOnDestroy() {\n        if (this.forceSelectionUpdateModelTimeout) {\n            clearTimeout(this.forceSelectionUpdateModelTimeout);\n            this.forceSelectionUpdateModelTimeout = null;\n        }\n\n        if (this.scrollHandler) {\n            this.scrollHandler.destroy();\n            this.scrollHandler = null;\n        }\n        this.restoreOverlayAppend();\n        this.onOverlayHide();\n    }\n\n    showMore() {\n        this._maxHeighContainerItemStrOld = this._maxHeighContainerItemStr;\n        this._maxHeighContainerItemStr = '10000px';\n        this.showCountItem = false;\n    }\n\n    showLess() {\n        this._maxHeighContainerItemStr = this._maxHeighContainerItemStrOld;\n        this._maxHeighContainerItemStrOld = null;\n        this.showCountItem = true;\n    }\n}\n\n@NgModule({\n    imports: [CommonModule, InputTextModule, ButtonModule, SharedModule, RippleModule],\n    exports: [AutoComplete, SharedModule],\n    declarations: [AutoComplete]\n})\nexport class AutoCompleteModule { }\n"]}