ngx-dropdown-list 1.1.2 → 1.2.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 (66) hide show
  1. package/README.md +2 -2
  2. package/esm2020/ngx-dropdown-list.mjs +5 -0
  3. package/esm2020/public_api.mjs +2 -0
  4. package/esm2020/src/ngx-dropdown-list/anchor/anchor.component.mjs +149 -0
  5. package/esm2020/src/ngx-dropdown-list/dropdown/dropdown.component.mjs +252 -0
  6. package/esm2020/src/ngx-dropdown-list/dropdown-list.component.mjs +233 -0
  7. package/esm2020/src/ngx-dropdown-list/dropdown-list.module.mjs +38 -0
  8. package/esm2020/src/ngx-dropdown-list/filter/input-filter.component.mjs +44 -0
  9. package/esm2020/src/ngx-dropdown-list/group-item/group-item.component.mjs +25 -0
  10. package/esm2020/src/ngx-dropdown-list/index.mjs +3 -0
  11. package/esm2020/src/ngx-dropdown-list/item/item.component.mjs +77 -0
  12. package/esm2020/src/ngx-dropdown-list/types/index.mjs +3 -0
  13. package/esm2020/src/ngx-dropdown-list/types/selection-group-items.types.mjs +2 -0
  14. package/esm2020/src/ngx-dropdown-list/types/selection-item.types.mjs +2 -0
  15. package/esm2020/src/ngx-dropdown-list/utils/util.mjs +59 -0
  16. package/fesm2015/ngx-dropdown-list.mjs +854 -0
  17. package/fesm2015/ngx-dropdown-list.mjs.map +1 -0
  18. package/fesm2020/ngx-dropdown-list.mjs +854 -0
  19. package/fesm2020/ngx-dropdown-list.mjs.map +1 -0
  20. package/ngx-dropdown-list.d.ts +1 -5
  21. package/package.json +26 -48
  22. package/src/ngx-dropdown-list/anchor/anchor.component.d.ts +6 -3
  23. package/src/ngx-dropdown-list/dropdown/dropdown.component.d.ts +5 -2
  24. package/src/ngx-dropdown-list/dropdown-list.component.d.ts +7 -4
  25. package/src/ngx-dropdown-list/dropdown-list.module.d.ts +12 -0
  26. package/src/ngx-dropdown-list/filter/input-filter.component.d.ts +3 -0
  27. package/src/ngx-dropdown-list/group-item/group-item.component.d.ts +3 -0
  28. package/src/ngx-dropdown-list/item/item.component.d.ts +3 -0
  29. package/bundles/ngx-dropdown-list.umd.js +0 -1212
  30. package/bundles/ngx-dropdown-list.umd.js.map +0 -1
  31. package/bundles/ngx-dropdown-list.umd.min.js +0 -2
  32. package/bundles/ngx-dropdown-list.umd.min.js.map +0 -1
  33. package/esm2015/ngx-dropdown-list.js +0 -14
  34. package/esm2015/public_api.js +0 -6
  35. package/esm2015/src/ngx-dropdown-list/anchor/anchor.component.js +0 -226
  36. package/esm2015/src/ngx-dropdown-list/dropdown/dropdown.component.js +0 -351
  37. package/esm2015/src/ngx-dropdown-list/dropdown-list.component.js +0 -290
  38. package/esm2015/src/ngx-dropdown-list/dropdown-list.module.js +0 -32
  39. package/esm2015/src/ngx-dropdown-list/filter/input-filter.component.js +0 -64
  40. package/esm2015/src/ngx-dropdown-list/group-item/group-item.component.js +0 -37
  41. package/esm2015/src/ngx-dropdown-list/index.js +0 -7
  42. package/esm2015/src/ngx-dropdown-list/item/item.component.js +0 -104
  43. package/esm2015/src/ngx-dropdown-list/types/index.js +0 -7
  44. package/esm2015/src/ngx-dropdown-list/types/selection-group-items.types.js +0 -16
  45. package/esm2015/src/ngx-dropdown-list/types/selection-item.types.js +0 -20
  46. package/esm2015/src/ngx-dropdown-list/utils/util.js +0 -101
  47. package/esm5/ngx-dropdown-list.js +0 -14
  48. package/esm5/public_api.js +0 -6
  49. package/esm5/src/ngx-dropdown-list/anchor/anchor.component.js +0 -272
  50. package/esm5/src/ngx-dropdown-list/dropdown/dropdown.component.js +0 -420
  51. package/esm5/src/ngx-dropdown-list/dropdown-list.component.js +0 -361
  52. package/esm5/src/ngx-dropdown-list/dropdown-list.module.js +0 -36
  53. package/esm5/src/ngx-dropdown-list/filter/input-filter.component.js +0 -79
  54. package/esm5/src/ngx-dropdown-list/group-item/group-item.component.js +0 -47
  55. package/esm5/src/ngx-dropdown-list/index.js +0 -7
  56. package/esm5/src/ngx-dropdown-list/item/item.component.js +0 -120
  57. package/esm5/src/ngx-dropdown-list/types/index.js +0 -7
  58. package/esm5/src/ngx-dropdown-list/types/selection-group-items.types.js +0 -16
  59. package/esm5/src/ngx-dropdown-list/types/selection-item.types.js +0 -20
  60. package/esm5/src/ngx-dropdown-list/utils/util.js +0 -124
  61. package/fesm2015/ngx-dropdown-list.js +0 -930
  62. package/fesm2015/ngx-dropdown-list.js.map +0 -1
  63. package/fesm5/ngx-dropdown-list.js +0 -1177
  64. package/fesm5/ngx-dropdown-list.js.map +0 -1
  65. package/ngx-dropdown-list-1.1.2.tgz +0 -0
  66. package/ngx-dropdown-list.metadata.json +0 -1
