@ng-select/ng-select 2.20.2 → 3.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (104) hide show
  1. package/README.md +3 -3
  2. package/bundles/ng-select-ng-select.umd.js +4525 -0
  3. package/bundles/ng-select-ng-select.umd.js.map +1 -0
  4. package/bundles/ng-select-ng-select.umd.min.js +2 -0
  5. package/bundles/ng-select-ng-select.umd.min.js.map +1 -0
  6. package/esm2015/lib/config.service.js +40 -0
  7. package/esm2015/lib/console.service.js +20 -0
  8. package/esm2015/lib/id.js +21 -0
  9. package/esm2015/lib/items-list.js +661 -0
  10. package/esm2015/lib/ng-dropdown-panel.component.js +661 -0
  11. package/esm2015/lib/ng-dropdown-panel.service.js +127 -0
  12. package/esm2015/lib/ng-option.component.js +74 -0
  13. package/esm2015/lib/ng-select.component.js +1384 -0
  14. package/esm2015/lib/ng-select.module.js +57 -0
  15. package/esm2015/lib/ng-select.types.js +48 -0
  16. package/esm2015/{ng-select → lib}/ng-templates.directive.js +2 -3
  17. package/esm2015/lib/search-helper.js +862 -0
  18. package/esm2015/lib/selection-model.js +166 -0
  19. package/esm2015/lib/value-utils.js +33 -0
  20. package/esm2015/ng-select-ng-select.js +15 -0
  21. package/esm2015/public-api.js +11 -0
  22. package/esm5/lib/config.service.js +42 -0
  23. package/esm5/lib/console.service.js +28 -0
  24. package/esm5/lib/id.js +21 -0
  25. package/esm5/lib/items-list.js +888 -0
  26. package/esm5/lib/ng-dropdown-panel.component.js +770 -0
  27. package/esm5/lib/ng-dropdown-panel.service.js +150 -0
  28. package/esm5/lib/ng-option.component.js +86 -0
  29. package/esm5/lib/ng-select.component.js +1637 -0
  30. package/esm5/lib/ng-select.module.js +61 -0
  31. package/esm5/lib/ng-select.types.js +48 -0
  32. package/esm5/{ng-select → lib}/ng-templates.directive.js +2 -3
  33. package/esm5/lib/search-helper.js +862 -0
  34. package/esm5/{ng-select → lib}/selection-model.js +69 -22
  35. package/esm5/lib/value-utils.js +33 -0
  36. package/esm5/ng-select-ng-select.js +15 -0
  37. package/esm5/public-api.js +11 -0
  38. package/fesm2015/ng-select-ng-select.js +3804 -0
  39. package/fesm2015/ng-select-ng-select.js.map +1 -0
  40. package/fesm5/ng-select-ng-select.js +4442 -0
  41. package/fesm5/ng-select-ng-select.js.map +1 -0
  42. package/{ng-select → lib}/config.service.d.ts +0 -0
  43. package/{ng-select → lib}/console.service.d.ts +0 -0
  44. package/{ng-select → lib}/id.d.ts +0 -0
  45. package/{ng-select → lib}/items-list.d.ts +1 -1
  46. package/{ng-select → lib}/ng-dropdown-panel.component.d.ts +0 -0
  47. package/{ng-select → lib}/ng-dropdown-panel.service.d.ts +0 -0
  48. package/{ng-select → lib}/ng-option.component.d.ts +0 -0
  49. package/{ng-select → lib}/ng-select.component.d.ts +9 -9
  50. package/{ng-select → lib}/ng-select.module.d.ts +0 -0
  51. package/{ng-select → lib}/ng-select.types.d.ts +0 -0
  52. package/{ng-select → lib}/ng-templates.directive.d.ts +0 -0
  53. package/{ng-select → lib}/search-helper.d.ts +0 -0
  54. package/{ng-select → lib}/selection-model.d.ts +0 -0
  55. package/{ng-select → lib}/value-utils.d.ts +0 -0
  56. package/ng-select-ng-select.d.ts +10 -0
  57. package/ng-select-ng-select.metadata.json +1 -0
  58. package/package.json +13 -14
  59. package/public-api.d.ts +5 -0
  60. package/scss/material.theme.scss +1 -1
  61. package/themes/material.theme.css +1 -1
  62. package/bundles/ng-select.umd.js +0 -4283
  63. package/bundles/ng-select.umd.js.map +0 -1
  64. package/bundles/ng-select.umd.min.js +0 -2
  65. package/bundles/ng-select.umd.min.js.map +0 -1
  66. package/esm2015/index.js +0 -9
  67. package/esm2015/ng-select/config.service.js +0 -41
  68. package/esm2015/ng-select/console.service.js +0 -21
  69. package/esm2015/ng-select/id.js +0 -17
  70. package/esm2015/ng-select/items-list.js +0 -542
  71. package/esm2015/ng-select/ng-dropdown-panel.component.js +0 -562
  72. package/esm2015/ng-select/ng-dropdown-panel.service.js +0 -121
  73. package/esm2015/ng-select/ng-option-highlight.directive.js +0 -98
  74. package/esm2015/ng-select/ng-option.component.js +0 -71
  75. package/esm2015/ng-select/ng-select.component.js +0 -1214
  76. package/esm2015/ng-select/ng-select.module.js +0 -61
  77. package/esm2015/ng-select/ng-select.types.js +0 -49
  78. package/esm2015/ng-select/search-helper.js +0 -859
  79. package/esm2015/ng-select/selection-model.js +0 -122
  80. package/esm2015/ng-select/value-utils.js +0 -34
  81. package/esm2015/ng-select.js +0 -17
  82. package/esm5/index.js +0 -9
  83. package/esm5/ng-select/config.service.js +0 -43
  84. package/esm5/ng-select/console.service.js +0 -29
  85. package/esm5/ng-select/id.js +0 -17
  86. package/esm5/ng-select/items-list.js +0 -761
  87. package/esm5/ng-select/ng-dropdown-panel.component.js +0 -654
  88. package/esm5/ng-select/ng-dropdown-panel.service.js +0 -144
  89. package/esm5/ng-select/ng-option-highlight.directive.js +0 -113
  90. package/esm5/ng-select/ng-option.component.js +0 -82
  91. package/esm5/ng-select/ng-select.component.js +0 -1430
  92. package/esm5/ng-select/ng-select.module.js +0 -65
  93. package/esm5/ng-select/ng-select.types.js +0 -49
  94. package/esm5/ng-select/search-helper.js +0 -859
  95. package/esm5/ng-select/value-utils.js +0 -34
  96. package/esm5/ng-select.js +0 -17
  97. package/fesm2015/ng-select.js +0 -3559
  98. package/fesm2015/ng-select.js.map +0 -1
  99. package/fesm5/ng-select.js +0 -4145
  100. package/fesm5/ng-select.js.map +0 -1
  101. package/index.d.ts +0 -5
  102. package/ng-select/ng-option-highlight.directive.d.ts +0 -14
  103. package/ng-select.d.ts +0 -11
  104. package/ng-select.metadata.json +0 -1
