@ng-select/ng-select 2.20.5 → 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 -545
  71. package/esm2015/ng-select/ng-dropdown-panel.component.js +0 -559
  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 -764
  87. package/esm5/ng-select/ng-dropdown-panel.component.js +0 -651
  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
@@ -1,559 +0,0 @@
1
- /**
2
- * @fileoverview added by tsickle
3
- * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
4
- */
5
- import { DOCUMENT } from '@angular/common';
6
- import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, HostListener, Inject, Input, NgZone, Optional, Output, Renderer2, TemplateRef, ViewChild, ViewEncapsulation } from '@angular/core';
7
- import { animationFrameScheduler, asapScheduler, fromEvent, merge, Subject } from 'rxjs';
8
- import { auditTime, takeUntil } from 'rxjs/operators';
9
- import { NgDropdownPanelService } from './ng-dropdown-panel.service';
10
- import { isDefined } from './value-utils';
11
- /** @type {?} */
12
- const TOP_CSS_CLASS = 'ng-select-top';
13
- /** @type {?} */
14
- const BOTTOM_CSS_CLASS = 'ng-select-bottom';
15
- /** @type {?} */
16
- const SCROLL_SCHEDULER = typeof requestAnimationFrame !== 'undefined' ? animationFrameScheduler : asapScheduler;
17
- export class NgDropdownPanelComponent {
18
- /**
19
- * @param {?} _renderer
20
- * @param {?} _zone
21
- * @param {?} _panelService
22
- * @param {?} _elementRef
23
- * @param {?} _document
24
- */
25
- constructor(_renderer, _zone, _panelService, _elementRef, _document) {
26
- this._renderer = _renderer;
27
- this._zone = _zone;
28
- this._panelService = _panelService;
29
- this._document = _document;
30
- this.items = [];
31
- this.position = 'auto';
32
- this.virtualScroll = false;
33
- this.filterValue = null;
34
- this.update = new EventEmitter();
35
- this.scroll = new EventEmitter();
36
- this.scrollToEnd = new EventEmitter();
37
- this.outsideClick = new EventEmitter();
38
- this._destroy$ = new Subject();
39
- this._scrollToEndFired = false;
40
- this._updateScrollHeight = false;
41
- this._lastScrollPosition = 0;
42
- this._dropdown = _elementRef.nativeElement;
43
- }
44
- /**
45
- * @return {?}
46
- */
47
- get currentPosition() {
48
- return this._currentPosition;
49
- }
50
- /**
51
- * @return {?}
52
- */
53
- get itemsLength() {
54
- return this._itemsLength;
55
- }
56
- /**
57
- * @param {?} value
58
- * @return {?}
59
- */
60
- set itemsLength(value) {
61
- if (value !== this._itemsLength) {
62
- this._itemsLength = value;
63
- this._onItemsLengthChanged();
64
- }
65
- }
66
- /**
67
- * @param {?} $event
68
- * @return {?}
69
- */
70
- handleMousedown($event) {
71
- /** @type {?} */
72
- const target = /** @type {?} */ ($event.target);
73
- if (target.tagName === 'INPUT') {
74
- return;
75
- }
76
- $event.preventDefault();
77
- }
78
- /**
79
- * @return {?}
80
- */
81
- ngOnInit() {
82
- this._select = this._dropdown.parentElement;
83
- this._virtualPadding = this.paddingElementRef.nativeElement;
84
- this._scrollablePanel = this.scrollElementRef.nativeElement;
85
- this._contentPanel = this.contentElementRef.nativeElement;
86
- this._handleScroll();
87
- this._handleOutsideClick();
88
- this._appendDropdown();
89
- }
90
- /**
91
- * @param {?} changes
92
- * @return {?}
93
- */
94
- ngOnChanges(changes) {
95
- if (changes["items"]) {
96
- /** @type {?} */
97
- const change = changes["items"];
98
- this._onItemsChange(change.currentValue, change.firstChange);
99
- }
100
- }
101
- /**
102
- * @return {?}
103
- */
104
- ngOnDestroy() {
105
- this._destroy$.next();
106
- this._destroy$.complete();
107
- this._destroy$.unsubscribe();
108
- if (this.appendTo) {
109
- this._renderer.removeChild(this._dropdown.parentNode, this._dropdown);
110
- }
111
- }
112
- /**
113
- * @param {?} option
114
- * @param {?=} startFromOption
115
- * @return {?}
116
- */
117
- scrollTo(option, startFromOption = false) {
118
- if (!option) {
119
- return;
120
- }
121
- /** @type {?} */
122
- const index = this.items.indexOf(option);
123
- if (index < 0 || index >= this.itemsLength) {
124
- return;
125
- }
126
- /** @type {?} */
127
- let scrollTo;
128
- if (this.virtualScroll) {
129
- /** @type {?} */
130
- const itemHeight = this._panelService.dimensions.itemHeight;
131
- scrollTo = this._panelService.getScrollTo(index * itemHeight, itemHeight, this._lastScrollPosition);
132
- }
133
- else {
134
- /** @type {?} */
135
- const item = this._dropdown.querySelector(`#${option.htmlId}`);
136
- /** @type {?} */
137
- const lastScroll = startFromOption ? item.offsetTop : this._lastScrollPosition;
138
- scrollTo = this._panelService.getScrollTo(item.offsetTop, item.clientHeight, lastScroll);
139
- }
140
- if (isDefined(scrollTo)) {
141
- this._scrollablePanel.scrollTop = scrollTo;
142
- }
143
- }
144
- /**
145
- * @return {?}
146
- */
147
- scrollToTag() {
148
- /** @type {?} */
149
- const panel = this._scrollablePanel;
150
- panel.scrollTop = panel.scrollHeight - panel.clientHeight;
151
- }
152
- /**
153
- * @return {?}
154
- */
155
- adjustPosition() {
156
- /** @type {?} */
157
- const parent = this._parent.getBoundingClientRect();
158
- /** @type {?} */
159
- const select = this._select.getBoundingClientRect();
160
- this._setOffset(parent, select);
161
- }
162
- /**
163
- * @return {?}
164
- */
165
- _handleDropdownPosition() {
166
- this._currentPosition = this._calculateCurrentPosition(this._dropdown);
167
- if (this._currentPosition === 'top') {
168
- this._renderer.addClass(this._dropdown, TOP_CSS_CLASS);
169
- this._renderer.removeClass(this._dropdown, BOTTOM_CSS_CLASS);
170
- this._renderer.addClass(this._select, TOP_CSS_CLASS);
171
- this._renderer.removeClass(this._select, BOTTOM_CSS_CLASS);
172
- }
173
- else {
174
- this._renderer.addClass(this._dropdown, BOTTOM_CSS_CLASS);
175
- this._renderer.removeClass(this._dropdown, TOP_CSS_CLASS);
176
- this._renderer.addClass(this._select, BOTTOM_CSS_CLASS);
177
- this._renderer.removeClass(this._select, TOP_CSS_CLASS);
178
- }
179
- if (this.appendTo) {
180
- this._updatePosition();
181
- }
182
- this._dropdown.style.opacity = '1';
183
- }
184
- /**
185
- * @return {?}
186
- */
187
- _handleScroll() {
188
- this._zone.runOutsideAngular(() => {
189
- fromEvent(this.scrollElementRef.nativeElement, 'scroll')
190
- .pipe(takeUntil(this._destroy$), auditTime(0, SCROLL_SCHEDULER))
191
- .subscribe((e) => this._onContentScrolled(e.srcElement.scrollTop));
192
- });
193
- }
194
- /**
195
- * @return {?}
196
- */
197
- _handleOutsideClick() {
198
- if (!this._document) {
199
- return;
200
- }
201
- this._zone.runOutsideAngular(() => {
202
- merge(fromEvent(this._document, 'touchstart', { capture: true }), fromEvent(this._document, 'mousedown', { capture: true })).pipe(takeUntil(this._destroy$))
203
- .subscribe($event => this._checkToClose($event));
204
- });
205
- }
206
- /**
207
- * @param {?} $event
208
- * @return {?}
209
- */
210
- _checkToClose($event) {
211
- if (this._select.contains($event.target) || this._dropdown.contains($event.target)) {
212
- return;
213
- }
214
- /** @type {?} */
215
- const path = $event.path || ($event.composedPath && $event.composedPath());
216
- if ($event.target && $event.target.shadowRoot && path && path[0] && this._select.contains(path[0])) {
217
- return;
218
- }
219
- this.outsideClick.emit();
220
- }
221
- /**
222
- * @param {?} items
223
- * @param {?} firstChange
224
- * @return {?}
225
- */
226
- _onItemsChange(items, firstChange) {
227
- this.items = items || [];
228
- this._scrollToEndFired = false;
229
- this.itemsLength = items.length;
230
- if (this.virtualScroll) {
231
- this._updateItemsRange(firstChange);
232
- }
233
- else {
234
- this._updateItems(firstChange);
235
- }
236
- }
237
- /**
238
- * @param {?} firstChange
239
- * @return {?}
240
- */
241
- _updateItems(firstChange) {
242
- this.update.emit(this.items);
243
- if (firstChange === false) {
244
- return;
245
- }
246
- this._zone.runOutsideAngular(() => {
247
- Promise.resolve().then(() => {
248
- /** @type {?} */
249
- const panelHeight = this._scrollablePanel.clientHeight;
250
- this._panelService.setDimensions(0, panelHeight);
251
- this._handleDropdownPosition();
252
- this.scrollTo(this.markedItem, firstChange);
253
- });
254
- });
255
- }
256
- /**
257
- * @param {?} firstChange
258
- * @return {?}
259
- */
260
- _updateItemsRange(firstChange) {
261
- this._zone.runOutsideAngular(() => {
262
- this._measureDimensions().then(() => {
263
- if (firstChange) {
264
- this._renderItemsRange(this._startOffset);
265
- this._handleDropdownPosition();
266
- }
267
- else {
268
- this._renderItemsRange();
269
- }
270
- });
271
- });
272
- }
273
- /**
274
- * @param {?} scrollTop
275
- * @return {?}
276
- */
277
- _onContentScrolled(scrollTop) {
278
- if (this.virtualScroll) {
279
- this._renderItemsRange(scrollTop);
280
- }
281
- this._lastScrollPosition = scrollTop;
282
- this._fireScrollToEnd(scrollTop);
283
- }
284
- /**
285
- * @param {?} height
286
- * @return {?}
287
- */
288
- _updateVirtualHeight(height) {
289
- if (this._updateScrollHeight) {
290
- this._virtualPadding.style.height = `${height}px`;
291
- this._updateScrollHeight = false;
292
- }
293
- }
294
- /**
295
- * @return {?}
296
- */
297
- _onItemsLengthChanged() {
298
- this._updateScrollHeight = true;
299
- }
300
- /**
301
- * @return {?}
302
- */
303
- get _startOffset() {
304
- if (this.markedItem) {
305
- return this.markedItem.index * this._panelService.dimensions.itemHeight;
306
- }
307
- return 0;
308
- }
309
- /**
310
- * @param {?=} scrollTop
311
- * @return {?}
312
- */
313
- _renderItemsRange(scrollTop = null) {
314
- if (scrollTop && this._lastScrollPosition === scrollTop) {
315
- return;
316
- }
317
- scrollTop = scrollTop || this._scrollablePanel.scrollTop;
318
- /** @type {?} */
319
- const range = this._panelService.calculateItems(scrollTop, this.itemsLength, this.bufferAmount);
320
- this._updateVirtualHeight(range.scrollHeight);
321
- this._contentPanel.style.transform = `translateY(${range.topPadding}px)`;
322
- this._zone.run(() => {
323
- this.update.emit(this.items.slice(range.start, range.end));
324
- this.scroll.emit({ start: range.start, end: range.end });
325
- });
326
- if (isDefined(scrollTop) && this._lastScrollPosition === 0) {
327
- this._scrollablePanel.scrollTop = scrollTop;
328
- this._lastScrollPosition = scrollTop;
329
- }
330
- }
331
- /**
332
- * @return {?}
333
- */
334
- _measureDimensions() {
335
- if (this._panelService.dimensions.itemHeight > 0 || this.itemsLength === 0) {
336
- return Promise.resolve(this._panelService.dimensions);
337
- }
338
- const [first] = this.items;
339
- this.update.emit([first]);
340
- return Promise.resolve().then(() => {
341
- /** @type {?} */
342
- const option = this._dropdown.querySelector(`#${first.htmlId}`);
343
- /** @type {?} */
344
- const optionHeight = option.clientHeight;
345
- this._virtualPadding.style.height = `${optionHeight * this.itemsLength}px`;
346
- /** @type {?} */
347
- const panelHeight = this._scrollablePanel.clientHeight;
348
- this._panelService.setDimensions(optionHeight, panelHeight);
349
- return this._panelService.dimensions;
350
- });
351
- }
352
- /**
353
- * @param {?} scrollTop
354
- * @return {?}
355
- */
356
- _fireScrollToEnd(scrollTop) {
357
- if (this._scrollToEndFired || scrollTop === 0) {
358
- return;
359
- }
360
- /** @type {?} */
361
- const padding = this.virtualScroll ?
362
- this._virtualPadding :
363
- this._contentPanel;
364
- if (scrollTop + this._dropdown.clientHeight >= padding.clientHeight) {
365
- this._zone.run(() => this.scrollToEnd.emit());
366
- this._scrollToEndFired = true;
367
- }
368
- }
369
- /**
370
- * @param {?} dropdownEl
371
- * @return {?}
372
- */
373
- _calculateCurrentPosition(dropdownEl) {
374
- if (this.position !== 'auto') {
375
- return this.position;
376
- }
377
- /** @type {?} */
378
- const selectRect = this._select.getBoundingClientRect();
379
- /** @type {?} */
380
- const scrollTop = document.documentElement.scrollTop || document.body.scrollTop;
381
- /** @type {?} */
382
- const offsetTop = selectRect.top + window.pageYOffset;
383
- /** @type {?} */
384
- const height = selectRect.height;
385
- /** @type {?} */
386
- const dropdownHeight = dropdownEl.getBoundingClientRect().height;
387
- if (offsetTop + height + dropdownHeight > scrollTop + document.documentElement.clientHeight) {
388
- return 'top';
389
- }
390
- else {
391
- return 'bottom';
392
- }
393
- }
394
- /**
395
- * @return {?}
396
- */
397
- _appendDropdown() {
398
- if (!this.appendTo) {
399
- return;
400
- }
401
- this._parent = document.querySelector(this.appendTo);
402
- if (!parent) {
403
- throw new Error(`appendTo selector ${this.appendTo} did not found any parent element`);
404
- }
405
- this._parent.appendChild(this._dropdown);
406
- }
407
- /**
408
- * @return {?}
409
- */
410
- _updatePosition() {
411
- /** @type {?} */
412
- const select = this._select.getBoundingClientRect();
413
- /** @type {?} */
414
- const parent = this._parent.getBoundingClientRect();
415
- /** @type {?} */
416
- const offsetLeft = select.left - parent.left;
417
- this._setOffset(parent, select);
418
- this._dropdown.style.left = offsetLeft + 'px';
419
- this._dropdown.style.width = select.width + 'px';
420
- this._dropdown.style.minWidth = select.width + 'px';
421
- }
422
- /**
423
- * @param {?} parent
424
- * @param {?} select
425
- * @return {?}
426
- */
427
- _setOffset(parent, select) {
428
- /** @type {?} */
429
- const delta = select.height;
430
- if (this._currentPosition === 'top') {
431
- /** @type {?} */
432
- const offsetBottom = parent.bottom - select.bottom;
433
- this._dropdown.style.bottom = offsetBottom + delta + 'px';
434
- this._dropdown.style.top = 'auto';
435
- }
436
- else if (this._currentPosition === 'bottom') {
437
- /** @type {?} */
438
- const offsetTop = select.top - parent.top;
439
- this._dropdown.style.top = offsetTop + delta + 'px';
440
- this._dropdown.style.bottom = 'auto';
441
- }
442
- }
443
- }
444
- NgDropdownPanelComponent.decorators = [
445
- { type: Component, args: [{
446
- changeDetection: ChangeDetectionStrategy.OnPush,
447
- encapsulation: ViewEncapsulation.None,
448
- selector: 'ng-dropdown-panel',
449
- template: `
450
- <div *ngIf="headerTemplate" class="ng-dropdown-header">
451
- <ng-container [ngTemplateOutlet]="headerTemplate" [ngTemplateOutletContext]="{ searchTerm: filterValue }"></ng-container>
452
- </div>
453
- <div #scroll class="ng-dropdown-panel-items scroll-host">
454
- <div #padding [class.total-padding]="virtualScroll"></div>
455
- <div #content [class.scrollable-content]="virtualScroll && items.length">
456
- <ng-content></ng-content>
457
- </div>
458
- </div>
459
- <div *ngIf="footerTemplate" class="ng-dropdown-footer">
460
- <ng-container [ngTemplateOutlet]="footerTemplate" [ngTemplateOutletContext]="{ searchTerm: filterValue }"></ng-container>
461
- </div>
462
- `
463
- }] }
464
- ];
465
- /** @nocollapse */
466
- NgDropdownPanelComponent.ctorParameters = () => [
467
- { type: Renderer2 },
468
- { type: NgZone },
469
- { type: NgDropdownPanelService },
470
- { type: ElementRef },
471
- { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [DOCUMENT,] }] }
472
- ];
473
- NgDropdownPanelComponent.propDecorators = {
474
- items: [{ type: Input }],
475
- markedItem: [{ type: Input }],
476
- position: [{ type: Input }],
477
- appendTo: [{ type: Input }],
478
- bufferAmount: [{ type: Input }],
479
- virtualScroll: [{ type: Input }],
480
- headerTemplate: [{ type: Input }],
481
- footerTemplate: [{ type: Input }],
482
- filterValue: [{ type: Input }],
483
- update: [{ type: Output }],
484
- scroll: [{ type: Output }],
485
- scrollToEnd: [{ type: Output }],
486
- outsideClick: [{ type: Output }],
487
- contentElementRef: [{ type: ViewChild, args: ['content', { read: ElementRef },] }],
488
- scrollElementRef: [{ type: ViewChild, args: ['scroll', { read: ElementRef },] }],
489
- paddingElementRef: [{ type: ViewChild, args: ['padding', { read: ElementRef },] }],
490
- handleMousedown: [{ type: HostListener, args: ['mousedown', ['$event'],] }]
491
- };
492
- if (false) {
493
- /** @type {?} */
494
- NgDropdownPanelComponent.prototype.items;
495
- /** @type {?} */
496
- NgDropdownPanelComponent.prototype.markedItem;
497
- /** @type {?} */
498
- NgDropdownPanelComponent.prototype.position;
499
- /** @type {?} */
500
- NgDropdownPanelComponent.prototype.appendTo;
501
- /** @type {?} */
502
- NgDropdownPanelComponent.prototype.bufferAmount;
503
- /** @type {?} */
504
- NgDropdownPanelComponent.prototype.virtualScroll;
505
- /** @type {?} */
506
- NgDropdownPanelComponent.prototype.headerTemplate;
507
- /** @type {?} */
508
- NgDropdownPanelComponent.prototype.footerTemplate;
509
- /** @type {?} */
510
- NgDropdownPanelComponent.prototype.filterValue;
511
- /** @type {?} */
512
- NgDropdownPanelComponent.prototype.update;
513
- /** @type {?} */
514
- NgDropdownPanelComponent.prototype.scroll;
515
- /** @type {?} */
516
- NgDropdownPanelComponent.prototype.scrollToEnd;
517
- /** @type {?} */
518
- NgDropdownPanelComponent.prototype.outsideClick;
519
- /** @type {?} */
520
- NgDropdownPanelComponent.prototype.contentElementRef;
521
- /** @type {?} */
522
- NgDropdownPanelComponent.prototype.scrollElementRef;
523
- /** @type {?} */
524
- NgDropdownPanelComponent.prototype.paddingElementRef;
525
- /** @type {?} */
526
- NgDropdownPanelComponent.prototype._destroy$;
527
- /** @type {?} */
528
- NgDropdownPanelComponent.prototype._dropdown;
529
- /** @type {?} */
530
- NgDropdownPanelComponent.prototype._virtualPadding;
531
- /** @type {?} */
532
- NgDropdownPanelComponent.prototype._scrollablePanel;
533
- /** @type {?} */
534
- NgDropdownPanelComponent.prototype._contentPanel;
535
- /** @type {?} */
536
- NgDropdownPanelComponent.prototype._select;
537
- /** @type {?} */
538
- NgDropdownPanelComponent.prototype._parent;
539
- /** @type {?} */
540
- NgDropdownPanelComponent.prototype._scrollToEndFired;
541
- /** @type {?} */
542
- NgDropdownPanelComponent.prototype._updateScrollHeight;
543
- /** @type {?} */
544
- NgDropdownPanelComponent.prototype._lastScrollPosition;
545
- /** @type {?} */
546
- NgDropdownPanelComponent.prototype._currentPosition;
547
- /** @type {?} */
548
- NgDropdownPanelComponent.prototype._itemsLength;
549
- /** @type {?} */
550
- NgDropdownPanelComponent.prototype._renderer;
551
- /** @type {?} */
552
- NgDropdownPanelComponent.prototype._zone;
553
- /** @type {?} */
554
- NgDropdownPanelComponent.prototype._panelService;
555
- /** @type {?} */
556
- NgDropdownPanelComponent.prototype._document;
557
- }
558
-
559
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng-dropdown-panel.component.js","sourceRoot":"ng://@ng-select/ng-select/","sources":["ng-select/ng-dropdown-panel.component.ts"],"names":[],"mappings":"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","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 }) contentElementRef: ElementRef;\n    @ViewChild('scroll', { read: ElementRef }) scrollElementRef: ElementRef;\n    @ViewChild('padding', { read: ElementRef }) 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: Event) => this._onContentScrolled(e.srcElement.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"]}