@@ -1,420 +0,0 @@
1
- /**
2
- * @fileoverview added by tsickle
3
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
4
- */
5
- import { Component, ElementRef, EventEmitter, Input, Output, ViewChild } from '@angular/core';
6
- import { clearAllSelection, getFirstSelectedItem, hasGroup, stopPropagationAndDefault } from '../utils/util';
7
- var DropdownComponent = /** @class */ (function () {
8
- function DropdownComponent() {
9
- /**
10
- * bind to [checkbox], the flag for multi-select (checkbox) mode.
11
- */
12
- this.checkbox = false;
13
- /**
14
- * bind to [filterBox] for displaying the filter input text box
15
- */
16
- this.filterBox = false;
17
- /**
18
- * bind to [allowClear] for enabling the clearance (clearance is not avaiable when checkbox is enabled)
19
- */
20
- this.allowClear = true;
21
- /**
22
- * bind to [formatNumber] for show formatted number text
23
- */
24
- this.formatNumber = false;
25
- /**
26
- * for 2-way binding of [selectedValue]
27
- */
28
- this.selectedValueChange = new EventEmitter(true);
29
- /**
30
- * [selectionChange] event that will be triggered when changing of the selection
31
- */
32
- this.selectionChange = new EventEmitter(true);
33
- /**
34
- * [dropdownBlur] event that will be triggered with (blur) of dropdown
35
- */
36
- this.dropdownBlur = new EventEmitter();
37
- /**
38
- * [itemClick] event that will be triggered when clicking the option of dropdown
39
- */
40
- this.itemClick = new EventEmitter();
41
- /**
42
- * flag of clicking dropdown. It's to prevent (blur) of dropdown from happening in checkbox mode.
43
- */
44
- this._clickedItems = false;
45
- }
46
- /**
47
- * @param {?} changes
48
- * @return {?}
49
- */
50
- DropdownComponent.prototype.ngOnChanges = /**
51
- * @param {?} changes
52
- * @return {?}
53
- */
54
- function (changes) {
55
- if (changes.items) {
56
- this._checkSelectionChange(changes.items.previousValue, changes.items.currentValue);
57
- }
58
- };
59
- /**
60
- * triggered when clicking the dropdown
61
- */
62
- /**
63
- * triggered when clicking the dropdown
64
- * @param {?} event
65
- * @return {?}
66
- */
67
- DropdownComponent.prototype.onItemsClick = /**
68
- * triggered when clicking the dropdown
69
- * @param {?} event
70
- * @return {?}
71
- */
72
- function (event) {
73
- if (event.offsetX > (event.target.clientWidth + event.target.clientLeft)) {
74
- stopPropagationAndDefault(event);
75
- return;
76
- }
77
- // should ignore clicking on filter
78
- if (this.checkbox && event.target.type !== 'text') {
79
- this._clickedItems = true;
80
- }
81
- };
82
- /**
83
- * triggered when clicking the item
84
- */
85
- /**
86
- * triggered when clicking the item
87
- * @param {?} currentItem
88
- * @return {?}
89
- */
90
- DropdownComponent.prototype.onItemClick = /**
91
- * triggered when clicking the item
92
- * @param {?} currentItem
93
- * @return {?}
94
- */
95
- function (currentItem) {
96
- if (!this.checkbox) {
97
- this.selectedValue = this._getItemValue(currentItem); // currentItem.value != null ? currentItem.value : currentItem.text;
98
- clearAllSelection(this.items);
99
- // set the selection of current one
100
- currentItem.selected = true;
101
- this.itemClick.emit(currentItem);
102
- this._onSelectionChange(this.selectedValue);
103
- }
104
- };
105
- /**
106
- * triggers with (blur) event of filter input box
107
- */
108
- /**
109
- * triggers with (blur) event of filter input box
110
- * @param {?} event
111
- * @return {?}
112
- */
113
- DropdownComponent.prototype.onFilterTextBlur = /**
114
- * triggers with (blur) event of filter input box
115
- * @param {?} event
116
- * @return {?}
117
- */
118
- function (event) {
119
- this.dropdownBlur.emit(event);
120
- };
121
- /**
122
- * triggers with (blur) event of dropdown
123
- */
124
- /**
125
- * triggers with (blur) event of dropdown
126
- * @param {?} event
127
- * @return {?}
128
- */
129
- DropdownComponent.prototype.onItemsBlur = /**
130
- * triggers with (blur) event of dropdown
131
- * @param {?} event
132
- * @return {?}
133
- */
134
- function (event) {
135
- if (this.checkbox) {
136
- if (this._clickedItems) {
137
- // in checkbox mode, this blur event will be ignored when clicking the dropdown (check the checkbox)
138
- event.target.focus();
139
- this._clickedItems = false;
140
- return;
141
- }
142
- }
143
- this.dropdownBlur.emit(event);
144
- };
145
- /**
146
- * toggle the selection when checking status changed (in checkbox mode)
147
- */
148
- /**
149
- * toggle the selection when checking status changed (in checkbox mode)
150
- * @param {?} item
151
- * @return {?}
152
- */
153
- DropdownComponent.prototype.toggleSelection = /**
154
- * toggle the selection when checking status changed (in checkbox mode)
155
- * @param {?} item
156
- * @return {?}
157
- */
158
- function (item) {
159
- item.selected = !item.selected;
160
- this.selectionChange.emit(this._getItemValue(item)); // item.value != null ? item.value : item.text);
161
- };
162
- Object.defineProperty(DropdownComponent.prototype, "itemsValues", {
163
- /**
164
- * items values list after applying the filter
165
- */
166
- get: /**
167
- * items values list after applying the filter
168
- * @return {?}
169
- */
170
- function () {
171
- /** @type {?} */
172
- var filter;
173
- if (this.filterValue) {
174
- filter = this.filterValue.toUpperCase();
175
- }
176
- if (filter == null) {
177
- return this.items;
178
- }
179
- if (!this.items || this.items.length === 0) {
180
- return [];
181
- }
182
- if (hasGroup(this.items)) {
183
- /** @type {?} */
184
- var items_1 = [];
185
- this.items.forEach((/**
186
- * @param {?} groupItem
187
- * @return {?}
188
- */
189
- function (groupItem) {
190
- if (groupItem.group != null && groupItem.group.toString().toUpperCase().includes(filter)) {
191
- // if groupItem contains the filters, the groupItem needs to be displayed as well
192
- items_1.push(groupItem);
193
- }
194
- else {
195
- /** @type {?} */
196
- var filteredItems = groupItem.items.filter((/**
197
- * @param {?} item
198
- * @return {?}
199
- */
200
- function (item) { return item.text != null && item.text.toString().toUpperCase().includes(filter); }));
201
- if (filteredItems && filteredItems.length > 0) {
202
- items_1.push({ group: groupItem.group, items: filteredItems });
203
- }
204
- }
205
- }));
206
- return items_1;
207
- }
208
- else {
209
- return this.items.filter((/**
210
- * @param {?} item
211
- * @return {?}
212
- */
213
- function (item) { return (item.text != null && item.text.toString().toUpperCase().includes(filter)); }));
214
- }
215
- },
216
- enumerable: true,
217
- configurable: true
218
- });
219
- Object.defineProperty(DropdownComponent.prototype, "optionsClass", {
220
- /**
221
- * options CSS class
222
- */
223
- get: /**
224
- * options CSS class
225
- * @return {?}
226
- */
227
- function () {
228
- if (this.filterBox && !this.checkbox) {
229
- return 'options with-filter';
230
- }
231
- else {
232
- return 'options no-filter';
233
- }
234
- },
235
- enumerable: true,
236
- configurable: true
237
- });
238
- /**
239
- * get item value. Return text if value is not available
240
- */
241
- /**
242
- * get item value. Return text if value is not available
243
- * @private
244
- * @param {?} item
245
- * @return {?}
246
- */
247
- DropdownComponent.prototype._getItemValue = /**
248
- * get item value. Return text if value is not available
249
- * @private
250
- * @param {?} item
251
- * @return {?}
252
- */
253
- function (item) {
254
- return item ? item.value != null ? item.value : item.text : undefined;
255
- };
256
- /**
257
- * selection changed, emits events: (selectedValueChange) and (selectionChange);
258
- */
259
- /**
260
- * selection changed, emits events: (selectedValueChange) and (selectionChange);
261
- * @private
262
- * @param {?} value
263
- * @return {?}
264
- */
265
- DropdownComponent.prototype._onSelectionChange = /**
266
- * selection changed, emits events: (selectedValueChange) and (selectionChange);
267
- * @private
268
- * @param {?} value
269
- * @return {?}
270
- */
271
- function (value) {
272
- this.selectedValueChange.emit(value);
273
- this.selectionChange.emit(value);
274
- };
275
- /**
276
- * check whether the selection is changed. Emits relative events when if changed.
277
- */
278
- /**
279
- * check whether the selection is changed. Emits relative events when if changed.
280
- * @private
281
- * @param {?} previousValue
282
- * @param {?} currentValue
283
- * @return {?}
284
- */
285
- DropdownComponent.prototype._checkSelectionChange = /**
286
- * check whether the selection is changed. Emits relative events when if changed.
287
- * @private
288
- * @param {?} previousValue
289
- * @param {?} currentValue
290
- * @return {?}
291
- */
292
- function (previousValue, currentValue) {
293
- /** @type {?} */
294
- var curSelectedItem = getFirstSelectedItem(currentValue);
295
- /** @type {?} */
296
- var lastSelectedItem = getFirstSelectedItem(previousValue);
297
- /** @type {?} */
298
- var curSelectedItemId = curSelectedItem ? curSelectedItem.id : undefined;
299
- /** @type {?} */
300
- var lastSelectedItemId = lastSelectedItem ? lastSelectedItem.id : undefined;
301
- if (curSelectedItemId !== lastSelectedItemId && !this.checkbox) {
302
- this._onSelectionChange(this._getItemValue(curSelectedItem));
303
- }
304
- };
305
- DropdownComponent.decorators = [
306
- { type: Component, args: [{
307
- selector: 'dropdown',
308
- template: "\n <span #dropdown class=\"dropdown\" tabindex=\"3\" (mousedown)=\"onItemsClick($event)\" (blur)=\"onItemsBlur($event)\" *ngIf=\"!disabled\" >\n <input-filter #filterInput tabindex=\"4\" *ngIf=\"filterBox && !checkbox\" [(filterValue)]=\"filterValue\" (inputFilterBlur)=\"onFilterTextBlur($event)\"></input-filter>\n <span #selectionOptions [ngClass]=\"optionsClass\">\n <ng-container *ngFor=\"let item of itemsValues\" >\n <ng-container *ngIf=\"item && item.group\">\n <group-item [item]=\"item\"></group-item>\n <item *ngFor=\"let subItem of item.items\" (itemClick)=\"onItemClick(subItem)\" (checkStatusChange)=\"toggleSelection(subItem)\"\n [item]=\"subItem\" [checkbox]=\"checkbox\" [formatNumber]=\"formatNumber\" [suffixText]=\"suffixText\">\n </item>\n </ng-container>\n <ng-container *ngIf=\"item && !item.group\">\n <item (itemClick)=\"onItemClick(item)\" (checkStatusChange)=\"toggleSelection(item)\"\n [item]=\"item\" [checkbox]=\"checkbox\" [formatNumber]=\"formatNumber\" [suffixText]=\"suffixText\">\n </item>\n </ng-container>\n </ng-container>\n </span>\n </span>\n ",
309
- styles: ["*,:after,:before{font-size:inherit;font-weight:inherit;font-family:inherit;box-sizing:inherit;background:inherit}.dropdown{width:100%;padding:0;display:none;margin:0;border:1px solid #66afe9;border-top:none;border-bottom:none;border-top-right-radius:0;border-top-left-radius:0;box-sizing:border-box;position:relative;z-index:999}.dropdown:focus{outline:0}.dropdown .options{width:calc(100% + 2px);left:0;box-sizing:border-box;background:#fff;position:absolute;max-height:228px;overflow-y:auto;overflow-x:hidden;border:1px solid #66afe9;border-top:none;border-bottom-right-radius:4px;border-bottom-left-radius:4px;margin-left:-1px;margin-right:-1px}.dropdown .with-filter{top:32px}.dropdown .no-filter{top:0}"]
310
- }] }
311
- ];
312
- DropdownComponent.propDecorators = {
313
- dropdownRef: [{ type: ViewChild, args: ['dropdown', { read: ElementRef },] }],
314
- filterInputRef: [{ type: ViewChild, args: ['filterInput', { read: ElementRef },] }],
315
- placeHolder: [{ type: Input }],
316
- items: [{ type: Input }],
317
- checkbox: [{ type: Input }],
318
- selectedValue: [{ type: Input }],
319
- filterBox: [{ type: Input }],
320
- suffixText: [{ type: Input }],
321
- disabled: [{ type: Input }],
322
- allowClear: [{ type: Input }],
323
- formatNumber: [{ type: Input }],
324
- selectedValueChange: [{ type: Output }],
325
- selectionChange: [{ type: Output }],
326
- dropdownBlur: [{ type: Output }],
327
- itemClick: [{ type: Output }]
328
- };
329
- return DropdownComponent;
330
- }());
331
- export { DropdownComponent };
332
- if (false) {
333
- /**
334
- * Child element reference of dropdown
335
- * @type {?}
336
- */
337
- DropdownComponent.prototype.dropdownRef;
338
- /**
339
- * Child element reference of filter input text
340
- * @type {?}
341
- */
342
- DropdownComponent.prototype.filterInputRef;
343
- /**
344
- * bind to [placeHolder] for displaying the place holder string of the anchor.
345
- * @type {?}
346
- */
347
- DropdownComponent.prototype.placeHolder;
348
- /**
349
- * bind to [items] for the options/groups in the dropdown
350
- * @type {?}
351
- */
352
- DropdownComponent.prototype.items;
353
- /**
354
- * bind to [checkbox], the flag for multi-select (checkbox) mode.
355
- * @type {?}
356
- */
357
- DropdownComponent.prototype.checkbox;
358
- /**
359
- * bind to [selectedValue] for the value of the selected option from dropdown
360
- * @type {?}
361
- */
362
- DropdownComponent.prototype.selectedValue;
363
- /**
364
- * bind to [filterBox] for displaying the filter input text box
365
- * @type {?}
366
- */
367
- DropdownComponent.prototype.filterBox;
368
- /**
369
- * bind to [suffixText] for displaying the suffix of the selected text of anchor
370
- * @type {?}
371
- */
372
- DropdownComponent.prototype.suffixText;
373
- /**
374
- * bind to [disabled] for disabling the dropdown
375
- * @type {?}
376
- */
377
- DropdownComponent.prototype.disabled;
378
- /**
379
- * bind to [allowClear] for enabling the clearance (clearance is not avaiable when checkbox is enabled)
380
- * @type {?}
381
- */
382
- DropdownComponent.prototype.allowClear;
383
- /**
384
- * bind to [formatNumber] for show formatted number text
385
- * @type {?}
386
- */
387
- DropdownComponent.prototype.formatNumber;
388
- /**
389
- * for 2-way binding of [selectedValue]
390
- * @type {?}
391
- */
392
- DropdownComponent.prototype.selectedValueChange;
393
- /**
394
- * [selectionChange] event that will be triggered when changing of the selection
395
- * @type {?}
396
- */
397
- DropdownComponent.prototype.selectionChange;
398
- /**
399
- * [dropdownBlur] event that will be triggered with (blur) of dropdown
400
- * @type {?}
401
- */
402
- DropdownComponent.prototype.dropdownBlur;
403
- /**
404
- * [itemClick] event that will be triggered when clicking the option of dropdown
405
- * @type {?}
406
- */
407
- DropdownComponent.prototype.itemClick;
408
- /**
409
- * filter value
410
- * @type {?}
411
- */
412
- DropdownComponent.prototype.filterValue;
413
- /**
414
- * flag of clicking dropdown. It's to prevent (blur) of dropdown from happening in checkbox mode.
415
- * @type {?}
416
- * @private
417
- */
418
- DropdownComponent.prototype._clickedItems;
419
- }
420
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"ng://ngx-dropdown-list/","sources":["src/ngx-dropdown-list/dropdown/dropdown.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, ElementRef, EventEmitter, Input, OnChanges, Output, SimpleChanges, ViewChild} from '@angular/core';\r\nimport {clearAllSelection, getFirstSelectedItem, hasGroup, stopPropagationAndDefault} from '../utils/util';\r\n\r\n@Component({\r\n  selector: 'dropdown',\r\n  template: `\r\n    <span #dropdown class=\"dropdown\" tabindex=\"3\" (mousedown)=\"onItemsClick($event)\" (blur)=\"onItemsBlur($event)\" *ngIf=\"!disabled\" >\r\n      <input-filter #filterInput tabindex=\"4\" *ngIf=\"filterBox && !checkbox\" [(filterValue)]=\"filterValue\" (inputFilterBlur)=\"onFilterTextBlur($event)\"></input-filter>\r\n      <span #selectionOptions [ngClass]=\"optionsClass\">\r\n        <ng-container *ngFor=\"let item of itemsValues\" >\r\n          <ng-container *ngIf=\"item && item.group\">\r\n            <group-item [item]=\"item\"></group-item>\r\n            <item *ngFor=\"let subItem of item.items\" (itemClick)=\"onItemClick(subItem)\" (checkStatusChange)=\"toggleSelection(subItem)\"\r\n                  [item]=\"subItem\" [checkbox]=\"checkbox\" [formatNumber]=\"formatNumber\" [suffixText]=\"suffixText\">\r\n            </item>\r\n          </ng-container>\r\n          <ng-container *ngIf=\"item && !item.group\">\r\n            <item (itemClick)=\"onItemClick(item)\" (checkStatusChange)=\"toggleSelection(item)\"\r\n                  [item]=\"item\" [checkbox]=\"checkbox\" [formatNumber]=\"formatNumber\" [suffixText]=\"suffixText\">\r\n            </item>\r\n          </ng-container>\r\n        </ng-container>\r\n      </span>\r\n    </span>\r\n  `,\r\n  styleUrls: ['./dropdown.component.scss']\r\n})\r\n\r\nexport class DropdownComponent implements OnChanges {\r\n  /**\r\n   * Child element reference of dropdown\r\n   */\r\n  @ViewChild('dropdown', { read: ElementRef }) dropdownRef: ElementRef;\r\n  /**\r\n   * Child element reference of filter input text\r\n   */\r\n  @ViewChild('filterInput', { read: ElementRef }) filterInputRef: ElementRef;\r\n  /**\r\n   * bind to [placeHolder] for displaying the place holder string of the anchor.\r\n   */\r\n  @Input() placeHolder: string;\r\n  /**\r\n   * bind to [items] for the options/groups in the dropdown\r\n   */\r\n  @Input() items: any[];\r\n  /**\r\n   * bind to [checkbox], the flag for multi-select (checkbox) mode.\r\n   */\r\n  @Input() checkbox = false;\r\n  /**\r\n   * bind to [selectedValue] for the value of the selected option from dropdown\r\n   */\r\n  @Input() selectedValue: any;\r\n  /**\r\n   * bind to [filterBox] for displaying the filter input text box\r\n   */\r\n  @Input() filterBox = false;\r\n  /**\r\n   * bind to [suffixText] for displaying the suffix of the selected text of anchor\r\n   */\r\n  @Input() suffixText: string;\r\n  /**\r\n   * bind to [disabled] for disabling the dropdown\r\n   */\r\n  @Input() disabled: boolean;\r\n  /**\r\n   * bind to [allowClear] for enabling the clearance (clearance is not avaiable when checkbox is enabled)\r\n   */\r\n  @Input() allowClear = true;\r\n  /**\r\n   * bind to [formatNumber] for show formatted number text\r\n   */\r\n  @Input() formatNumber = false;\r\n  /**\r\n   * for 2-way binding of [selectedValue]\r\n   */\r\n  @Output() selectedValueChange = new EventEmitter<string>(true);\r\n  /**\r\n   * [selectionChange] event that will be triggered when changing of the selection\r\n   */\r\n  @Output() selectionChange = new EventEmitter<any>(true);\r\n  /**\r\n   * [dropdownBlur] event that will be triggered with (blur) of dropdown\r\n   */\r\n  @Output() dropdownBlur = new EventEmitter<any>();\r\n  /**\r\n   * [itemClick] event that will be triggered when clicking the option of dropdown\r\n   */\r\n  @Output() itemClick = new EventEmitter<any>();\r\n  /**\r\n   * filter value\r\n   */\r\n  filterValue: string;\r\n  /**\r\n   * flag of clicking dropdown. It's to prevent (blur) of dropdown from happening in checkbox mode.\r\n   */\r\n  private _clickedItems = false;\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (changes.items) {\r\n      this._checkSelectionChange(changes.items.previousValue, changes.items.currentValue);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * triggered when clicking the dropdown\r\n   */\r\n  onItemsClick(event: any): void {\r\n    if (event.offsetX > (event.target.clientWidth + event.target.clientLeft)) {\r\n      stopPropagationAndDefault(event);\r\n      return;\r\n    }\r\n    // should ignore clicking on filter\r\n    if (this.checkbox && event.target.type !== 'text') {\r\n      this._clickedItems = true;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * triggered when clicking the item\r\n   */\r\n  onItemClick(currentItem): void {\r\n    if (!this.checkbox) {\r\n      this.selectedValue = this._getItemValue(currentItem); // currentItem.value != null ? currentItem.value : currentItem.text;\r\n      clearAllSelection(this.items);\r\n      // set the selection of current one\r\n      currentItem.selected = true;\r\n      this.itemClick.emit(currentItem);\r\n      this._onSelectionChange(this.selectedValue);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * triggers with (blur) event of filter input box\r\n   */\r\n  onFilterTextBlur(event): void {\r\n    this.dropdownBlur.emit(event);\r\n  }\r\n\r\n  /**\r\n   * triggers with (blur) event of dropdown\r\n   */\r\n  onItemsBlur(event): void {\r\n    if (this.checkbox) {\r\n      if (this._clickedItems) {\r\n        // in checkbox mode, this blur event will be ignored when clicking the dropdown (check the checkbox)\r\n        event.target.focus();\r\n        this._clickedItems = false;\r\n        return;\r\n      }\r\n    }\r\n    this.dropdownBlur.emit(event);\r\n  }\r\n\r\n  /**\r\n   * toggle the selection when checking status changed (in checkbox mode)\r\n   */\r\n  toggleSelection(item: {id: string, value?: any, text: any, selected?: boolean}): void {\r\n    item.selected = !item.selected;\r\n    this.selectionChange.emit(this._getItemValue(item)); // item.value != null ? item.value : item.text);\r\n  }\r\n\r\n  /**\r\n   * items values list after applying the filter\r\n   */\r\n  get itemsValues(): any[] {\r\n    let filter;\r\n    if (this.filterValue) {\r\n      filter = this.filterValue.toUpperCase();\r\n    }\r\n\r\n    if (filter == null) {\r\n      return this.items;\r\n    }\r\n    if (!this.items || this.items.length === 0) {\r\n      return [];\r\n    }\r\n    if (hasGroup(this.items)) {\r\n      const items = [];\r\n      this.items.forEach(groupItem => {\r\n        if (groupItem.group != null && groupItem.group.toString().toUpperCase().includes(filter)) {\r\n          // if groupItem contains the filters, the groupItem needs to be displayed as well\r\n          items.push(groupItem);\r\n        } else {\r\n          const filteredItems = groupItem.items.filter(item => item.text != null && item.text.toString().toUpperCase().includes(filter));\r\n          if (filteredItems && filteredItems.length > 0) {\r\n            items.push({group: groupItem.group, items: filteredItems});\r\n          }\r\n        }\r\n      });\r\n      return items;\r\n    } else {\r\n      return this.items.filter(item => (item.text != null && item.text.toString().toUpperCase().includes(filter)));\r\n    }\r\n  }\r\n  /**\r\n   * options CSS class\r\n   */\r\n  get optionsClass(): string {\r\n    if (this.filterBox && !this.checkbox) {\r\n      return 'options with-filter';\r\n    } else {\r\n      return 'options no-filter';\r\n    }\r\n  }\r\n\r\n  /**\r\n   * get item value. Return text if value is not available\r\n   */\r\n  private _getItemValue(item): any {\r\n    return item ? item.value != null ? item.value : item.text : undefined;\r\n  }\r\n\r\n  /**\r\n   * selection changed, emits events: (selectedValueChange) and (selectionChange);\r\n   */\r\n  private _onSelectionChange(value) {\r\n    this.selectedValueChange.emit(value);\r\n    this.selectionChange.emit(value);\r\n  }\r\n\r\n  /**\r\n   * check whether the selection is changed. Emits relative events when if changed.\r\n   */\r\n  private _checkSelectionChange(previousValue, currentValue) {\r\n    const curSelectedItem = getFirstSelectedItem(currentValue);\r\n    const lastSelectedItem = getFirstSelectedItem(previousValue);\r\n    const curSelectedItemId = curSelectedItem ? curSelectedItem.id : undefined;\r\n    const lastSelectedItemId = lastSelectedItem ? lastSelectedItem.id : undefined;\r\n    if (curSelectedItemId !== lastSelectedItemId && !this.checkbox) {\r\n      this._onSelectionChange(this._getItemValue(curSelectedItem));\r\n    }\r\n  }\r\n}\r\n"]}