@ng-matero/ng-select 0.6.0 → 1.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/index.d.ts CHANGED
@@ -1,7 +1,7 @@
1
1
  import * as i0 from '@angular/core';
2
- import { OnInit, OnChanges, OnDestroy, TemplateRef, EventEmitter, ElementRef, SimpleChanges, AfterViewChecked, AfterViewInit, InjectionToken, QueryList } from '@angular/core';
3
- import { Subject } from 'rxjs';
2
+ import { OnChanges, AfterViewChecked, OnDestroy, ElementRef, SimpleChanges, OnInit, TemplateRef, EventEmitter, InjectionToken, AfterViewInit, QueryList } from '@angular/core';
4
3
  import { ControlValueAccessor } from '@angular/forms';
4
+ import { Subject } from 'rxjs';
5
5
 
6
6
  interface NgOptionItem {
7
7
  [name: string]: any;
@@ -24,18 +24,100 @@ interface ScrollEvent {
24
24
  start: number;
25
25
  end: number;
26
26
  }
27
- type DropdownPanelPosition = 'top' | 'right' | 'bottom' | 'left' | 'auto';
27
+ type PanelPosition = 'top' | 'right' | 'bottom' | 'left' | 'auto';
28
28
  type AddTagFn = (term: string) => any | Promise<any>;
29
29
  type CompareWithFn = (a: any, b: any) => boolean;
30
30
  type GroupValueFn = (key: string | any, children: any[]) => string | any;
31
31
  type SearchFn = (term: string, item: any) => boolean;
32
32
  type TrackByFn = (item: any) => any;
33
33
 
34
- declare class NgDropdownPanel implements OnInit, OnChanges, OnDestroy {
34
+ type SelectionModelFactory = () => SelectionModel;
35
+ declare function DefaultSelectionModelFactory(): DefaultSelectionModel;
36
+ interface SelectionModel {
37
+ value: NgOptionItem[];
38
+ select(item: NgOptionItem, multiple: boolean, selectableGroupAsModel: boolean): void;
39
+ unselect(item: NgOptionItem, multiple: boolean): void;
40
+ clear(keepDisabled: boolean): void;
41
+ }
42
+ declare class DefaultSelectionModel implements SelectionModel {
43
+ get value(): NgOptionItem[];
44
+ private _selected;
45
+ select(item: NgOptionItem, multiple: boolean, groupAsModel: boolean): void;
46
+ unselect(item: NgOptionItem, multiple: boolean): void;
47
+ clear(keepDisabled: boolean): void;
48
+ private _setChildrenSelectedState;
49
+ private _removeChildren;
50
+ private _removeParent;
51
+ private _activeChildren;
52
+ }
53
+
54
+ declare class ItemsList {
55
+ private _ngSelect;
56
+ private _selectionModel;
57
+ private _groups;
58
+ constructor(_ngSelect: NgSelect, _selectionModel: SelectionModel);
59
+ get items(): NgOptionItem[];
60
+ private _items;
61
+ get filteredItems(): NgOptionItem[];
62
+ private _filteredItems;
63
+ get markedIndex(): number;
64
+ private _markedIndex;
65
+ get selectedItems(): NgOptionItem[];
66
+ get markedItem(): NgOptionItem | undefined;
67
+ get noItemsToSelect(): boolean;
68
+ get maxItemsSelected(): boolean;
69
+ get lastSelectedItem(): NgOptionItem | null;
70
+ setItems(items: readonly any[]): void;
71
+ select(item: NgOptionItem): void;
72
+ unselect(item: NgOptionItem): void;
73
+ findItem(value: any): NgOptionItem;
74
+ addItem(item: any): NgOptionItem;
75
+ clearSelected(keepDisabled?: boolean): void;
76
+ findByLabel(term: string): NgOptionItem | undefined;
77
+ filter(term: string): void;
78
+ resetFilteredItems(): void;
79
+ unmarkItem(): void;
80
+ markNextItem(): void;
81
+ markPreviousItem(): void;
82
+ markItem(item: NgOptionItem): void;
83
+ markSelectedOrDefault(markDefault?: boolean): void;
84
+ resolveNested(option: any, key: string): any;
85
+ mapItem(item: any, index: number | null): NgOptionItem;
86
+ mapSelectedItems(): void;
87
+ private _showSelected;
88
+ private _hideSelected;
89
+ private _defaultSearchFn;
90
+ private _getNextItemIndex;
91
+ private _stepToItem;
92
+ private _getLastMarkedIndex;
93
+ private _groupBy;
94
+ private _flatten;
95
+ }
96
+
97
+ declare class NgSelectOption implements OnChanges, AfterViewChecked, OnDestroy {
98
+ value: any;
99
+ disabled: boolean;
100
+ elementRef: ElementRef<HTMLElement>;
101
+ readonly stateChange$: Subject<{
102
+ value: any;
103
+ disabled: boolean;
104
+ label?: string;
105
+ }>;
106
+ private _previousLabel;
107
+ get label(): string;
108
+ ngOnChanges(changes: SimpleChanges): void;
109
+ ngAfterViewChecked(): void;
110
+ ngOnDestroy(): void;
111
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgSelectOption, never>;
112
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgSelectOption, "ng-option, ng-select-option", never, { "value": { "alias": "value"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; }, {}, never, ["*"], true, never>;
113
+ static ngAcceptInputType_disabled: unknown;
114
+ }
115
+
116
+ declare class NgSelectPanel implements OnInit, OnChanges, OnDestroy {
35
117
  listboxId: string;
36
118
  items: NgOptionItem[];
37
119
  markedItem?: NgOptionItem;
38
- position: DropdownPanelPosition;
120
+ position: PanelPosition;
39
121
  appendTo?: string;
40
122
  bufferAmount: number;
41
123
  virtualScroll: boolean;
@@ -65,7 +147,7 @@ declare class NgDropdownPanel implements OnInit, OnChanges, OnDestroy {
65
147
  private _scrollToEndFired;
66
148
  private _updateScrollHeight;
67
149
  private _lastScrollPosition;
68
- get currentPosition(): DropdownPanelPosition;
150
+ get currentPosition(): PanelPosition;
69
151
  private _currentPosition;
70
152
  private get itemsLength();
71
153
  private set itemsLength(value);
@@ -82,6 +164,7 @@ declare class NgDropdownPanel implements OnInit, OnChanges, OnDestroy {
82
164
  private _handleScroll;
83
165
  private _handleOutsideClick;
84
166
  private _checkToClose;
167
+ private _coordinatesWithin;
85
168
  private _onItemsChange;
86
169
  private _updateItems;
87
170
  private _updateItemsRange;
@@ -97,131 +180,12 @@ declare class NgDropdownPanel implements OnInit, OnChanges, OnDestroy {
97
180
  private _updateXPosition;
98
181
  private _updateYPosition;
99
182
  private _setupMousedownListener;
100
- static ɵfac: i0.ɵɵFactoryDeclaration<NgDropdownPanel, never>;
101
- static ɵcmp: i0.ɵɵComponentDeclaration<NgDropdownPanel, "ng-dropdown-panel", never, { "listboxId": { "alias": "listboxId"; "required": false; }; "items": { "alias": "items"; "required": false; }; "markedItem": { "alias": "markedItem"; "required": false; }; "position": { "alias": "position"; "required": false; }; "appendTo": { "alias": "appendTo"; "required": false; }; "bufferAmount": { "alias": "bufferAmount"; "required": false; }; "virtualScroll": { "alias": "virtualScroll"; "required": false; }; "multiple": { "alias": "multiple"; "required": false; }; "headerTemplate": { "alias": "headerTemplate"; "required": false; }; "footerTemplate": { "alias": "footerTemplate"; "required": false; }; "filterValue": { "alias": "filterValue"; "required": false; }; }, { "update": "update"; "scroll": "scroll"; "scrollToEnd": "scrollToEnd"; "outsideClick": "outsideClick"; }, never, ["*"], true, never>;
183
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgSelectPanel, never>;
184
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgSelectPanel, "ng-select-panel", never, { "listboxId": { "alias": "listboxId"; "required": false; }; "items": { "alias": "items"; "required": false; }; "markedItem": { "alias": "markedItem"; "required": false; }; "position": { "alias": "position"; "required": false; }; "appendTo": { "alias": "appendTo"; "required": false; }; "bufferAmount": { "alias": "bufferAmount"; "required": false; }; "virtualScroll": { "alias": "virtualScroll"; "required": false; }; "multiple": { "alias": "multiple"; "required": false; }; "headerTemplate": { "alias": "headerTemplate"; "required": false; }; "footerTemplate": { "alias": "footerTemplate"; "required": false; }; "filterValue": { "alias": "filterValue"; "required": false; }; }, { "update": "update"; "scroll": "scroll"; "scrollToEnd": "scrollToEnd"; "outsideClick": "outsideClick"; }, never, ["*"], true, never>;
102
185
  static ngAcceptInputType_virtualScroll: unknown;
103
186
  static ngAcceptInputType_multiple: unknown;
104
187
  }
105
188
 
106
- interface ItemsRangeResult {
107
- scrollHeight: number;
108
- topPadding: number;
109
- start: number;
110
- end: number;
111
- }
112
- interface PanelDimensions {
113
- itemHeight: number;
114
- panelHeight: number;
115
- itemsPerViewport: number;
116
- }
117
- declare class NgDropdownPanelUtils {
118
- get dimensions(): PanelDimensions;
119
- private _dimensions;
120
- calculateItems(scrollPos: number, itemsLength: number, buffer: number): ItemsRangeResult;
121
- setDimensions(itemHeight: number, panelHeight: number): void;
122
- getScrollTo(itemTop: number, itemHeight: number, lastScroll: number): number | null;
123
- static ɵfac: i0.ɵɵFactoryDeclaration<NgDropdownPanelUtils, never>;
124
- static ɵprov: i0.ɵɵInjectableDeclaration<NgDropdownPanelUtils>;
125
- }
126
-
127
- declare class NgOption implements OnChanges, AfterViewChecked, OnDestroy {
128
- value: any;
129
- disabled: boolean;
130
- elementRef: ElementRef<HTMLElement>;
131
- readonly stateChange$: Subject<{
132
- value: any;
133
- disabled: boolean;
134
- label?: string;
135
- }>;
136
- private _previousLabel;
137
- get label(): string;
138
- ngOnChanges(changes: SimpleChanges): void;
139
- ngAfterViewChecked(): void;
140
- ngOnDestroy(): void;
141
- static ɵfac: i0.ɵɵFactoryDeclaration<NgOption, never>;
142
- static ɵcmp: i0.ɵɵComponentDeclaration<NgOption, "ng-option", never, { "value": { "alias": "value"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; }, {}, never, ["*"], true, never>;
143
- static ngAcceptInputType_disabled: unknown;
144
- }
145
-
146
- declare class NgOptionHighlight implements OnChanges, AfterViewInit {
147
- term: string;
148
- private elementRef;
149
- private renderer;
150
- private element;
151
- private label;
152
- private get _canHighlight();
153
- ngOnChanges(): void;
154
- ngAfterViewInit(): void;
155
- private _escapeRegExp;
156
- private _highlightLabel;
157
- private _setInnerHtml;
158
- static ɵfac: i0.ɵɵFactoryDeclaration<NgOptionHighlight, never>;
159
- static ɵdir: i0.ɵɵDirectiveDeclaration<NgOptionHighlight, "[ngOptionHighlight]", never, { "term": { "alias": "ngOptionHighlight"; "required": false; }; }, {}, never, never, true, never>;
160
- }
161
-
162
- type SelectionModelFactory = () => SelectionModel;
163
- declare function DefaultSelectionModelFactory(): DefaultSelectionModel;
164
- interface SelectionModel {
165
- value: NgOptionItem[];
166
- select(item: NgOptionItem, multiple: boolean, selectableGroupAsModel: boolean): void;
167
- unselect(item: NgOptionItem, multiple: boolean): void;
168
- clear(keepDisabled: boolean): void;
169
- }
170
- declare class DefaultSelectionModel implements SelectionModel {
171
- get value(): NgOptionItem[];
172
- private _selected;
173
- select(item: NgOptionItem, multiple: boolean, groupAsModel: boolean): void;
174
- unselect(item: NgOptionItem, multiple: boolean): void;
175
- clear(keepDisabled: boolean): void;
176
- private _setChildrenSelectedState;
177
- private _removeChildren;
178
- private _removeParent;
179
- private _activeChildren;
180
- }
181
-
182
- declare class ItemsList {
183
- private _ngSelect;
184
- private _selectionModel;
185
- private _groups;
186
- constructor(_ngSelect: NgSelect, _selectionModel: SelectionModel);
187
- get items(): NgOptionItem[];
188
- private _items;
189
- get filteredItems(): NgOptionItem[];
190
- private _filteredItems;
191
- get markedIndex(): number;
192
- private _markedIndex;
193
- get selectedItems(): NgOptionItem[];
194
- get markedItem(): NgOptionItem | undefined;
195
- get noItemsToSelect(): boolean;
196
- get maxItemsSelected(): boolean;
197
- get lastSelectedItem(): NgOptionItem | null;
198
- setItems(items: readonly any[]): void;
199
- select(item: NgOptionItem): void;
200
- unselect(item: NgOptionItem): void;
201
- findItem(value: any): NgOptionItem;
202
- addItem(item: any): NgOptionItem;
203
- clearSelected(keepDisabled?: boolean): void;
204
- findByLabel(term: string): NgOptionItem | undefined;
205
- filter(term: string): void;
206
- resetFilteredItems(): void;
207
- unmarkItem(): void;
208
- markNextItem(): void;
209
- markPreviousItem(): void;
210
- markItem(item: NgOptionItem): void;
211
- markSelectedOrDefault(markDefault?: boolean): void;
212
- resolveNested(option: any, key: string): any;
213
- mapItem(item: any, index: number | null): NgOptionItem;
214
- mapSelectedItems(): void;
215
- private _showSelected;
216
- private _hideSelected;
217
- private _defaultSearchFn;
218
- private _getNextItemIndex;
219
- private _stepToItem;
220
- private _getLastMarkedIndex;
221
- private _groupBy;
222
- private _flatten;
223
- }
224
-
225
189
  declare const SELECTION_MODEL_FACTORY: InjectionToken<SelectionModelFactory>;
226
190
  declare class NgSelect implements OnDestroy, OnChanges, OnInit, AfterViewInit, ControlValueAccessor {
227
191
  private _cdr;
@@ -239,7 +203,7 @@ declare class NgSelect implements OnDestroy, OnChanges, OnInit, AfterViewInit, C
239
203
  placeholder: string | undefined;
240
204
  fixedPlaceholder: boolean;
241
205
  appendTo: string | undefined;
242
- panelPosition: DropdownPanelPosition;
206
+ panelPosition: PanelPosition;
243
207
  panelDisabled: boolean;
244
208
  readonly: boolean;
245
209
  multiple: boolean;
@@ -273,7 +237,6 @@ declare class NgSelect implements OnDestroy, OnChanges, OnInit, AfterViewInit, C
273
237
  searchFn: SearchFn | null;
274
238
  keyDownFn: (e: KeyboardEvent) => boolean;
275
239
  trackByFn: TrackByFn | null;
276
- appearance: string;
277
240
  tabIndex?: number;
278
241
  inputAttrs: Record<string, string>;
279
242
  ariaLabel?: string | null;
@@ -310,22 +273,22 @@ declare class NgSelect implements OnDestroy, OnChanges, OnInit, AfterViewInit, C
310
273
  removeEvent: EventEmitter<any>;
311
274
  scroll: EventEmitter<ScrollEvent>;
312
275
  scrollToEnd: EventEmitter<void>;
313
- dropdownPanel: NgDropdownPanel;
276
+ dropdownPanel: NgSelectPanel;
314
277
  searchInput: ElementRef<HTMLInputElement>;
315
278
  clearButton?: ElementRef<HTMLSpanElement>;
316
- ngOptions?: QueryList<NgOption>;
279
+ ngOptions?: QueryList<NgSelectOption>;
317
280
  optionTemplate?: TemplateRef<any>;
318
281
  optgroupTemplate?: TemplateRef<any>;
319
282
  labelTemplate?: TemplateRef<any>;
320
283
  multiLabelTemplate?: TemplateRef<any>;
321
- headerTemplate?: TemplateRef<any>;
322
- footerTemplate?: TemplateRef<any>;
284
+ panelHeaderTemplate?: TemplateRef<any>;
285
+ panelFooterTemplate?: TemplateRef<any>;
323
286
  notFoundTemplate?: TemplateRef<any>;
324
287
  placeholderTemplate?: TemplateRef<any>;
325
288
  typeToSearchTemplate?: TemplateRef<any>;
326
289
  loadingTextTemplate?: TemplateRef<any>;
327
290
  tagTemplate?: TemplateRef<any>;
328
- loadingSpinnerTemplate?: TemplateRef<any>;
291
+ loadingTemplate?: TemplateRef<any>;
329
292
  clearButtonTemplate?: TemplateRef<any>;
330
293
  itemsList: ItemsList;
331
294
  element: HTMLElement;
@@ -345,7 +308,7 @@ declare class NgSelect implements OnDestroy, OnChanges, OnInit, AfterViewInit, C
345
308
  get selectedValues(): any[];
346
309
  get selectedViewValuesStr(): string;
347
310
  get hasValue(): boolean;
348
- get currentPanelPosition(): DropdownPanelPosition | undefined;
311
+ get currentPanelPosition(): PanelPosition | undefined;
349
312
  get showAddTag(): boolean;
350
313
  get filtered(): boolean;
351
314
  private get _editableSearchTerm();
@@ -412,7 +375,7 @@ declare class NgSelect implements OnDestroy, OnChanges, OnInit, AfterViewInit, C
412
375
  private _nextItemIsTag;
413
376
  private _handleBackspace;
414
377
  static ɵfac: i0.ɵɵFactoryDeclaration<NgSelect, never>;
415
- static ɵcmp: i0.ɵɵComponentDeclaration<NgSelect, "ng-select", never, { "bindLabel": { "alias": "bindLabel"; "required": false; }; "bindValue": { "alias": "bindValue"; "required": false; }; "placeholder": { "alias": "placeholder"; "required": false; }; "fixedPlaceholder": { "alias": "fixedPlaceholder"; "required": false; }; "appendTo": { "alias": "appendTo"; "required": false; }; "panelPosition": { "alias": "panelPosition"; "required": false; }; "panelDisabled": { "alias": "panelDisabled"; "required": false; }; "readonly": { "alias": "readonly"; "required": false; }; "multiple": { "alias": "multiple"; "required": false; }; "searchable": { "alias": "searchable"; "required": false; }; "clearable": { "alias": "clearable"; "required": false; }; "clearOnBackspace": { "alias": "clearOnBackspace"; "required": false; }; "clearAllText": { "alias": "clearAllText"; "required": false; }; "loading": { "alias": "loading"; "required": false; }; "loadingText": { "alias": "loadingText"; "required": false; }; "closeOnSelect": { "alias": "closeOnSelect"; "required": false; }; "hideSelected": { "alias": "hideSelected"; "required": false; }; "selectOnTab": { "alias": "selectOnTab"; "required": false; }; "openOnEnter": { "alias": "openOnEnter"; "required": false; }; "virtualScroll": { "alias": "virtualScroll"; "required": false; }; "bufferAmount": { "alias": "bufferAmount"; "required": false; }; "selectableGroup": { "alias": "selectableGroup"; "required": false; }; "selectableGroupAsModel": { "alias": "selectableGroupAsModel"; "required": false; }; "searchWhileComposing": { "alias": "searchWhileComposing"; "required": false; }; "editableSearchTerm": { "alias": "editableSearchTerm"; "required": false; }; "maxSelectedItems": { "alias": "maxSelectedItems"; "required": false; }; "minTermLength": { "alias": "minTermLength"; "required": false; }; "markFirst": { "alias": "markFirst"; "required": false; }; "preventToggleOnRightClick": { "alias": "preventToggleOnRightClick"; "required": false; }; "addTag": { "alias": "addTag"; "required": false; }; "addTagText": { "alias": "addTagText"; "required": false; }; "notFoundText": { "alias": "notFoundText"; "required": false; }; "typeahead": { "alias": "typeahead"; "required": false; }; "typeToSearchText": { "alias": "typeToSearchText"; "required": false; }; "groupBy": { "alias": "groupBy"; "required": false; }; "groupValue": { "alias": "groupValue"; "required": false; }; "searchFn": { "alias": "searchFn"; "required": false; }; "keyDownFn": { "alias": "keyDownFn"; "required": false; }; "trackByFn": { "alias": "trackByFn"; "required": false; }; "appearance": { "alias": "appearance"; "required": false; }; "tabIndex": { "alias": "tabIndex"; "required": false; }; "inputAttrs": { "alias": "inputAttrs"; "required": false; }; "ariaLabel": { "alias": "ariaLabel"; "required": false; }; "ariaLabelledby": { "alias": "ariaLabelledby"; "required": false; }; "ariaDescribedby": { "alias": "ariaDescribedby"; "required": false; }; "panelClass": { "alias": "panelClass"; "required": false; }; "inputId": { "alias": "inputId"; "required": false; }; "items": { "alias": "items"; "required": false; }; "compareWith": { "alias": "compareWith"; "required": false; }; "clearSearchOnAdd": { "alias": "clearSearchOnAdd"; "required": false; }; "deselectOnClick": { "alias": "deselectOnClick"; "required": false; }; }, { "blurEvent": "blur"; "focusEvent": "focus"; "changeEvent": "change"; "openEvent": "open"; "closeEvent": "close"; "searchEvent": "search"; "clearEvent": "clear"; "addEvent": "add"; "removeEvent": "remove"; "scroll": "scroll"; "scrollToEnd": "scrollToEnd"; }, ["optionTemplate", "optgroupTemplate", "labelTemplate", "multiLabelTemplate", "headerTemplate", "footerTemplate", "notFoundTemplate", "placeholderTemplate", "typeToSearchTemplate", "loadingTextTemplate", "tagTemplate", "loadingSpinnerTemplate", "clearButtonTemplate", "ngOptions"], never, true, never>;
378
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgSelect, "ng-select", never, { "bindLabel": { "alias": "bindLabel"; "required": false; }; "bindValue": { "alias": "bindValue"; "required": false; }; "placeholder": { "alias": "placeholder"; "required": false; }; "fixedPlaceholder": { "alias": "fixedPlaceholder"; "required": false; }; "appendTo": { "alias": "appendTo"; "required": false; }; "panelPosition": { "alias": "panelPosition"; "required": false; }; "panelDisabled": { "alias": "panelDisabled"; "required": false; }; "readonly": { "alias": "readonly"; "required": false; }; "multiple": { "alias": "multiple"; "required": false; }; "searchable": { "alias": "searchable"; "required": false; }; "clearable": { "alias": "clearable"; "required": false; }; "clearOnBackspace": { "alias": "clearOnBackspace"; "required": false; }; "clearAllText": { "alias": "clearAllText"; "required": false; }; "loading": { "alias": "loading"; "required": false; }; "loadingText": { "alias": "loadingText"; "required": false; }; "closeOnSelect": { "alias": "closeOnSelect"; "required": false; }; "hideSelected": { "alias": "hideSelected"; "required": false; }; "selectOnTab": { "alias": "selectOnTab"; "required": false; }; "openOnEnter": { "alias": "openOnEnter"; "required": false; }; "virtualScroll": { "alias": "virtualScroll"; "required": false; }; "bufferAmount": { "alias": "bufferAmount"; "required": false; }; "selectableGroup": { "alias": "selectableGroup"; "required": false; }; "selectableGroupAsModel": { "alias": "selectableGroupAsModel"; "required": false; }; "searchWhileComposing": { "alias": "searchWhileComposing"; "required": false; }; "editableSearchTerm": { "alias": "editableSearchTerm"; "required": false; }; "maxSelectedItems": { "alias": "maxSelectedItems"; "required": false; }; "minTermLength": { "alias": "minTermLength"; "required": false; }; "markFirst": { "alias": "markFirst"; "required": false; }; "preventToggleOnRightClick": { "alias": "preventToggleOnRightClick"; "required": false; }; "addTag": { "alias": "addTag"; "required": false; }; "addTagText": { "alias": "addTagText"; "required": false; }; "notFoundText": { "alias": "notFoundText"; "required": false; }; "typeahead": { "alias": "typeahead"; "required": false; }; "typeToSearchText": { "alias": "typeToSearchText"; "required": false; }; "groupBy": { "alias": "groupBy"; "required": false; }; "groupValue": { "alias": "groupValue"; "required": false; }; "searchFn": { "alias": "searchFn"; "required": false; }; "keyDownFn": { "alias": "keyDownFn"; "required": false; }; "trackByFn": { "alias": "trackByFn"; "required": false; }; "tabIndex": { "alias": "tabIndex"; "required": false; }; "inputAttrs": { "alias": "inputAttrs"; "required": false; }; "ariaLabel": { "alias": "ariaLabel"; "required": false; }; "ariaLabelledby": { "alias": "ariaLabelledby"; "required": false; }; "ariaDescribedby": { "alias": "ariaDescribedby"; "required": false; }; "panelClass": { "alias": "panelClass"; "required": false; }; "inputId": { "alias": "inputId"; "required": false; }; "items": { "alias": "items"; "required": false; }; "compareWith": { "alias": "compareWith"; "required": false; }; "clearSearchOnAdd": { "alias": "clearSearchOnAdd"; "required": false; }; "deselectOnClick": { "alias": "deselectOnClick"; "required": false; }; }, { "blurEvent": "blur"; "focusEvent": "focus"; "changeEvent": "change"; "openEvent": "open"; "closeEvent": "close"; "searchEvent": "search"; "clearEvent": "clear"; "addEvent": "add"; "removeEvent": "remove"; "scroll": "scroll"; "scrollToEnd": "scrollToEnd"; }, ["optionTemplate", "optgroupTemplate", "labelTemplate", "multiLabelTemplate", "panelHeaderTemplate", "panelFooterTemplate", "notFoundTemplate", "placeholderTemplate", "typeToSearchTemplate", "loadingTextTemplate", "tagTemplate", "loadingTemplate", "clearButtonTemplate", "ngOptions"], never, true, never>;
416
379
  static ngAcceptInputType_panelDisabled: unknown;
417
380
  static ngAcceptInputType_readonly: unknown;
418
381
  static ngAcceptInputType_multiple: unknown;
@@ -454,90 +417,126 @@ declare class NgSelectConfig {
454
417
  bindLabel?: string;
455
418
  clearSearchOnAdd?: boolean;
456
419
  deselectOnClick?: boolean;
457
- appearance: string;
458
420
  static ɵfac: i0.ɵɵFactoryDeclaration<NgSelectConfig, never>;
459
421
  static ɵprov: i0.ɵɵInjectableDeclaration<NgSelectConfig>;
460
422
  }
461
423
 
462
- declare class NgItemLabel implements OnChanges {
463
- ngItemLabel: string;
464
- escape: boolean;
424
+ declare class NgSelectLabelRenderer implements OnChanges {
425
+ ngSelectLabelValue: string;
426
+ ngSelectLabelEscape: boolean;
465
427
  private element;
466
428
  ngOnChanges(): void;
467
- static ɵfac: i0.ɵɵFactoryDeclaration<NgItemLabel, never>;
468
- static ɵdir: i0.ɵɵDirectiveDeclaration<NgItemLabel, "[ngItemLabel]", never, { "ngItemLabel": { "alias": "ngItemLabel"; "required": false; }; "escape": { "alias": "escape"; "required": false; }; }, {}, never, never, true, never>;
429
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgSelectLabelRenderer, never>;
430
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgSelectLabelRenderer, "[ngSelectLabelValue]", never, { "ngSelectLabelValue": { "alias": "ngSelectLabelValue"; "required": false; }; "ngSelectLabelEscape": { "alias": "ngSelectLabelEscape"; "required": false; }; }, {}, never, never, true, never>;
469
431
  }
470
- declare class NgOptionTemplate {
432
+ declare class NgSelectOptionTemplate {
471
433
  template: TemplateRef<any>;
472
- static ɵfac: i0.ɵɵFactoryDeclaration<NgOptionTemplate, never>;
473
- static ɵdir: i0.ɵɵDirectiveDeclaration<NgOptionTemplate, "[ng-option-tmp]", never, {}, {}, never, never, true, never>;
434
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgSelectOptionTemplate, never>;
435
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgSelectOptionTemplate, "[ngSelectOption]", never, {}, {}, never, never, true, never>;
474
436
  }
475
- declare class NgOptgroupTemplate {
437
+ declare class NgSelectOptgroupTemplate {
476
438
  template: TemplateRef<any>;
477
- static ɵfac: i0.ɵɵFactoryDeclaration<NgOptgroupTemplate, never>;
478
- static ɵdir: i0.ɵɵDirectiveDeclaration<NgOptgroupTemplate, "[ng-optgroup-tmp]", never, {}, {}, never, never, true, never>;
439
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgSelectOptgroupTemplate, never>;
440
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgSelectOptgroupTemplate, "[ngSelectOptgroup]", never, {}, {}, never, never, true, never>;
479
441
  }
480
- declare class NgLabelTemplate {
442
+ declare class NgSelectLabelTemplate {
481
443
  template: TemplateRef<any>;
482
- static ɵfac: i0.ɵɵFactoryDeclaration<NgLabelTemplate, never>;
483
- static ɵdir: i0.ɵɵDirectiveDeclaration<NgLabelTemplate, "[ng-label-tmp]", never, {}, {}, never, never, true, never>;
444
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgSelectLabelTemplate, never>;
445
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgSelectLabelTemplate, "[ngSelectLabel]", never, {}, {}, never, never, true, never>;
484
446
  }
485
- declare class NgMultiLabelTemplate {
447
+ declare class NgSelectMultiLabelTemplate {
486
448
  template: TemplateRef<any>;
487
- static ɵfac: i0.ɵɵFactoryDeclaration<NgMultiLabelTemplate, never>;
488
- static ɵdir: i0.ɵɵDirectiveDeclaration<NgMultiLabelTemplate, "[ng-multi-label-tmp]", never, {}, {}, never, never, true, never>;
449
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgSelectMultiLabelTemplate, never>;
450
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgSelectMultiLabelTemplate, "[ngSelectMultiLabel]", never, {}, {}, never, never, true, never>;
489
451
  }
490
- declare class NgHeaderTemplate {
452
+ declare class NgSelectPanelHeaderTemplate {
491
453
  template: TemplateRef<any>;
492
- static ɵfac: i0.ɵɵFactoryDeclaration<NgHeaderTemplate, never>;
493
- static ɵdir: i0.ɵɵDirectiveDeclaration<NgHeaderTemplate, "[ng-header-tmp]", never, {}, {}, never, never, true, never>;
454
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgSelectPanelHeaderTemplate, never>;
455
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgSelectPanelHeaderTemplate, "[ngSelectPanelHeader]", never, {}, {}, never, never, true, never>;
494
456
  }
495
- declare class NgFooterTemplate {
457
+ declare class NgSelectPanelFooterTemplate {
496
458
  template: TemplateRef<any>;
497
- static ɵfac: i0.ɵɵFactoryDeclaration<NgFooterTemplate, never>;
498
- static ɵdir: i0.ɵɵDirectiveDeclaration<NgFooterTemplate, "[ng-footer-tmp]", never, {}, {}, never, never, true, never>;
459
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgSelectPanelFooterTemplate, never>;
460
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgSelectPanelFooterTemplate, "[ngSelectPanelFooter]", never, {}, {}, never, never, true, never>;
499
461
  }
500
- declare class NgNotFoundTemplate {
462
+ declare class NgSelectNotFoundTemplate {
501
463
  template: TemplateRef<any>;
502
- static ɵfac: i0.ɵɵFactoryDeclaration<NgNotFoundTemplate, never>;
503
- static ɵdir: i0.ɵɵDirectiveDeclaration<NgNotFoundTemplate, "[ng-notfound-tmp]", never, {}, {}, never, never, true, never>;
464
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgSelectNotFoundTemplate, never>;
465
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgSelectNotFoundTemplate, "[ngSelectNotFound]", never, {}, {}, never, never, true, never>;
504
466
  }
505
- declare class NgPlaceholderTemplate {
467
+ declare class NgSelectPlaceholderTemplate {
506
468
  template: TemplateRef<any>;
507
- static ɵfac: i0.ɵɵFactoryDeclaration<NgPlaceholderTemplate, never>;
508
- static ɵdir: i0.ɵɵDirectiveDeclaration<NgPlaceholderTemplate, "[ng-placeholder-tmp]", never, {}, {}, never, never, true, never>;
469
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgSelectPlaceholderTemplate, never>;
470
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgSelectPlaceholderTemplate, "[ngSelectPlaceholder]", never, {}, {}, never, never, true, never>;
509
471
  }
510
- declare class NgTypeToSearchTemplate {
472
+ declare class NgSelectTypeToSearchTemplate {
511
473
  template: TemplateRef<any>;
512
- static ɵfac: i0.ɵɵFactoryDeclaration<NgTypeToSearchTemplate, never>;
513
- static ɵdir: i0.ɵɵDirectiveDeclaration<NgTypeToSearchTemplate, "[ng-typetosearch-tmp]", never, {}, {}, never, never, true, never>;
474
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgSelectTypeToSearchTemplate, never>;
475
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgSelectTypeToSearchTemplate, "[ngSelectTypeToSearch]", never, {}, {}, never, never, true, never>;
514
476
  }
515
- declare class NgLoadingTextTemplate {
477
+ declare class NgSelectLoadingTextTemplate {
516
478
  template: TemplateRef<any>;
517
- static ɵfac: i0.ɵɵFactoryDeclaration<NgLoadingTextTemplate, never>;
518
- static ɵdir: i0.ɵɵDirectiveDeclaration<NgLoadingTextTemplate, "[ng-loadingtext-tmp]", never, {}, {}, never, never, true, never>;
479
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgSelectLoadingTextTemplate, never>;
480
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgSelectLoadingTextTemplate, "[ngSelectLoadingText]", never, {}, {}, never, never, true, never>;
519
481
  }
520
- declare class NgTagTemplate {
482
+ declare class NgSelectTagTemplate {
521
483
  template: TemplateRef<any>;
522
- static ɵfac: i0.ɵɵFactoryDeclaration<NgTagTemplate, never>;
523
- static ɵdir: i0.ɵɵDirectiveDeclaration<NgTagTemplate, "[ng-tag-tmp]", never, {}, {}, never, never, true, never>;
484
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgSelectTagTemplate, never>;
485
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgSelectTagTemplate, "[ngSelectTag]", never, {}, {}, never, never, true, never>;
524
486
  }
525
- declare class NgLoadingSpinnerTemplate {
487
+ declare class NgSelectLoadingTemplate {
526
488
  template: TemplateRef<any>;
527
- static ɵfac: i0.ɵɵFactoryDeclaration<NgLoadingSpinnerTemplate, never>;
528
- static ɵdir: i0.ɵɵDirectiveDeclaration<NgLoadingSpinnerTemplate, "[ng-loadingspinner-tmp]", never, {}, {}, never, never, true, never>;
489
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgSelectLoadingTemplate, never>;
490
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgSelectLoadingTemplate, "[ngSelectLoading]", never, {}, {}, never, never, true, never>;
529
491
  }
530
- declare class NgClearButtonTemplate {
492
+ declare class NgSelectClearButtonTemplate {
531
493
  template: TemplateRef<any>;
532
- static ɵfac: i0.ɵɵFactoryDeclaration<NgClearButtonTemplate, never>;
533
- static ɵdir: i0.ɵɵDirectiveDeclaration<NgClearButtonTemplate, "[ng-clearbutton-tmp]", never, {}, {}, never, never, true, never>;
494
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgSelectClearButtonTemplate, never>;
495
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgSelectClearButtonTemplate, "[ngSelectClearButton]", never, {}, {}, never, never, true, never>;
534
496
  }
535
497
 
536
498
  declare class NgSelectModule {
537
499
  static ɵfac: i0.ɵɵFactoryDeclaration<NgSelectModule, never>;
538
- static ɵmod: i0.ɵɵNgModuleDeclaration<NgSelectModule, never, [typeof NgDropdownPanel, typeof NgOption, typeof NgSelect, typeof NgOptgroupTemplate, typeof NgOptionTemplate, typeof NgLabelTemplate, typeof NgMultiLabelTemplate, typeof NgHeaderTemplate, typeof NgFooterTemplate, typeof NgPlaceholderTemplate, typeof NgClearButtonTemplate, typeof NgNotFoundTemplate, typeof NgTypeToSearchTemplate, typeof NgLoadingTextTemplate, typeof NgTagTemplate, typeof NgLoadingSpinnerTemplate, typeof NgItemLabel], [typeof NgSelect, typeof NgOption, typeof NgOptgroupTemplate, typeof NgOptionTemplate, typeof NgLabelTemplate, typeof NgMultiLabelTemplate, typeof NgHeaderTemplate, typeof NgFooterTemplate, typeof NgPlaceholderTemplate, typeof NgNotFoundTemplate, typeof NgTypeToSearchTemplate, typeof NgLoadingTextTemplate, typeof NgTagTemplate, typeof NgLoadingSpinnerTemplate, typeof NgClearButtonTemplate]>;
500
+ static ɵmod: i0.ɵɵNgModuleDeclaration<NgSelectModule, never, [typeof NgSelectPanel, typeof NgSelect, typeof NgSelectOption, typeof NgSelectOptgroupTemplate, typeof NgSelectOptionTemplate, typeof NgSelectLabelTemplate, typeof NgSelectMultiLabelTemplate, typeof NgSelectPanelHeaderTemplate, typeof NgSelectPanelFooterTemplate, typeof NgSelectPlaceholderTemplate, typeof NgSelectClearButtonTemplate, typeof NgSelectNotFoundTemplate, typeof NgSelectTypeToSearchTemplate, typeof NgSelectLoadingTextTemplate, typeof NgSelectTagTemplate, typeof NgSelectLoadingTemplate, typeof NgSelectLabelRenderer], [typeof NgSelect, typeof NgSelectOption, typeof NgSelectOptgroupTemplate, typeof NgSelectOptionTemplate, typeof NgSelectLabelTemplate, typeof NgSelectMultiLabelTemplate, typeof NgSelectPanelHeaderTemplate, typeof NgSelectPanelFooterTemplate, typeof NgSelectPlaceholderTemplate, typeof NgSelectClearButtonTemplate, typeof NgSelectNotFoundTemplate, typeof NgSelectTypeToSearchTemplate, typeof NgSelectLoadingTextTemplate, typeof NgSelectTagTemplate, typeof NgSelectLoadingTemplate]>;
539
501
  static ɵinj: i0.ɵɵInjectorDeclaration<NgSelectModule>;
540
502
  }
541
503
 
542
- export { DefaultSelectionModel, DefaultSelectionModelFactory, NgClearButtonTemplate, NgDropdownPanel, NgDropdownPanelUtils, NgFooterTemplate, NgHeaderTemplate, NgItemLabel, NgLabelTemplate, NgLoadingSpinnerTemplate, NgLoadingTextTemplate, NgMultiLabelTemplate, NgNotFoundTemplate, NgOptgroupTemplate, NgOption, NgOptionHighlight, NgOptionTemplate, NgPlaceholderTemplate, NgSelect, NgSelectConfig, NgSelectModule, NgTagTemplate, NgTypeToSearchTemplate, SELECTION_MODEL_FACTORY };
543
- export type { AddTagFn, CompareWithFn, DropdownPanelPosition, GroupValueFn, ItemsRangeResult, NgOptionItem, PanelDimensions, ScrollEvent, SearchEvent, SearchFn, SelectionModel, SelectionModelFactory, TrackByFn };
504
+ declare class NgSelectOptionHighlight implements OnChanges, AfterViewInit {
505
+ term: string;
506
+ private elementRef;
507
+ private renderer;
508
+ private element;
509
+ private label;
510
+ private get _canHighlight();
511
+ ngOnChanges(): void;
512
+ ngAfterViewInit(): void;
513
+ private _escapeRegExp;
514
+ private _highlightLabel;
515
+ private _setInnerHtml;
516
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgSelectOptionHighlight, never>;
517
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgSelectOptionHighlight, "[ngOptionHighlight]", never, { "term": { "alias": "ngOptionHighlight"; "required": false; }; }, {}, never, never, true, never>;
518
+ }
519
+
520
+ interface ItemsRangeResult {
521
+ scrollHeight: number;
522
+ topPadding: number;
523
+ start: number;
524
+ end: number;
525
+ }
526
+ interface PanelDimensions {
527
+ itemHeight: number;
528
+ panelHeight: number;
529
+ itemsPerViewport: number;
530
+ }
531
+ declare class NgSelectPanelUtils {
532
+ get dimensions(): PanelDimensions;
533
+ private _dimensions;
534
+ calculateItems(scrollPos: number, itemsLength: number, buffer: number): ItemsRangeResult;
535
+ setDimensions(itemHeight: number, panelHeight: number): void;
536
+ getScrollTo(itemTop: number, itemHeight: number, lastScroll: number): number | null;
537
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgSelectPanelUtils, never>;
538
+ static ɵprov: i0.ɵɵInjectableDeclaration<NgSelectPanelUtils>;
539
+ }
540
+
541
+ export { DefaultSelectionModel, DefaultSelectionModelFactory, NgSelect, NgSelectClearButtonTemplate, NgSelectConfig, NgSelectLabelRenderer, NgSelectLabelTemplate, NgSelectLoadingTemplate, NgSelectLoadingTextTemplate, NgSelectModule, NgSelectMultiLabelTemplate, NgSelectNotFoundTemplate, NgSelectOptgroupTemplate, NgSelectOption, NgSelectOptionHighlight, NgSelectOptionTemplate, NgSelectPanel, NgSelectPanelFooterTemplate, NgSelectPanelHeaderTemplate, NgSelectPanelUtils, NgSelectPlaceholderTemplate, NgSelectTagTemplate, NgSelectTypeToSearchTemplate, SELECTION_MODEL_FACTORY };
542
+ export type { AddTagFn, CompareWithFn, GroupValueFn, ItemsRangeResult, NgOptionItem, PanelDimensions, PanelPosition, ScrollEvent, SearchEvent, SearchFn, SelectionModel, SelectionModelFactory, TrackByFn };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ng-matero/ng-select",
3
- "version": "0.6.0",
3
+ "version": "1.0.1",
4
4
  "description": "Angular Select - All in One UI Select, Multiselect and Autocomplete",
5
5
  "publishConfig": {
6
6
  "access": "public"
@@ -27,30 +27,13 @@
27
27
  "url": "https://github.com/ng-matero/combobox/issues"
28
28
  },
29
29
  "exports": {
30
- "./scss/ant.design.theme": {
31
- "style": "./scss/ant.design.theme.scss"
32
- },
33
- "./scss/default.theme": {
34
- "style": "./scss/default.theme.scss"
35
- },
36
- "./scss/material.theme": {
37
- "style": "./scss/material.theme.scss"
38
- },
39
- "./themes/ant.design.theme.css": {
40
- "style": "./themes/ant.design.theme.css"
41
- },
42
- "./themes/default.theme.css": {
43
- "style": "./themes/default.theme.css"
44
- },
45
- "./themes/material.theme.css": {
46
- "style": "./themes/material.theme.css"
47
- },
48
- "./package.json": {
49
- "default": "./package.json"
50
- },
51
30
  ".": {
31
+ "sass": "./_index.scss",
52
32
  "types": "./index.d.ts",
53
33
  "default": "./fesm2022/ng-matero-ng-select.mjs"
34
+ },
35
+ "./package.json": {
36
+ "default": "./package.json"
54
37
  }
55
38
  },
56
39
  "peerDependencies": {