@@ -0,0 +1,770 @@
1
+ /**
2
+ * @fileoverview added by tsickle
3
+ * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
4
+ */
5
+ import * as tslib_1 from "tslib";
6
+ import { DOCUMENT } from '@angular/common';
7
+ import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, HostListener, Inject, Input, NgZone, Optional, Output, Renderer2, TemplateRef, ViewChild, ViewEncapsulation } from '@angular/core';
8
+ import { animationFrameScheduler, asapScheduler, fromEvent, merge, Subject } from 'rxjs';
9
+ import { auditTime, takeUntil } from 'rxjs/operators';
10
+ import { NgDropdownPanelService } from './ng-dropdown-panel.service';
11
+ import { isDefined } from './value-utils';
12
+ /** @type {?} */
13
+ var TOP_CSS_CLASS = 'ng-select-top';
14
+ /** @type {?} */
15
+ var BOTTOM_CSS_CLASS = 'ng-select-bottom';
16
+ /** @type {?} */
17
+ var SCROLL_SCHEDULER = typeof requestAnimationFrame !== 'undefined' ? animationFrameScheduler : asapScheduler;
18
+ var NgDropdownPanelComponent = /** @class */ (function () {
19
+ function NgDropdownPanelComponent(_renderer, _zone, _panelService, _elementRef, _document) {
20
+ this._renderer = _renderer;
21
+ this._zone = _zone;
22
+ this._panelService = _panelService;
23
+ this._document = _document;
24
+ this.items = [];
25
+ this.position = 'auto';
26
+ this.virtualScroll = false;
27
+ this.filterValue = null;
28
+ this.update = new EventEmitter();
29
+ this.scroll = new EventEmitter();
30
+ this.scrollToEnd = new EventEmitter();
31
+ this.outsideClick = new EventEmitter();
32
+ this._destroy$ = new Subject();
33
+ this._scrollToEndFired = false;
34
+ this._updateScrollHeight = false;
35
+ this._lastScrollPosition = 0;
36
+ this._dropdown = _elementRef.nativeElement;
37
+ }
38
+ Object.defineProperty(NgDropdownPanelComponent.prototype, "currentPosition", {
39
+ get: /**
40
+ * @return {?}
41
+ */
42
+ function () {
43
+ return this._currentPosition;
44
+ },
45
+ enumerable: true,
46
+ configurable: true
47
+ });
48
+ Object.defineProperty(NgDropdownPanelComponent.prototype, "itemsLength", {
49
+ get: /**
50
+ * @private
51
+ * @return {?}
52
+ */
53
+ function () {
54
+ return this._itemsLength;
55
+ },
56
+ set: /**
57
+ * @private
58
+ * @param {?} value
59
+ * @return {?}
60
+ */
61
+ function (value) {
62
+ if (value !== this._itemsLength) {
63
+ this._itemsLength = value;
64
+ this._onItemsLengthChanged();
65
+ }
66
+ },
67
+ enumerable: true,
68
+ configurable: true
69
+ });
70
+ /**
71
+ * @param {?} $event
72
+ * @return {?}
73
+ */
74
+ NgDropdownPanelComponent.prototype.handleMousedown = /**
75
+ * @param {?} $event
76
+ * @return {?}
77
+ */
78
+ function ($event) {
79
+ /** @type {?} */
80
+ var target = (/** @type {?} */ ($event.target));
81
+ if (target.tagName === 'INPUT') {
82
+ return;
83
+ }
84
+ $event.preventDefault();
85
+ };
86
+ /**
87
+ * @return {?}
88
+ */
89
+ NgDropdownPanelComponent.prototype.ngOnInit = /**
90
+ * @return {?}
91
+ */
92
+ function () {
93
+ this._select = this._dropdown.parentElement;
94
+ this._virtualPadding = this.paddingElementRef.nativeElement;
95
+ this._scrollablePanel = this.scrollElementRef.nativeElement;
96
+ this._contentPanel = this.contentElementRef.nativeElement;
97
+ this._handleScroll();
98
+ this._handleOutsideClick();
99
+ this._appendDropdown();
100
+ };
101
+ /**
102
+ * @param {?} changes
103
+ * @return {?}
104
+ */
105
+ NgDropdownPanelComponent.prototype.ngOnChanges = /**
106
+ * @param {?} changes
107
+ * @return {?}
108
+ */
109
+ function (changes) {
110
+ if (changes.items) {
111
+ /** @type {?} */
112
+ var change = changes.items;
113
+ this._onItemsChange(change.currentValue, change.firstChange);
114
+ }
115
+ };
116
+ /**
117
+ * @return {?}
118
+ */
119
+ NgDropdownPanelComponent.prototype.ngOnDestroy = /**
120
+ * @return {?}
121
+ */
122
+ function () {
123
+ this._destroy$.next();
124
+ this._destroy$.complete();
125
+ this._destroy$.unsubscribe();
126
+ if (this.appendTo) {
127
+ this._renderer.removeChild(this._dropdown.parentNode, this._dropdown);
128
+ }
129
+ };
130
+ /**
131
+ * @param {?} option
132
+ * @param {?=} startFromOption
133
+ * @return {?}
134
+ */
135
+ NgDropdownPanelComponent.prototype.scrollTo = /**
136
+ * @param {?} option
137
+ * @param {?=} startFromOption
138
+ * @return {?}
139
+ */
140
+ function (option, startFromOption) {
141
+ if (startFromOption === void 0) { startFromOption = false; }
142
+ if (!option) {
143
+ return;
144
+ }
145
+ /** @type {?} */
146
+ var index = this.items.indexOf(option);
147
+ if (index < 0 || index >= this.itemsLength) {
148
+ return;
149
+ }
150
+ /** @type {?} */
151
+ var scrollTo;
152
+ if (this.virtualScroll) {
153
+ /** @type {?} */
154
+ var itemHeight = this._panelService.dimensions.itemHeight;
155
+ scrollTo = this._panelService.getScrollTo(index * itemHeight, itemHeight, this._lastScrollPosition);
156
+ }
157
+ else {
158
+ /** @type {?} */
159
+ var item = this._dropdown.querySelector("#" + option.htmlId);
160
+ /** @type {?} */
161
+ var lastScroll = startFromOption ? item.offsetTop : this._lastScrollPosition;
162
+ scrollTo = this._panelService.getScrollTo(item.offsetTop, item.clientHeight, lastScroll);
163
+ }
164
+ if (isDefined(scrollTo)) {
165
+ this._scrollablePanel.scrollTop = scrollTo;
166
+ }
167
+ };
168
+ /**
169
+ * @return {?}
170
+ */
171
+ NgDropdownPanelComponent.prototype.scrollToTag = /**
172
+ * @return {?}
173
+ */
174
+ function () {
175
+ /** @type {?} */
176
+ var panel = this._scrollablePanel;
177
+ panel.scrollTop = panel.scrollHeight - panel.clientHeight;
178
+ };
179
+ /**
180
+ * @return {?}
181
+ */
182
+ NgDropdownPanelComponent.prototype.adjustPosition = /**
183
+ * @return {?}
184
+ */
185
+ function () {
186
+ /** @type {?} */
187
+ var parent = this._parent.getBoundingClientRect();
188
+ /** @type {?} */
189
+ var select = this._select.getBoundingClientRect();
190
+ this._setOffset(parent, select);
191
+ };
192
+ /**
193
+ * @private
194
+ * @return {?}
195
+ */
196
+ NgDropdownPanelComponent.prototype._handleDropdownPosition = /**
197
+ * @private
198
+ * @return {?}
199
+ */
200
+ function () {
201
+ this._currentPosition = this._calculateCurrentPosition(this._dropdown);
202
+ if (this._currentPosition === 'top') {
203
+ this._renderer.addClass(this._dropdown, TOP_CSS_CLASS);
204
+ this._renderer.removeClass(this._dropdown, BOTTOM_CSS_CLASS);
205
+ this._renderer.addClass(this._select, TOP_CSS_CLASS);
206
+ this._renderer.removeClass(this._select, BOTTOM_CSS_CLASS);
207
+ }
208
+ else {
209
+ this._renderer.addClass(this._dropdown, BOTTOM_CSS_CLASS);
210
+ this._renderer.removeClass(this._dropdown, TOP_CSS_CLASS);
211
+ this._renderer.addClass(this._select, BOTTOM_CSS_CLASS);
212
+ this._renderer.removeClass(this._select, TOP_CSS_CLASS);
213
+ }
214
+ if (this.appendTo) {
215
+ this._updatePosition();
216
+ }
217
+ this._dropdown.style.opacity = '1';
218
+ };
219
+ /**
220
+ * @private
221
+ * @return {?}
222
+ */
223
+ NgDropdownPanelComponent.prototype._handleScroll = /**
224
+ * @private
225
+ * @return {?}
226
+ */
227
+ function () {
228
+ var _this = this;
229
+ this._zone.runOutsideAngular((/**
230
+ * @return {?}
231
+ */
232
+ function () {
233
+ fromEvent(_this.scrollElementRef.nativeElement, 'scroll')
234
+ .pipe(takeUntil(_this._destroy$), auditTime(0, SCROLL_SCHEDULER))
235
+ .subscribe((/**
236
+ * @param {?} e
237
+ * @return {?}
238
+ */
239
+ function (e) { return _this._onContentScrolled(e.target.scrollTop); }));
240
+ }));
241
+ };
242
+ /**
243
+ * @private
244
+ * @return {?}
245
+ */
246
+ NgDropdownPanelComponent.prototype._handleOutsideClick = /**
247
+ * @private
248
+ * @return {?}
249
+ */
250
+ function () {
251
+ var _this = this;
252
+ if (!this._document) {
253
+ return;
254
+ }
255
+ this._zone.runOutsideAngular((/**
256
+ * @return {?}
257
+ */
258
+ function () {
259
+ merge(fromEvent(_this._document, 'touchstart', { capture: true }), fromEvent(_this._document, 'mousedown', { capture: true })).pipe(takeUntil(_this._destroy$))
260
+ .subscribe((/**
261
+ * @param {?} $event
262
+ * @return {?}
263
+ */
264
+ function ($event) { return _this._checkToClose($event); }));
265
+ }));
266
+ };
267
+ /**
268
+ * @private
269
+ * @param {?} $event
270
+ * @return {?}
271
+ */
272
+ NgDropdownPanelComponent.prototype._checkToClose = /**
273
+ * @private
274
+ * @param {?} $event
275
+ * @return {?}
276
+ */
277
+ function ($event) {
278
+ if (this._select.contains($event.target) || this._dropdown.contains($event.target)) {
279
+ return;
280
+ }
281
+ /** @type {?} */
282
+ var path = $event.path || ($event.composedPath && $event.composedPath());
283
+ if ($event.target && $event.target.shadowRoot && path && path[0] && this._select.contains(path[0])) {
284
+ return;
285
+ }
286
+ this.outsideClick.emit();
287
+ };
288
+ /**
289
+ * @private
290
+ * @param {?} items
291
+ * @param {?} firstChange
292
+ * @return {?}
293
+ */
294
+ NgDropdownPanelComponent.prototype._onItemsChange = /**
295
+ * @private
296
+ * @param {?} items
297
+ * @param {?} firstChange
298
+ * @return {?}
299
+ */
300
+ function (items, firstChange) {
301
+ this.items = items || [];
302
+ this._scrollToEndFired = false;
303
+ this.itemsLength = items.length;
304
+ if (this.virtualScroll) {
305
+ this._updateItemsRange(firstChange);
306
+ }
307
+ else {
308
+ this._updateItems(firstChange);
309
+ }
310
+ };
311
+ /**
312
+ * @private
313
+ * @param {?} firstChange
314
+ * @return {?}
315
+ */
316
+ NgDropdownPanelComponent.prototype._updateItems = /**
317
+ * @private
318
+ * @param {?} firstChange
319
+ * @return {?}
320
+ */
321
+ function (firstChange) {
322
+ var _this = this;
323
+ this.update.emit(this.items);
324
+ if (firstChange === false) {
325
+ return;
326
+ }
327
+ this._zone.runOutsideAngular((/**
328
+ * @return {?}
329
+ */
330
+ function () {
331
+ Promise.resolve().then((/**
332
+ * @return {?}
333
+ */
334
+ function () {
335
+ /** @type {?} */
336
+ var panelHeight = _this._scrollablePanel.clientHeight;
337
+ _this._panelService.setDimensions(0, panelHeight);
338
+ _this._handleDropdownPosition();
339
+ _this.scrollTo(_this.markedItem, firstChange);
340
+ }));
341
+ }));
342
+ };
343
+ /**
344
+ * @private
345
+ * @param {?} firstChange
346
+ * @return {?}
347
+ */
348
+ NgDropdownPanelComponent.prototype._updateItemsRange = /**
349
+ * @private
350
+ * @param {?} firstChange
351
+ * @return {?}
352
+ */
353
+ function (firstChange) {
354
+ var _this = this;
355
+ this._zone.runOutsideAngular((/**
356
+ * @return {?}
357
+ */
358
+ function () {
359
+ _this._measureDimensions().then((/**
360
+ * @return {?}
361
+ */
362
+ function () {
363
+ if (firstChange) {
364
+ _this._renderItemsRange(_this._startOffset);
365
+ _this._handleDropdownPosition();
366
+ }
367
+ else {
368
+ _this._renderItemsRange();
369
+ }
370
+ }));
371
+ }));
372
+ };
373
+ /**
374
+ * @private
375
+ * @param {?} scrollTop
376
+ * @return {?}
377
+ */
378
+ NgDropdownPanelComponent.prototype._onContentScrolled = /**
379
+ * @private
380
+ * @param {?} scrollTop
381
+ * @return {?}
382
+ */
383
+ function (scrollTop) {
384
+ if (this.virtualScroll) {
385
+ this._renderItemsRange(scrollTop);
386
+ }
387
+ this._lastScrollPosition = scrollTop;
388
+ this._fireScrollToEnd(scrollTop);
389
+ };
390
+ /**
391
+ * @private
392
+ * @param {?} height
393
+ * @return {?}
394
+ */
395
+ NgDropdownPanelComponent.prototype._updateVirtualHeight = /**
396
+ * @private
397
+ * @param {?} height
398
+ * @return {?}
399
+ */
400
+ function (height) {
401
+ if (this._updateScrollHeight) {
402
+ this._virtualPadding.style.height = height + "px";
403
+ this._updateScrollHeight = false;
404
+ }
405
+ };
406
+ /**
407
+ * @private
408
+ * @return {?}
409
+ */
410
+ NgDropdownPanelComponent.prototype._onItemsLengthChanged = /**
411
+ * @private
412
+ * @return {?}
413
+ */
414
+ function () {
415
+ this._updateScrollHeight = true;
416
+ };
417
+ Object.defineProperty(NgDropdownPanelComponent.prototype, "_startOffset", {
418
+ get: /**
419
+ * @private
420
+ * @return {?}
421
+ */
422
+ function () {
423
+ if (this.markedItem) {
424
+ return this.markedItem.index * this._panelService.dimensions.itemHeight;
425
+ }
426
+ return 0;
427
+ },
428
+ enumerable: true,
429
+ configurable: true
430
+ });
431
+ /**
432
+ * @private
433
+ * @param {?=} scrollTop
434
+ * @return {?}
435
+ */
436
+ NgDropdownPanelComponent.prototype._renderItemsRange = /**
437
+ * @private
438
+ * @param {?=} scrollTop
439
+ * @return {?}
440
+ */
441
+ function (scrollTop) {
442
+ var _this = this;
443
+ if (scrollTop === void 0) { scrollTop = null; }
444
+ if (scrollTop && this._lastScrollPosition === scrollTop) {
445
+ return;
446
+ }
447
+ scrollTop = scrollTop || this._scrollablePanel.scrollTop;
448
+ /** @type {?} */
449
+ var range = this._panelService.calculateItems(scrollTop, this.itemsLength, this.bufferAmount);
450
+ this._updateVirtualHeight(range.scrollHeight);
451
+ this._contentPanel.style.transform = "translateY(" + range.topPadding + "px)";
452
+ this._zone.run((/**
453
+ * @return {?}
454
+ */
455
+ function () {
456
+ _this.update.emit(_this.items.slice(range.start, range.end));
457
+ _this.scroll.emit({ start: range.start, end: range.end });
458
+ }));
459
+ if (isDefined(scrollTop) && this._lastScrollPosition === 0) {
460
+ this._scrollablePanel.scrollTop = scrollTop;
461
+ this._lastScrollPosition = scrollTop;
462
+ }
463
+ };
464
+ /**
465
+ * @private
466
+ * @return {?}
467
+ */
468
+ NgDropdownPanelComponent.prototype._measureDimensions = /**
469
+ * @private
470
+ * @return {?}
471
+ */
472
+ function () {
473
+ var _this = this;
474
+ if (this._panelService.dimensions.itemHeight > 0 || this.itemsLength === 0) {
475
+ return Promise.resolve(this._panelService.dimensions);
476
+ }
477
+ var _a = tslib_1.__read(this.items, 1), first = _a[0];
478
+ this.update.emit([first]);
479
+ return Promise.resolve().then((/**
480
+ * @return {?}
481
+ */
482
+ function () {
483
+ /** @type {?} */
484
+ var option = _this._dropdown.querySelector("#" + first.htmlId);
485
+ /** @type {?} */
486
+ var optionHeight = option.clientHeight;
487
+ _this._virtualPadding.style.height = optionHeight * _this.itemsLength + "px";
488
+ /** @type {?} */
489
+ var panelHeight = _this._scrollablePanel.clientHeight;
490
+ _this._panelService.setDimensions(optionHeight, panelHeight);
491
+ return _this._panelService.dimensions;
492
+ }));
493
+ };
494
+ /**
495
+ * @private
496
+ * @param {?} scrollTop
497
+ * @return {?}
498
+ */
499
+ NgDropdownPanelComponent.prototype._fireScrollToEnd = /**
500
+ * @private
501
+ * @param {?} scrollTop
502
+ * @return {?}
503
+ */
504
+ function (scrollTop) {
505
+ var _this = this;
506
+ if (this._scrollToEndFired || scrollTop === 0) {
507
+ return;
508
+ }
509
+ /** @type {?} */
510
+ var padding = this.virtualScroll ?
511
+ this._virtualPadding :
512
+ this._contentPanel;
513
+ if (scrollTop + this._dropdown.clientHeight >= padding.clientHeight) {
514
+ this._zone.run((/**
515
+ * @return {?}
516
+ */
517
+ function () { return _this.scrollToEnd.emit(); }));
518
+ this._scrollToEndFired = true;
519
+ }
520
+ };
521
+ /**
522
+ * @private
523
+ * @param {?} dropdownEl
524
+ * @return {?}
525
+ */
526
+ NgDropdownPanelComponent.prototype._calculateCurrentPosition = /**
527
+ * @private
528
+ * @param {?} dropdownEl
529
+ * @return {?}
530
+ */
531
+ function (dropdownEl) {
532
+ if (this.position !== 'auto') {
533
+ return this.position;
534
+ }
535
+ /** @type {?} */
536
+ var selectRect = this._select.getBoundingClientRect();
537
+ /** @type {?} */
538
+ var scrollTop = document.documentElement.scrollTop || document.body.scrollTop;
539
+ /** @type {?} */
540
+ var offsetTop = selectRect.top + window.pageYOffset;
541
+ /** @type {?} */
542
+ var height = selectRect.height;
543
+ /** @type {?} */
544
+ var dropdownHeight = dropdownEl.getBoundingClientRect().height;
545
+ if (offsetTop + height + dropdownHeight > scrollTop + document.documentElement.clientHeight) {
546
+ return 'top';
547
+ }
548
+ else {
549
+ return 'bottom';
550
+ }
551
+ };
552
+ /**
553
+ * @private
554
+ * @return {?}
555
+ */
556
+ NgDropdownPanelComponent.prototype._appendDropdown = /**
557
+ * @private
558
+ * @return {?}
559
+ */
560
+ function () {
561
+ if (!this.appendTo) {
562
+ return;
563
+ }
564
+ this._parent = document.querySelector(this.appendTo);
565
+ if (!parent) {
566
+ throw new Error("appendTo selector " + this.appendTo + " did not found any parent element");
567
+ }
568
+ this._parent.appendChild(this._dropdown);
569
+ };
570
+ /**
571
+ * @private
572
+ * @return {?}
573
+ */
574
+ NgDropdownPanelComponent.prototype._updatePosition = /**
575
+ * @private
576
+ * @return {?}
577
+ */
578
+ function () {
579
+ /** @type {?} */
580
+ var select = this._select.getBoundingClientRect();
581
+ /** @type {?} */
582
+ var parent = this._parent.getBoundingClientRect();
583
+ /** @type {?} */
584
+ var offsetLeft = select.left - parent.left;
585
+ this._setOffset(parent, select);
586
+ this._dropdown.style.left = offsetLeft + 'px';
587
+ this._dropdown.style.width = select.width + 'px';
588
+ this._dropdown.style.minWidth = select.width + 'px';
589
+ };
590
+ /**
591
+ * @private
592
+ * @param {?} parent
593
+ * @param {?} select
594
+ * @return {?}
595
+ */
596
+ NgDropdownPanelComponent.prototype._setOffset = /**
597
+ * @private
598
+ * @param {?} parent
599
+ * @param {?} select
600
+ * @return {?}
601
+ */
602
+ function (parent, select) {
603
+ /** @type {?} */
604
+ var delta = select.height;
605
+ if (this._currentPosition === 'top') {
606
+ /** @type {?} */
607
+ var offsetBottom = parent.bottom - select.bottom;
608
+ this._dropdown.style.bottom = offsetBottom + delta + 'px';
609
+ this._dropdown.style.top = 'auto';
610
+ }
611
+ else if (this._currentPosition === 'bottom') {
612
+ /** @type {?} */
613
+ var offsetTop = select.top - parent.top;
614
+ this._dropdown.style.top = offsetTop + delta + 'px';
615
+ this._dropdown.style.bottom = 'auto';
616
+ }
617
+ };
618
+ NgDropdownPanelComponent.decorators = [
619
+ { type: Component, args: [{
620
+ changeDetection: ChangeDetectionStrategy.OnPush,
621
+ encapsulation: ViewEncapsulation.None,
622
+ selector: 'ng-dropdown-panel',
623
+ template: "\n <div *ngIf=\"headerTemplate\" class=\"ng-dropdown-header\">\n <ng-container [ngTemplateOutlet]=\"headerTemplate\" [ngTemplateOutletContext]=\"{ searchTerm: filterValue }\"></ng-container>\n </div>\n <div #scroll class=\"ng-dropdown-panel-items scroll-host\">\n <div #padding [class.total-padding]=\"virtualScroll\"></div>\n <div #content [class.scrollable-content]=\"virtualScroll && items.length\">\n <ng-content></ng-content>\n </div>\n </div>\n <div *ngIf=\"footerTemplate\" class=\"ng-dropdown-footer\">\n <ng-container [ngTemplateOutlet]=\"footerTemplate\" [ngTemplateOutletContext]=\"{ searchTerm: filterValue }\"></ng-container>\n </div>\n "
624
+ }] }
625
+ ];
626
+ /** @nocollapse */
627
+ NgDropdownPanelComponent.ctorParameters = function () { return [
628
+ { type: Renderer2 },
629
+ { type: NgZone },
630
+ { type: NgDropdownPanelService },
631
+ { type: ElementRef },
632
+ { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [DOCUMENT,] }] }
633
+ ]; };
634
+ NgDropdownPanelComponent.propDecorators = {
635
+ items: [{ type: Input }],
636
+ markedItem: [{ type: Input }],
637
+ position: [{ type: Input }],
638
+ appendTo: [{ type: Input }],
639
+ bufferAmount: [{ type: Input }],
640
+ virtualScroll: [{ type: Input }],
641
+ headerTemplate: [{ type: Input }],
642
+ footerTemplate: [{ type: Input }],
643
+ filterValue: [{ type: Input }],
644
+ update: [{ type: Output }],
645
+ scroll: [{ type: Output }],
646
+ scrollToEnd: [{ type: Output }],
647
+ outsideClick: [{ type: Output }],
648
+ contentElementRef: [{ type: ViewChild, args: ['content', { read: ElementRef, static: true },] }],
649
+ scrollElementRef: [{ type: ViewChild, args: ['scroll', { read: ElementRef, static: true },] }],
650
+ paddingElementRef: [{ type: ViewChild, args: ['padding', { read: ElementRef, static: true },] }],
651
+ handleMousedown: [{ type: HostListener, args: ['mousedown', ['$event'],] }]
652
+ };
653
+ return NgDropdownPanelComponent;
654
+ }());
655
+ export { NgDropdownPanelComponent };
656
+ if (false) {
657
+ /** @type {?} */
658
+ NgDropdownPanelComponent.prototype.items;
659
+ /** @type {?} */
660
+ NgDropdownPanelComponent.prototype.markedItem;
661
+ /** @type {?} */
662
+ NgDropdownPanelComponent.prototype.position;
663
+ /** @type {?} */
664
+ NgDropdownPanelComponent.prototype.appendTo;
665
+ /** @type {?} */
666
+ NgDropdownPanelComponent.prototype.bufferAmount;
667
+ /** @type {?} */
668
+ NgDropdownPanelComponent.prototype.virtualScroll;
669
+ /** @type {?} */
670
+ NgDropdownPanelComponent.prototype.headerTemplate;
671
+ /** @type {?} */
672
+ NgDropdownPanelComponent.prototype.footerTemplate;
673
+ /** @type {?} */
674
+ NgDropdownPanelComponent.prototype.filterValue;
675
+ /** @type {?} */
676
+ NgDropdownPanelComponent.prototype.update;
677
+ /** @type {?} */
678
+ NgDropdownPanelComponent.prototype.scroll;
679
+ /** @type {?} */
680
+ NgDropdownPanelComponent.prototype.scrollToEnd;
681
+ /** @type {?} */
682
+ NgDropdownPanelComponent.prototype.outsideClick;
683
+ /** @type {?} */
684
+ NgDropdownPanelComponent.prototype.contentElementRef;
685
+ /** @type {?} */
686
+ NgDropdownPanelComponent.prototype.scrollElementRef;
687
+ /** @type {?} */
688
+ NgDropdownPanelComponent.prototype.paddingElementRef;
689
+ /**
690
+ * @type {?}
691
+ * @private
692
+ */
693
+ NgDropdownPanelComponent.prototype._destroy$;
694
+ /**
695
+ * @type {?}
696
+ * @private
697
+ */
698
+ NgDropdownPanelComponent.prototype._dropdown;
699
+ /**
700
+ * @type {?}
701
+ * @private
702
+ */
703
+ NgDropdownPanelComponent.prototype._virtualPadding;
704
+ /**
705
+ * @type {?}
706
+ * @private
707
+ */
708
+ NgDropdownPanelComponent.prototype._scrollablePanel;
709
+ /**
710
+ * @type {?}
711
+ * @private
712
+ */
713
+ NgDropdownPanelComponent.prototype._contentPanel;
714
+ /**
715
+ * @type {?}
716
+ * @private
717
+ */
718
+ NgDropdownPanelComponent.prototype._select;
719
+ /**
720
+ * @type {?}
721
+ * @private
722
+ */
723
+ NgDropdownPanelComponent.prototype._parent;
724
+ /**
725
+ * @type {?}
726
+ * @private
727
+ */
728
+ NgDropdownPanelComponent.prototype._scrollToEndFired;
729
+ /**
730
+ * @type {?}
731
+ * @private
732
+ */
733
+ NgDropdownPanelComponent.prototype._updateScrollHeight;
734
+ /**
735
+ * @type {?}
736
+ * @private
737
+ */
738
+ NgDropdownPanelComponent.prototype._lastScrollPosition;
739
+ /**
740
+ * @type {?}
741
+ * @private
742
+ */
743
+ NgDropdownPanelComponent.prototype._currentPosition;
744
+ /**
745
+ * @type {?}
746
+ * @private
747
+ */
748
+ NgDropdownPanelComponent.prototype._itemsLength;
749
+ /**
750
+ * @type {?}
751
+ * @private
752
+ */
753
+ NgDropdownPanelComponent.prototype._renderer;
754
+ /**
755
+ * @type {?}
756
+ * @private
757
+ */
758
+ NgDropdownPanelComponent.prototype._zone;
759
+ /**
760
+ * @type {?}
761
+ * @private
762
+ */
763
+ NgDropdownPanelComponent.prototype._panelService;
764
+ /**
765
+ * @type {?}
766
+ * @private
767
+ */
768
+ NgDropdownPanelComponent.prototype._document;
769
+ }
770
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng-dropdown-panel.component.js","sourceRoot":"ng://@ng-select/ng-select/","sources":["lib/ng-dropdown-panel.component.ts"],"names":[],"mappings":";;;;;AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,UAAU,EACV,YAAY,EACZ,YAAY,EACZ,MAAM,EACN,KAAK,EACL,MAAM,EAIN,QAAQ,EACR,MAAM,EACN,SAAS,EAET,WAAW,EACX,SAAS,EACT,iBAAiB,EACpB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,uBAAuB,EAAE,aAAa,EAAE,SAAS,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AACzF,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AACtD,OAAO,EAAE,sBAAsB,EAAmB,MAAM,6BAA6B,CAAC;AAItF,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;;IAEpC,aAAa,GAAG,eAAe;;IAC/B,gBAAgB,GAAG,kBAAkB;;IACrC,gBAAgB,GAAG,OAAO,qBAAqB,KAAK,WAAW,CAAC,CAAC,CAAC,uBAAuB,CAAC,CAAC,CAAC,aAAa;AAE/G;IAmDI,kCACY,SAAoB,EACpB,KAAa,EACb,aAAqC,EAC7C,WAAuB,EACe,SAAc;QAJ5C,cAAS,GAAT,SAAS,CAAW;QACpB,UAAK,GAAL,KAAK,CAAQ;QACb,kBAAa,GAAb,aAAa,CAAwB;QAEP,cAAS,GAAT,SAAS,CAAK;QAnC/C,UAAK,GAAe,EAAE,CAAC;QAEvB,aAAQ,GAAqB,MAAM,CAAC;QAGpC,kBAAa,GAAG,KAAK,CAAC;QAGtB,gBAAW,GAAW,IAAI,CAAC;QAE1B,WAAM,GAAG,IAAI,YAAY,EAAS,CAAC;QACnC,WAAM,GAAG,IAAI,YAAY,EAAkC,CAAC;QAC5D,gBAAW,GAAG,IAAI,YAAY,EAAQ,CAAC;QACvC,iBAAY,GAAG,IAAI,YAAY,EAAQ,CAAC;QAMjC,cAAS,GAAG,IAAI,OAAO,EAAQ,CAAC;QAOzC,sBAAiB,GAAG,KAAK,CAAC;QAC1B,wBAAmB,GAAG,KAAK,CAAC;QAC5B,wBAAmB,GAAG,CAAC,CAAC;QAS5B,IAAI,CAAC,SAAS,GAAG,WAAW,CAAC,aAAa,CAAC;IAC/C,CAAC;IAID,sBAAI,qDAAe;;;;QAAnB;YACI,OAAO,IAAI,CAAC,gBAAgB,CAAC;QACjC,CAAC;;;OAAA;IAID,sBAAY,iDAAW;;;;;QAAvB;YACI,OAAO,IAAI,CAAC,YAAY,CAAC;QAC7B,CAAC;;;;;;QAED,UAAwB,KAAa;YACjC,IAAI,KAAK,KAAK,IAAI,CAAC,YAAY,EAAE;gBAC7B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;gBAC1B,IAAI,CAAC,qBAAqB,EAAE,CAAC;aAChC;QACL,CAAC;;;OAPA;;;;;IAUD,kDAAe;;;;IADf,UACgB,MAAkB;;YACxB,MAAM,GAAG,mBAAA,MAAM,CAAC,MAAM,EAAe;QAC3C,IAAI,MAAM,CAAC,OAAO,KAAK,OAAO,EAAE;YAC5B,OAAO;SACV;QACD,MAAM,CAAC,cAAc,EAAE,CAAC;IAC5B,CAAC;;;;IAED,2CAAQ;;;IAAR;QACI,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC;QAC5C,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC;QAC5D,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC;QAC5D,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC;QAC1D,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC3B,IAAI,CAAC,eAAe,EAAE,CAAC;IAC3B,CAAC;;;;;IAED,8CAAW;;;;IAAX,UAAY,OAAsB;QAC9B,IAAI,OAAO,CAAC,KAAK,EAAE;;gBACT,MAAM,GAAG,OAAO,CAAC,KAAK;YAC5B,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,YAAY,EAAE,MAAM,CAAC,WAAW,CAAC,CAAC;SAChE;IACL,CAAC;;;;IAED,8CAAW;;;IAAX;QACI,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACtB,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;QAC1B,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC;QAC7B,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;SACzE;IACL,CAAC;;;;;;IAED,2CAAQ;;;;;IAAR,UAAS,MAAgB,EAAE,eAAuB;QAAvB,gCAAA,EAAA,uBAAuB;QAC9C,IAAI,CAAC,MAAM,EAAE;YACT,OAAO;SACV;;YAEK,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC;QACxC,IAAI,KAAK,GAAG,CAAC,IAAI,KAAK,IAAI,IAAI,CAAC,WAAW,EAAE;YACxC,OAAO;SACV;;YAEG,QAAQ;QACZ,IAAI,IAAI,CAAC,aAAa,EAAE;;gBACd,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,UAAU;YAC3D,QAAQ,GAAG,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,KAAK,GAAG,UAAU,EAAE,UAAU,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC;SACvG;aAAM;;gBACG,IAAI,GAAgB,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,MAAI,MAAM,CAAC,MAAQ,CAAC;;gBACrE,UAAU,GAAG,eAAe,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,mBAAmB;YAC9E,QAAQ,GAAG,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC;SAC5F;QAED,IAAI,SAAS,CAAC,QAAQ,CAAC,EAAE;YACrB,IAAI,CAAC,gBAAgB,CAAC,SAAS,GAAG,QAAQ,CAAC;SAC9C;IACL,CAAC;;;;IAED,8CAAW;;;IAAX;;YACU,KAAK,GAAG,IAAI,CAAC,gBAAgB;QACnC,KAAK,CAAC,SAAS,GAAG,KAAK,CAAC,YAAY,GAAG,KAAK,CAAC,YAAY,CAAC;IAC9D,CAAC;;;;IAED,iDAAc;;;IAAd;;YACU,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,qBAAqB,EAAE;;YAC7C,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,qBAAqB,EAAE;QACnD,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACpC,CAAC;;;;;IAEO,0DAAuB;;;;IAA/B;QACI,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACvE,IAAI,IAAI,CAAC,gBAAgB,KAAK,KAAK,EAAE;YACjC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,EAAE,aAAa,CAAC,CAAC;YACvD,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,EAAE,gBAAgB,CAAC,CAAC;YAC7D,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;YACrD,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,EAAE,gBAAgB,CAAC,CAAA;SAC7D;aAAM;YACH,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,EAAE,gBAAgB,CAAC,CAAC;YAC1D,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,EAAE,aAAa,CAAC,CAAC;YAC1D,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,gBAAgB,CAAC,CAAC;YACxD,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;SAC3D;QAED,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,IAAI,CAAC,eAAe,EAAE,CAAC;SAC1B;QAED,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,OAAO,GAAG,GAAG,CAAC;IACvC,CAAC;;;;;IAEO,gDAAa;;;;IAArB;QAAA,iBAMC;QALG,IAAI,CAAC,KAAK,CAAC,iBAAiB;;;QAAC;YACzB,SAAS,CAAC,KAAI,CAAC,gBAAgB,CAAC,aAAa,EAAE,QAAQ,CAAC;iBACnD,IAAI,CAAC,SAAS,CAAC,KAAI,CAAC,SAAS,CAAC,EAAE,SAAS,CAAC,CAAC,EAAE,gBAAgB,CAAC,CAAC;iBAC/D,SAAS;;;;YAAC,UAAC,CAA0B,IAAK,OAAA,KAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,EAA3C,CAA2C,EAAC,CAAC;QAChG,CAAC,EAAC,CAAC;IACP,CAAC;;;;;IAEO,sDAAmB;;;;IAA3B;QAAA,iBAYC;QAXG,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACjB,OAAO;SACV;QAED,IAAI,CAAC,KAAK,CAAC,iBAAiB;;;QAAC;YACzB,KAAK,CACD,SAAS,CAAC,KAAI,CAAC,SAAS,EAAE,YAAY,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,EAC1D,SAAS,CAAC,KAAI,CAAC,SAAS,EAAE,WAAW,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAC5D,CAAC,IAAI,CAAC,SAAS,CAAC,KAAI,CAAC,SAAS,CAAC,CAAC;iBAC/B,SAAS;;;;YAAC,UAAA,MAAM,IAAI,OAAA,KAAI,CAAC,aAAa,CAAC,MAAM,CAAC,EAA1B,CAA0B,EAAC,CAAC;QACtD,CAAC,EAAC,CAAC;IACP,CAAC;;;;;;IAEO,gDAAa;;;;;IAArB,UAAsB,MAAW;QAC7B,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE;YAChF,OAAO;SACV;;YAEK,IAAI,GAAG,MAAM,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,YAAY,IAAI,MAAM,CAAC,YAAY,EAAE,CAAC;QAC1E,IAAI,MAAM,CAAC,MAAM,IAAI,MAAM,CAAC,MAAM,CAAC,UAAU,IAAI,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE;YAChG,OAAO;SACV;QAED,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC7B,CAAC;;;;;;;IAEO,iDAAc;;;;;;IAAtB,UAAuB,KAAiB,EAAE,WAAoB;QAC1D,IAAI,CAAC,KAAK,GAAG,KAAK,IAAI,EAAE,CAAC;QACzB,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,MAAM,CAAC;QAEhC,IAAI,IAAI,CAAC,aAAa,EAAE;YACpB,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;SACvC;aAAM;YACH,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;SAClC;IACL,CAAC;;;;;;IAEO,+CAAY;;;;;IAApB,UAAqB,WAAoB;QAAzC,iBAcC;QAbG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC7B,IAAI,WAAW,KAAK,KAAK,EAAE;YACvB,OAAO;SACV;QAED,IAAI,CAAC,KAAK,CAAC,iBAAiB;;;QAAC;YACzB,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI;;;YAAC;;oBACb,WAAW,GAAG,KAAI,CAAC,gBAAgB,CAAC,YAAY;gBACtD,KAAI,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC,EAAE,WAAW,CAAC,CAAC;gBACjD,KAAI,CAAC,uBAAuB,EAAE,CAAC;gBAC/B,KAAI,CAAC,QAAQ,CAAC,KAAI,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC;YAChD,CAAC,EAAC,CAAC;QACP,CAAC,EAAC,CAAC;IACP,CAAC;;;;;;IAEO,oDAAiB;;;;;IAAzB,UAA0B,WAAoB;QAA9C,iBAWC;QAVG,IAAI,CAAC,KAAK,CAAC,iBAAiB;;;QAAC;YACzB,KAAI,CAAC,kBAAkB,EAAE,CAAC,IAAI;;;YAAC;gBAC3B,IAAI,WAAW,EAAE;oBACb,KAAI,CAAC,iBAAiB,CAAC,KAAI,CAAC,YAAY,CAAC,CAAC;oBAC1C,KAAI,CAAC,uBAAuB,EAAE,CAAC;iBAClC;qBAAM;oBACH,KAAI,CAAC,iBAAiB,EAAE,CAAC;iBAC5B;YACL,CAAC,EAAC,CAAC;QACP,CAAC,EAAC,CAAC;IACP,CAAC;;;;;;IAEO,qDAAkB;;;;;IAA1B,UAA2B,SAAiB;QACxC,IAAI,IAAI,CAAC,aAAa,EAAE;YACpB,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;SACrC;QACD,IAAI,CAAC,mBAAmB,GAAG,SAAS,CAAC;QACrC,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC;IACrC,CAAC;;;;;;IAEO,uDAAoB;;;;;IAA5B,UAA6B,MAAc;QACvC,IAAI,IAAI,CAAC,mBAAmB,EAAE;YAC1B,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,MAAM,GAAM,MAAM,OAAI,CAAC;YAClD,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;SACpC;IACL,CAAC;;;;;IAEO,wDAAqB;;;;IAA7B;QACI,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;IACpC,CAAC;IAED,sBAAY,kDAAY;;;;;QAAxB;YACI,IAAI,IAAI,CAAC,UAAU,EAAE;gBACjB,OAAO,IAAI,CAAC,UAAU,CAAC,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,UAAU,CAAC;aAC3E;YACD,OAAO,CAAC,CAAC;QACb,CAAC;;;OAAA;;;;;;IAEO,oDAAiB;;;;;IAAzB,UAA0B,SAAgB;QAA1C,iBAmBC;QAnByB,0BAAA,EAAA,gBAAgB;QACtC,IAAI,SAAS,IAAI,IAAI,CAAC,mBAAmB,KAAK,SAAS,EAAE;YACrD,OAAO;SACV;QAED,SAAS,GAAG,SAAS,IAAI,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC;;YACnD,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,SAAS,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,YAAY,CAAC;QAC/F,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;QAC9C,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,SAAS,GAAG,gBAAc,KAAK,CAAC,UAAU,QAAK,CAAC;QAEzE,IAAI,CAAC,KAAK,CAAC,GAAG;;;QAAC;YACX,KAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAI,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC;YAC3D,KAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,GAAG,EAAE,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC;QAC7D,CAAC,EAAC,CAAC;QAEH,IAAI,SAAS,CAAC,SAAS,CAAC,IAAI,IAAI,CAAC,mBAAmB,KAAK,CAAC,EAAE;YACxD,IAAI,CAAC,gBAAgB,CAAC,SAAS,GAAG,SAAS,CAAC;YAC5C,IAAI,CAAC,mBAAmB,GAAG,SAAS,CAAC;SACxC;IACL,CAAC;;;;;IAEO,qDAAkB;;;;IAA1B;QAAA,iBAiBC;QAhBG,IAAI,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,UAAU,GAAG,CAAC,IAAI,IAAI,CAAC,WAAW,KAAK,CAAC,EAAE;YACxE,OAAO,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;SACzD;QAEK,IAAA,kCAAoB,EAAnB,aAAmB;QAC1B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;QAE1B,OAAO,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI;;;QAAC;;gBACpB,MAAM,GAAG,KAAI,CAAC,SAAS,CAAC,aAAa,CAAC,MAAI,KAAK,CAAC,MAAQ,CAAC;;gBACzD,YAAY,GAAG,MAAM,CAAC,YAAY;YACxC,KAAI,CAAC,eAAe,CAAC,KAAK,CAAC,MAAM,GAAM,YAAY,GAAG,KAAI,CAAC,WAAW,OAAI,CAAC;;gBACrE,WAAW,GAAG,KAAI,CAAC,gBAAgB,CAAC,YAAY;YACtD,KAAI,CAAC,aAAa,CAAC,aAAa,CAAC,YAAY,EAAE,WAAW,CAAC,CAAC;YAE5D,OAAO,KAAI,CAAC,aAAa,CAAC,UAAU,CAAC;QACzC,CAAC,EAAC,CAAC;IACP,CAAC;;;;;;IAEO,mDAAgB;;;;;IAAxB,UAAyB,SAAiB;QAA1C,iBAaC;QAZG,IAAI,IAAI,CAAC,iBAAiB,IAAI,SAAS,KAAK,CAAC,EAAE;YAC3C,OAAO;SACV;;YAEK,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC;YAChC,IAAI,CAAC,eAAe,CAAC,CAAC;YACtB,IAAI,CAAC,aAAa;QAEtB,IAAI,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,IAAI,OAAO,CAAC,YAAY,EAAE;YACjE,IAAI,CAAC,KAAK,CAAC,GAAG;;;YAAC,cAAM,OAAA,KAAI,CAAC,WAAW,CAAC,IAAI,EAAE,EAAvB,CAAuB,EAAC,CAAC;YAC9C,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;SACjC;IACL,CAAC;;;;;;IAEO,4DAAyB;;;;;IAAjC,UAAkC,UAAuB;QACrD,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM,EAAE;YAC1B,OAAO,IAAI,CAAC,QAAQ,CAAC;SACxB;;YACK,UAAU,GAAe,IAAI,CAAC,OAAO,CAAC,qBAAqB,EAAE;;YAC7D,SAAS,GAAG,QAAQ,CAAC,eAAe,CAAC,SAAS,IAAI,QAAQ,CAAC,IAAI,CAAC,SAAS;;YACzE,SAAS,GAAG,UAAU,CAAC,GAAG,GAAG,MAAM,CAAC,WAAW;;YAC/C,MAAM,GAAG,UAAU,CAAC,MAAM;;YAC1B,cAAc,GAAG,UAAU,CAAC,qBAAqB,EAAE,CAAC,MAAM;QAChE,IAAI,SAAS,GAAG,MAAM,GAAG,cAAc,GAAG,SAAS,GAAG,QAAQ,CAAC,eAAe,CAAC,YAAY,EAAE;YACzF,OAAO,KAAK,CAAC;SAChB;aAAM;YACH,OAAO,QAAQ,CAAC;SACnB;IACL,CAAC;;;;;IAEO,kDAAe;;;;IAAvB;QACI,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAChB,OAAO;SACV;QAED,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACrD,IAAI,CAAC,MAAM,EAAE;YACT,MAAM,IAAI,KAAK,CAAC,uBAAqB,IAAI,CAAC,QAAQ,sCAAmC,CAAC,CAAC;SAC1F;QACD,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC7C,CAAC;;;;;IAEO,kDAAe;;;;IAAvB;;YACU,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,qBAAqB,EAAE;;YAC7C,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,qBAAqB,EAAE;;YAC7C,UAAU,GAAG,MAAM,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI;QAE5C,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;QAEhC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,GAAG,UAAU,GAAG,IAAI,CAAC;QAC9C,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC;QACjD,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,QAAQ,GAAG,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC;IACxD,CAAC;;;;;;;IAEO,6CAAU;;;;;;IAAlB,UAAmB,MAAkB,EAAE,MAAkB;;YAC/C,KAAK,GAAG,MAAM,CAAC,MAAM;QAE3B,IAAI,IAAI,CAAC,gBAAgB,KAAK,KAAK,EAAE;;gBAC3B,YAAY,GAAG,MAAM,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM;YAClD,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,MAAM,GAAG,YAAY,GAAG,KAAK,GAAG,IAAI,CAAC;YAC1D,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,GAAG,MAAM,CAAC;SACrC;aAAM,IAAI,IAAI,CAAC,gBAAgB,KAAK,QAAQ,EAAE;;gBACrC,SAAS,GAAG,MAAM,CAAC,GAAG,GAAG,MAAM,CAAC,GAAG;YACzC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,GAAG,SAAS,GAAG,KAAK,GAAG,IAAI,CAAC;YACpD,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;SACxC;IACL,CAAC;;gBA7XJ,SAAS,SAAC;oBACP,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,aAAa,EAAE,iBAAiB,CAAC,IAAI;oBACrC,QAAQ,EAAE,mBAAmB;oBAC7B,QAAQ,EAAE,+vBAaT;iBACJ;;;;gBApCG,SAAS;gBANT,MAAM;gBAcD,sBAAsB;gBAnB3B,UAAU;gDAqFL,QAAQ,YAAI,MAAM,SAAC,QAAQ;;;wBAnC/B,KAAK;6BACL,KAAK;2BACL,KAAK;2BACL,KAAK;+BACL,KAAK;gCACL,KAAK;iCACL,KAAK;iCACL,KAAK;8BACL,KAAK;yBAEL,MAAM;yBACN,MAAM;8BACN,MAAM;+BACN,MAAM;oCAEN,SAAS,SAAC,SAAS,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,IAAI,EAAE;mCACvD,SAAS,SAAC,QAAQ,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,IAAI,EAAE;oCACtD,SAAS,SAAC,SAAS,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,IAAI,EAAE;kCA0CvD,YAAY,SAAC,WAAW,EAAE,CAAC,QAAQ,CAAC;;IA8SzC,+BAAC;CAAA,AA9XD,IA8XC;SA3WY,wBAAwB;;;IAEjC,yCAAgC;;IAChC,8CAA8B;;IAC9B,4CAA6C;;IAC7C,4CAA0B;;IAC1B,gDAAsB;;IACtB,iDAA+B;;IAC/B,kDAA0C;;IAC1C,kDAA0C;;IAC1C,+CAAoC;;IAEpC,0CAA6C;;IAC7C,0CAAsE;;IACtE,+CAAiD;;IACjD,gDAAkD;;IAElD,qDAAwF;;IACxF,oDAAsF;;IACtF,qDAAwF;;;;;IAExF,6CAAiD;;;;;IACjD,6CAAwC;;;;;IACxC,mDAAqC;;;;;IACrC,oDAAsC;;;;;IACtC,iDAAmC;;;;;IACnC,2CAA6B;;;;;IAC7B,2CAA6B;;;;;IAC7B,qDAAkC;;;;;IAClC,uDAAoC;;;;;IACpC,uDAAgC;;;;;IAYhC,oDAA2C;;;;;IAM3C,gDAA6B;;;;;IAfzB,6CAA4B;;;;;IAC5B,yCAAqB;;;;;IACrB,iDAA6C;;;;;IAE7C,6CAAoD","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostListener,\n    Inject,\n    Input,\n    NgZone,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Output,\n    Renderer2,\n    SimpleChanges,\n    TemplateRef,\n    ViewChild,\n    ViewEncapsulation\n} from '@angular/core';\nimport { animationFrameScheduler, asapScheduler, fromEvent, merge, Subject } from 'rxjs';\nimport { auditTime, takeUntil } from 'rxjs/operators';\nimport { NgDropdownPanelService, PanelDimensions } from './ng-dropdown-panel.service';\n\nimport { DropdownPosition } from './ng-select.component';\nimport { NgOption } from './ng-select.types';\nimport { isDefined } from './value-utils';\n\nconst TOP_CSS_CLASS = 'ng-select-top';\nconst BOTTOM_CSS_CLASS = 'ng-select-bottom';\nconst SCROLL_SCHEDULER = typeof requestAnimationFrame !== 'undefined' ? animationFrameScheduler : asapScheduler;\n\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    selector: 'ng-dropdown-panel',\n    template: `\n        <div *ngIf=\"headerTemplate\" class=\"ng-dropdown-header\">\n            <ng-container [ngTemplateOutlet]=\"headerTemplate\" [ngTemplateOutletContext]=\"{ searchTerm: filterValue }\"></ng-container>\n        </div>\n        <div #scroll class=\"ng-dropdown-panel-items scroll-host\">\n            <div #padding [class.total-padding]=\"virtualScroll\"></div>\n            <div #content [class.scrollable-content]=\"virtualScroll && items.length\">\n                <ng-content></ng-content>\n            </div>\n        </div>\n        <div *ngIf=\"footerTemplate\" class=\"ng-dropdown-footer\">\n            <ng-container [ngTemplateOutlet]=\"footerTemplate\" [ngTemplateOutletContext]=\"{ searchTerm: filterValue }\"></ng-container>\n        </div>\n    `\n})\nexport class NgDropdownPanelComponent implements OnInit, OnChanges, OnDestroy {\n\n    @Input() items: NgOption[] = [];\n    @Input() markedItem: NgOption;\n    @Input() position: DropdownPosition = 'auto';\n    @Input() appendTo: string;\n    @Input() bufferAmount;\n    @Input() virtualScroll = false;\n    @Input() headerTemplate: TemplateRef<any>;\n    @Input() footerTemplate: TemplateRef<any>;\n    @Input() filterValue: string = null;\n\n    @Output() update = new EventEmitter<any[]>();\n    @Output() scroll = new EventEmitter<{ start: number; end: number }>();\n    @Output() scrollToEnd = new EventEmitter<void>();\n    @Output() outsideClick = new EventEmitter<void>();\n\n    @ViewChild('content', { read: ElementRef, static: true }) contentElementRef: ElementRef;\n    @ViewChild('scroll', { read: ElementRef, static: true }) scrollElementRef: ElementRef;\n    @ViewChild('padding', { read: ElementRef, static: true }) paddingElementRef: ElementRef;\n\n    private readonly _destroy$ = new Subject<void>();\n    private readonly _dropdown: HTMLElement;\n    private _virtualPadding: HTMLElement;\n    private _scrollablePanel: HTMLElement;\n    private _contentPanel: HTMLElement;\n    private _select: HTMLElement;\n    private _parent: HTMLElement;\n    private _scrollToEndFired = false;\n    private _updateScrollHeight = false;\n    private _lastScrollPosition = 0;\n\n    constructor(\n        private _renderer: Renderer2,\n        private _zone: NgZone,\n        private _panelService: NgDropdownPanelService,\n        _elementRef: ElementRef,\n        @Optional() @Inject(DOCUMENT) private _document: any\n    ) {\n        this._dropdown = _elementRef.nativeElement;\n    }\n\n    private _currentPosition: DropdownPosition;\n\n    get currentPosition(): DropdownPosition {\n        return this._currentPosition;\n    }\n\n    private _itemsLength: number;\n\n    private get itemsLength() {\n        return this._itemsLength;\n    }\n\n    private set itemsLength(value: number) {\n        if (value !== this._itemsLength) {\n            this._itemsLength = value;\n            this._onItemsLengthChanged();\n        }\n    }\n\n    @HostListener('mousedown', ['$event'])\n    handleMousedown($event: MouseEvent) {\n        const target = $event.target as HTMLElement;\n        if (target.tagName === 'INPUT') {\n            return;\n        }\n        $event.preventDefault();\n    }\n\n    ngOnInit() {\n        this._select = this._dropdown.parentElement;\n        this._virtualPadding = this.paddingElementRef.nativeElement;\n        this._scrollablePanel = this.scrollElementRef.nativeElement;\n        this._contentPanel = this.contentElementRef.nativeElement;\n        this._handleScroll();\n        this._handleOutsideClick();\n        this._appendDropdown();\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        if (changes.items) {\n            const change = changes.items;\n            this._onItemsChange(change.currentValue, change.firstChange);\n        }\n    }\n\n    ngOnDestroy() {\n        this._destroy$.next();\n        this._destroy$.complete();\n        this._destroy$.unsubscribe();\n        if (this.appendTo) {\n            this._renderer.removeChild(this._dropdown.parentNode, this._dropdown);\n        }\n    }\n\n    scrollTo(option: NgOption, startFromOption = false) {\n        if (!option) {\n            return;\n        }\n\n        const index = this.items.indexOf(option);\n        if (index < 0 || index >= this.itemsLength) {\n            return;\n        }\n\n        let scrollTo;\n        if (this.virtualScroll) {\n            const itemHeight = this._panelService.dimensions.itemHeight;\n            scrollTo = this._panelService.getScrollTo(index * itemHeight, itemHeight, this._lastScrollPosition);\n        } else {\n            const item: HTMLElement = this._dropdown.querySelector(`#${option.htmlId}`);\n            const lastScroll = startFromOption ? item.offsetTop : this._lastScrollPosition;\n            scrollTo = this._panelService.getScrollTo(item.offsetTop, item.clientHeight, lastScroll);\n        }\n\n        if (isDefined(scrollTo)) {\n            this._scrollablePanel.scrollTop = scrollTo;\n        }\n    }\n\n    scrollToTag() {\n        const panel = this._scrollablePanel;\n        panel.scrollTop = panel.scrollHeight - panel.clientHeight;\n    }\n\n    adjustPosition() {\n        const parent = this._parent.getBoundingClientRect();\n        const select = this._select.getBoundingClientRect();\n        this._setOffset(parent, select);\n    }\n\n    private _handleDropdownPosition() {\n        this._currentPosition = this._calculateCurrentPosition(this._dropdown);\n        if (this._currentPosition === 'top') {\n            this._renderer.addClass(this._dropdown, TOP_CSS_CLASS);\n            this._renderer.removeClass(this._dropdown, BOTTOM_CSS_CLASS);\n            this._renderer.addClass(this._select, TOP_CSS_CLASS);\n            this._renderer.removeClass(this._select, BOTTOM_CSS_CLASS)\n        } else {\n            this._renderer.addClass(this._dropdown, BOTTOM_CSS_CLASS);\n            this._renderer.removeClass(this._dropdown, TOP_CSS_CLASS);\n            this._renderer.addClass(this._select, BOTTOM_CSS_CLASS);\n            this._renderer.removeClass(this._select, TOP_CSS_CLASS);\n        }\n\n        if (this.appendTo) {\n            this._updatePosition();\n        }\n\n        this._dropdown.style.opacity = '1';\n    }\n\n    private _handleScroll() {\n        this._zone.runOutsideAngular(() => {\n            fromEvent(this.scrollElementRef.nativeElement, 'scroll')\n                .pipe(takeUntil(this._destroy$), auditTime(0, SCROLL_SCHEDULER))\n                .subscribe((e: { target: HTMLElement }) => this._onContentScrolled(e.target.scrollTop));\n        });\n    }\n\n    private _handleOutsideClick() {\n        if (!this._document) {\n            return;\n        }\n\n        this._zone.runOutsideAngular(() => {\n            merge(\n                fromEvent(this._document, 'touchstart', { capture: true }),\n                fromEvent(this._document, 'mousedown', { capture: true })\n            ).pipe(takeUntil(this._destroy$))\n             .subscribe($event => this._checkToClose($event));\n        });\n    }\n\n    private _checkToClose($event: any) {\n        if (this._select.contains($event.target) || this._dropdown.contains($event.target)) {\n            return;\n        }\n\n        const path = $event.path || ($event.composedPath && $event.composedPath());\n        if ($event.target && $event.target.shadowRoot && path && path[0] && this._select.contains(path[0])) {\n            return;\n        }\n\n        this.outsideClick.emit();\n    }\n\n    private _onItemsChange(items: NgOption[], firstChange: boolean) {\n        this.items = items || [];\n        this._scrollToEndFired = false;\n        this.itemsLength = items.length;\n\n        if (this.virtualScroll) {\n            this._updateItemsRange(firstChange);\n        } else {\n            this._updateItems(firstChange);\n        }\n    }\n\n    private _updateItems(firstChange: boolean) {\n        this.update.emit(this.items);\n        if (firstChange === false) {\n            return;\n        }\n\n        this._zone.runOutsideAngular(() => {\n            Promise.resolve().then(() => {\n                const panelHeight = this._scrollablePanel.clientHeight;\n                this._panelService.setDimensions(0, panelHeight);\n                this._handleDropdownPosition();\n                this.scrollTo(this.markedItem, firstChange);\n            });\n        });\n    }\n\n    private _updateItemsRange(firstChange: boolean) {\n        this._zone.runOutsideAngular(() => {\n            this._measureDimensions().then(() => {\n                if (firstChange) {\n                    this._renderItemsRange(this._startOffset);\n                    this._handleDropdownPosition();\n                } else {\n                    this._renderItemsRange();\n                }\n            });\n        });\n    }\n\n    private _onContentScrolled(scrollTop: number) {\n        if (this.virtualScroll) {\n            this._renderItemsRange(scrollTop);\n        }\n        this._lastScrollPosition = scrollTop;\n        this._fireScrollToEnd(scrollTop);\n    }\n\n    private _updateVirtualHeight(height: number) {\n        if (this._updateScrollHeight) {\n            this._virtualPadding.style.height = `${height}px`;\n            this._updateScrollHeight = false;\n        }\n    }\n\n    private _onItemsLengthChanged() {\n        this._updateScrollHeight = true;\n    }\n\n    private get _startOffset() {\n        if (this.markedItem) {\n            return this.markedItem.index * this._panelService.dimensions.itemHeight;\n        }\n        return 0;\n    }\n\n    private _renderItemsRange(scrollTop = null) {\n        if (scrollTop && this._lastScrollPosition === scrollTop) {\n            return;\n        }\n\n        scrollTop = scrollTop || this._scrollablePanel.scrollTop;\n        const range = this._panelService.calculateItems(scrollTop, this.itemsLength, this.bufferAmount);\n        this._updateVirtualHeight(range.scrollHeight);\n        this._contentPanel.style.transform = `translateY(${range.topPadding}px)`;\n\n        this._zone.run(() => {\n            this.update.emit(this.items.slice(range.start, range.end));\n            this.scroll.emit({ start: range.start, end: range.end });\n        });\n\n        if (isDefined(scrollTop) && this._lastScrollPosition === 0) {\n            this._scrollablePanel.scrollTop = scrollTop;\n            this._lastScrollPosition = scrollTop;\n        }\n    }\n\n    private _measureDimensions(): Promise<PanelDimensions> {\n        if (this._panelService.dimensions.itemHeight > 0 || this.itemsLength === 0) {\n            return Promise.resolve(this._panelService.dimensions);\n        }\n\n        const [first] = this.items;\n        this.update.emit([first]);\n\n        return Promise.resolve().then(() => {\n            const option = this._dropdown.querySelector(`#${first.htmlId}`);\n            const optionHeight = option.clientHeight;\n            this._virtualPadding.style.height = `${optionHeight * this.itemsLength}px`;\n            const panelHeight = this._scrollablePanel.clientHeight;\n            this._panelService.setDimensions(optionHeight, panelHeight);\n\n            return this._panelService.dimensions;\n        });\n    }\n\n    private _fireScrollToEnd(scrollTop: number) {\n        if (this._scrollToEndFired || scrollTop === 0) {\n            return;\n        }\n\n        const padding = this.virtualScroll ?\n            this._virtualPadding :\n            this._contentPanel;\n\n        if (scrollTop + this._dropdown.clientHeight >= padding.clientHeight) {\n            this._zone.run(() => this.scrollToEnd.emit());\n            this._scrollToEndFired = true;\n        }\n    }\n\n    private _calculateCurrentPosition(dropdownEl: HTMLElement) {\n        if (this.position !== 'auto') {\n            return this.position;\n        }\n        const selectRect: ClientRect = this._select.getBoundingClientRect();\n        const scrollTop = document.documentElement.scrollTop || document.body.scrollTop;\n        const offsetTop = selectRect.top + window.pageYOffset;\n        const height = selectRect.height;\n        const dropdownHeight = dropdownEl.getBoundingClientRect().height;\n        if (offsetTop + height + dropdownHeight > scrollTop + document.documentElement.clientHeight) {\n            return 'top';\n        } else {\n            return 'bottom';\n        }\n    }\n\n    private _appendDropdown() {\n        if (!this.appendTo) {\n            return;\n        }\n\n        this._parent = document.querySelector(this.appendTo);\n        if (!parent) {\n            throw new Error(`appendTo selector ${this.appendTo} did not found any parent element`);\n        }\n        this._parent.appendChild(this._dropdown);\n    }\n\n    private _updatePosition() {\n        const select = this._select.getBoundingClientRect();\n        const parent = this._parent.getBoundingClientRect();\n        const offsetLeft = select.left - parent.left;\n\n        this._setOffset(parent, select);\n\n        this._dropdown.style.left = offsetLeft + 'px';\n        this._dropdown.style.width = select.width + 'px';\n        this._dropdown.style.minWidth = select.width + 'px';\n    }\n\n    private _setOffset(parent: ClientRect, select: ClientRect) {\n        const delta = select.height;\n\n        if (this._currentPosition === 'top') {\n            const offsetBottom = parent.bottom - select.bottom;\n            this._dropdown.style.bottom = offsetBottom + delta + 'px';\n            this._dropdown.style.top = 'auto';\n        } else if (this._currentPosition === 'bottom') {\n            const offsetTop = select.top - parent.top;\n            this._dropdown.style.top = offsetTop + delta + 'px';\n            this._dropdown.style.bottom = 'auto';\n        }\n    }\n}\n"]}