ngx-dropdown-list 1.1.0 → 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 (65) 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 -1180
  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 -339
  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 -73
  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 -408
  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 -96
  61. package/fesm2015/ngx-dropdown-list.js +0 -890
  62. package/fesm2015/ngx-dropdown-list.js.map +0 -1
  63. package/fesm5/ngx-dropdown-list.js +0 -1137
  64. package/fesm5/ngx-dropdown-list.js.map +0 -1
  65. package/ngx-dropdown-list.metadata.json +0 -1
@@ -1,1137 +0,0 @@
1
- import { __values } from 'tslib';
2
- import { Component, ElementRef, EventEmitter, Input, Output, ViewChild, NgModule } from '@angular/core';
3
- import { DecimalPipe, CommonModule } from '@angular/common';
4
- import { FormsModule } from '@angular/forms';
5
-
6
- /**
7
- * @fileoverview added by tsickle
8
- * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
9
- */
10
- /**
11
- * check whether the provided items contains group
12
- * @param {?} items
13
- * @return {?}
14
- */
15
- function hasGroup(items) {
16
- return items ? (items.find(function (item) { return item.group; }) != null) : false;
17
- }
18
- /**
19
- * clear all selections from the provide items.
20
- * @param {?} items the dropdown items, can be group or item
21
- * @return {?}
22
- */
23
- function clearAllSelection(items) {
24
- var e_1, _a;
25
- if (hasGroup(items)) {
26
- try {
27
- for (var items_1 = __values(items), items_1_1 = items_1.next(); !items_1_1.done; items_1_1 = items_1.next()) {
28
- var groupItem = items_1_1.value;
29
- if (groupItem.items) {
30
- groupItem.items.filter(function (item) { return item.selected; }).forEach(function (item) { return item.selected = false; });
31
- }
32
- }
33
- }
34
- catch (e_1_1) { e_1 = { error: e_1_1 }; }
35
- finally {
36
- try {
37
- if (items_1_1 && !items_1_1.done && (_a = items_1.return)) _a.call(items_1);
38
- }
39
- finally { if (e_1) throw e_1.error; }
40
- }
41
- }
42
- else {
43
- // clear the selection of previous selected item
44
- items.filter(function (item) { return item.selected; }).forEach(function (item) { return item.selected = false; });
45
- }
46
- }
47
- /**
48
- * stop all propagation and default actions
49
- * @param {?} event
50
- * @return {?}
51
- */
52
- function stopPropagationAndDefault(event) {
53
- event.stopImmediatePropagation();
54
- event.stopPropagation();
55
- event.preventDefault();
56
- }
57
- /**
58
- * check whether the provided value is number of not
59
- * @param {?} value
60
- * @return {?}
61
- */
62
- function isNumber(value) {
63
- return !(value == null || isNaN(value) || value.length === 0);
64
- }
65
- /**
66
- * get the selected item from the items list (including item and group)
67
- * @param {?} items
68
- * @return {?}
69
- */
70
- function getFirstSelectedItem(items) {
71
- var e_2, _a;
72
- if (!items) {
73
- return undefined;
74
- }
75
- /** @type {?} */
76
- var selectedItem;
77
- if (hasGroup(items)) {
78
- try {
79
- for (var items_2 = __values(items), items_2_1 = items_2.next(); !items_2_1.done; items_2_1 = items_2.next()) {
80
- var item = items_2_1.value;
81
- selectedItem = item.items ? item.items.find(function (subItem) { return subItem.selected; }) : undefined;
82
- if (selectedItem) {
83
- break;
84
- }
85
- }
86
- }
87
- catch (e_2_1) { e_2 = { error: e_2_1 }; }
88
- finally {
89
- try {
90
- if (items_2_1 && !items_2_1.done && (_a = items_2.return)) _a.call(items_2);
91
- }
92
- finally { if (e_2) throw e_2.error; }
93
- }
94
- }
95
- else {
96
- selectedItem = items ? items.find(function (item) { return item.selected; }) : undefined;
97
- }
98
- return selectedItem;
99
- }
100
-
101
- /**
102
- * @fileoverview added by tsickle
103
- * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
104
- */
105
- var DropdownListComponent = /** @class */ (function () {
106
- function DropdownListComponent() {
107
- /**
108
- * bind to [multiSelection], the flag for multi-select (checkbox) mode.
109
- */
110
- this.multiSelection = false;
111
- /**
112
- * bind to [filterBox] for displaying the filter input text box
113
- */
114
- this.filterBox = false;
115
- /**
116
- * bind to [allowClear] for enabling the clearance (clearance is not avaiable when checkbox is enabled)
117
- */
118
- this.allowClear = true;
119
- /**
120
- * bind to [formatNumber] for show formatted number text
121
- */
122
- this.formatNumber = false;
123
- /**
124
- * for 2-way binding of [selectedValue], using async event to
125
- * prevent "ExpressionChangedAfterItHasBeenCheckedError".
126
- */
127
- this.selectedValueChange = new EventEmitter(true);
128
- /**
129
- * [selectionChange] event that will be triggered when changing of the selection.
130
- * Using async event to prevent "ExpressionChangedAfterItHasBeenCheckedError".
131
- */
132
- this.selectionChange = new EventEmitter(true);
133
- /**
134
- * visibility flag of drop down
135
- */
136
- this.dropdownVisibility = false;
137
- }
138
- Object.defineProperty(DropdownListComponent.prototype, "selectedText", {
139
- /**
140
- * current selected text
141
- */
142
- get: /**
143
- * current selected text
144
- * @return {?}
145
- */
146
- function () {
147
- if (!this.multiSelection) {
148
- /** @type {?} */
149
- var selectedItem = getFirstSelectedItem(this.items);
150
- return selectedItem ? selectedItem.text : undefined;
151
- }
152
- },
153
- enumerable: true,
154
- configurable: true
155
- });
156
- /**
157
- * triggered with (selectionChange) event, emits (selectedValueChange) and (selectionChange)
158
- */
159
- /**
160
- * triggered with (selectionChange) event, emits (selectedValueChange) and (selectionChange)
161
- * @param {?} event
162
- * @return {?}
163
- */
164
- DropdownListComponent.prototype.onSelectionChange = /**
165
- * triggered with (selectionChange) event, emits (selectedValueChange) and (selectionChange)
166
- * @param {?} event
167
- * @return {?}
168
- */
169
- function (event) {
170
- this.selectedValueChange.emit(event);
171
- this.selectionChange.emit(event);
172
- };
173
- /**
174
- * triggered with (anchorClick) event, controlling the "open" and "close" of the dropdown
175
- */
176
- /**
177
- * triggered with (anchorClick) event, controlling the "open" and "close" of the dropdown
178
- * @param {?} event
179
- * @return {?}
180
- */
181
- DropdownListComponent.prototype.onAnchorClick = /**
182
- * triggered with (anchorClick) event, controlling the "open" and "close" of the dropdown
183
- * @param {?} event
184
- * @return {?}
185
- */
186
- function (event) {
187
- if (this.disabled) {
188
- stopPropagationAndDefault(event);
189
- return;
190
- }
191
- if (this._isSelectionOpen()) {
192
- this._hideItemList();
193
- }
194
- else {
195
- this._showItemsList();
196
- }
197
- stopPropagationAndDefault(event);
198
- };
199
- /**
200
- * triggered with (itemClick) event, closes the dropdown in non-checkbox mode
201
- */
202
- /**
203
- * triggered with (itemClick) event, closes the dropdown in non-checkbox mode
204
- * @return {?}
205
- */
206
- DropdownListComponent.prototype.onItemClick = /**
207
- * triggered with (itemClick) event, closes the dropdown in non-checkbox mode
208
- * @return {?}
209
- */
210
- function () {
211
- if (!this.multiSelection) {
212
- this._hideItemList();
213
- }
214
- };
215
- /**
216
- * triggered with (clearanceClick) event, clearing all selections
217
- * and emits (selectedValueChange) and (selectionChange) event for empty value
218
- */
219
- /**
220
- * triggered with (clearanceClick) event, clearing all selections
221
- * and emits (selectedValueChange) and (selectionChange) event for empty value
222
- * @param {?} event
223
- * @return {?}
224
- */
225
- DropdownListComponent.prototype.onClearanceClick = /**
226
- * triggered with (clearanceClick) event, clearing all selections
227
- * and emits (selectedValueChange) and (selectionChange) event for empty value
228
- * @param {?} event
229
- * @return {?}
230
- */
231
- function (event) {
232
- if (!this.multiSelection) {
233
- this.selectedValue = void 0;
234
- this.selectedValueChange.emit(undefined);
235
- this.selectionChange.emit(undefined);
236
- clearAllSelection(this.items);
237
- }
238
- stopPropagationAndDefault(event);
239
- };
240
- /**
241
- * triggered with (dropdownBlur) event, closes the dropdown
242
- */
243
- /**
244
- * triggered with (dropdownBlur) event, closes the dropdown
245
- * @return {?}
246
- */
247
- DropdownListComponent.prototype.onItemsBlur = /**
248
- * triggered with (dropdownBlur) event, closes the dropdown
249
- * @return {?}
250
- */
251
- function () {
252
- if (this._isSelectionOpen()) {
253
- this._hideItemList();
254
- }
255
- };
256
- /**
257
- * close the dropdown
258
- */
259
- /**
260
- * close the dropdown
261
- * @private
262
- * @return {?}
263
- */
264
- DropdownListComponent.prototype._hideItemList = /**
265
- * close the dropdown
266
- * @private
267
- * @return {?}
268
- */
269
- function () {
270
- // hide the dropdown element (has some problem for using CSS directly, using this as a workaround)
271
- this._dropdownElement.classList.remove('visible');
272
- this._dropdownElement.style.display = 'none';
273
- this.dropdownVisibility = false;
274
- };
275
- /**
276
- * open the dropdown
277
- */
278
- /**
279
- * open the dropdown
280
- * @private
281
- * @return {?}
282
- */
283
- DropdownListComponent.prototype._showItemsList = /**
284
- * open the dropdown
285
- * @private
286
- * @return {?}
287
- */
288
- function () {
289
- // display the dropdown element (has some problem for using CSS directly, using this as a workaround)
290
- this._dropdownElement.classList.add('visible');
291
- this._dropdownElement.style.display = 'block';
292
- this.dropdownVisibility = true;
293
- // scrolling to the selected item
294
- if (this._selectedElement) {
295
- this._selectedElement.scrollIntoView({ behavior: 'instant', block: 'center' });
296
- }
297
- // setting the focus
298
- if (this.filterBox && !this.multiSelection) {
299
- this._filterInputElement.focus();
300
- }
301
- else {
302
- this._dropdownElement.focus();
303
- }
304
- };
305
- /**
306
- * visibility status of dropdown
307
- */
308
- /**
309
- * visibility status of dropdown
310
- * @private
311
- * @return {?}
312
- */
313
- DropdownListComponent.prototype._isSelectionOpen = /**
314
- * visibility status of dropdown
315
- * @private
316
- * @return {?}
317
- */
318
- function () {
319
- return this.dropdownVisibility;
320
- };
321
- Object.defineProperty(DropdownListComponent.prototype, "_dropdownElement", {
322
- /**
323
- * get the real dropdown element (for focusing and visibility controlling), the <span> not the <dropdown>
324
- */
325
- get: /**
326
- * get the real dropdown element (for focusing and visibility controlling), the <span> not the <dropdown>
327
- * @private
328
- * @return {?}
329
- */
330
- function () {
331
- return this.dropdownRef ? this.dropdownRef.nativeElement ? this.dropdownRef.nativeElement.firstElementChild : null : null;
332
- },
333
- enumerable: true,
334
- configurable: true
335
- });
336
- Object.defineProperty(DropdownListComponent.prototype, "_filterInputElement", {
337
- /**
338
- * get the real filter element (for focusing), the <input> not the <input-filter>
339
- */
340
- get: /**
341
- * get the real filter element (for focusing), the <input> not the <input-filter>
342
- * @private
343
- * @return {?}
344
- */
345
- function () {
346
- return this._dropdownElement ?
347
- this._dropdownElement.firstElementChild ? this._dropdownElement.firstElementChild.firstElementChild : null : null;
348
- },
349
- enumerable: true,
350
- configurable: true
351
- });
352
- Object.defineProperty(DropdownListComponent.prototype, "_selectedElement", {
353
- /**
354
- * get the HTMLElement of selected item, for doing (scrollIntoView) scrolling to the selected item
355
- */
356
- get: /**
357
- * get the HTMLElement of selected item, for doing (scrollIntoView) scrolling to the selected item
358
- * @private
359
- * @return {?}
360
- */
361
- function () {
362
- /** @type {?} */
363
- var selectedItem = getFirstSelectedItem(this.items);
364
- return selectedItem ? (/** @type {?} */ (document.getElementById(selectedItem.id))) : undefined;
365
- },
366
- enumerable: true,
367
- configurable: true
368
- });
369
- DropdownListComponent.decorators = [
370
- { type: Component, args: [{
371
- selector: 'ngx-dropdown-list',
372
- template: "\n <span class=\"ngx-select\">\n <anchor (anchorClick)=\"onAnchorClick($event)\" (clearanceClick)=\"onClearanceClick($event)\"\n [checkbox]=\"multiSelection\"\n [formatNumber]=\"formatNumber\"\n [suffixText]=\"suffixText\"\n [placeHolder]=\"placeHolder\"\n [allowClear]=\"allowClear\"\n [openStatus]=\"dropdownVisibility\"\n [selectedText]=\"selectedText\"\n [disabled]=\"disabled\">\n </anchor>\n <dropdown #dropdown (dropdownBlur) = \"onItemsBlur()\" (selectionChange)=\"onSelectionChange($event)\"\n [items]=\"items\"\n [checkbox]=\"multiSelection\"\n [filterBox]=\"filterBox\"\n [formatNumber]=\"formatNumber\"\n [suffixText]=\"suffixText\"\n [(selectedValue)]=\"selectedValue\"\n (itemClick) = \"onItemClick()\"\n [disabled]=\"disabled\">\n </dropdown>\n </span>\n ",
373
- styles: [":host *,:host :after,:host :before{font-size:inherit;font-weight:inherit;font-family:inherit;box-sizing:inherit;background:inherit}:host .ngx-select{border-radius:4px;font-size:14px;position:relative;display:inline-block;width:100%;height:34px;background:#fff;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}"]
374
- }] }
375
- ];
376
- DropdownListComponent.propDecorators = {
377
- dropdownRef: [{ type: ViewChild, args: ['dropdown', { read: ElementRef },] }],
378
- placeHolder: [{ type: Input }],
379
- items: [{ type: Input }],
380
- multiSelection: [{ type: Input }],
381
- selectedValue: [{ type: Input }],
382
- filterBox: [{ type: Input }],
383
- suffixText: [{ type: Input }],
384
- disabled: [{ type: Input }],
385
- allowClear: [{ type: Input }],
386
- formatNumber: [{ type: Input }],
387
- selectedValueChange: [{ type: Output }],
388
- selectionChange: [{ type: Output }]
389
- };
390
- return DropdownListComponent;
391
- }());
392
-
393
- /**
394
- * @fileoverview added by tsickle
395
- * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
396
- */
397
- var ItemComponent = /** @class */ (function () {
398
- function ItemComponent() {
399
- /**
400
- * bind to [formatNumber], the flag for formatting the number
401
- */
402
- this.formatNumber = false;
403
- /**
404
- * bind to [itemClick] event, triggers when clicking the item of dropdown
405
- */
406
- this.itemClick = new EventEmitter();
407
- /**
408
- * bind to [checkStatusChange] event, triggers when check status is changed in checkbox mode.
409
- */
410
- this.checkStatusChange = new EventEmitter();
411
- }
412
- /**
413
- * check whether needs to format number for the provided text
414
- */
415
- /**
416
- * check whether needs to format number for the provided text
417
- * @param {?} value
418
- * @return {?}
419
- */
420
- ItemComponent.prototype.needFormatNumber = /**
421
- * check whether needs to format number for the provided text
422
- * @param {?} value
423
- * @return {?}
424
- */
425
- function (value) {
426
- return isNumber(value) && this.formatNumber;
427
- };
428
- /**
429
- * triggered when clicking the item, emits the [itemClick] event
430
- */
431
- /**
432
- * triggered when clicking the item, emits the [itemClick] event
433
- * @param {?} item
434
- * @return {?}
435
- */
436
- ItemComponent.prototype.onItemClick = /**
437
- * triggered when clicking the item, emits the [itemClick] event
438
- * @param {?} item
439
- * @return {?}
440
- */
441
- function (item) {
442
- this.itemClick.emit(item);
443
- };
444
- /**
445
- * triggered when checking status changed in checkbox mode, emits the [checkStatusChange] event
446
- */
447
- /**
448
- * triggered when checking status changed in checkbox mode, emits the [checkStatusChange] event
449
- * @param {?} item
450
- * @return {?}
451
- */
452
- ItemComponent.prototype.onCheckStatusChange = /**
453
- * triggered when checking status changed in checkbox mode, emits the [checkStatusChange] event
454
- * @param {?} item
455
- * @return {?}
456
- */
457
- function (item) {
458
- this.checkStatusChange.emit(item);
459
- };
460
- ItemComponent.decorators = [
461
- { type: Component, args: [{
462
- selector: 'item',
463
- template: "\n <label [class.container-checkbox]=\"checkbox\"\n [class.container-selection]=\"!checkbox && !item.selected\"\n [class.container-selection-selected]=\"!checkbox && item.selected\"\n [id]=\"item.id\" (mousedown)=\"onItemClick(item)\">\n {{needFormatNumber(item.text)? (item.text | number:'1.0-2') : item.text}}{{suffixText? suffixText : ''}}\n <ng-container *ngIf=\"checkbox\">\n <input type='checkbox' [id]=\"'checkbox-'+item.text\" (change)=\"onCheckStatusChange(item)\" [checked]=\"item.selected\">\n <span class=\"checkmark\" [id]=\"'checkmark-'+item.text\"></span>\n </ng-container>\n </label>",
464
- styles: ["*,:after,:before{font-size:inherit;font-weight:inherit;font-family:inherit;box-sizing:inherit;background:inherit}.container-checkbox,.container-selection,.container-selection-selected,.dropdown-item{background:0 0;display:list-item;list-style:none;position:relative;width:100%;height:auto;cursor:pointer;color:#495057;padding-bottom:5px;padding-top:5px;padding-left:12px}.container-checkbox{padding-left:35px}.container-checkbox input{position:absolute;opacity:0;cursor:pointer}.container-checkbox .checkmark{position:absolute;top:5px;left:10px;height:15px;width:15px;border:1px solid rgba(0,0,0,.3);background-color:#fff;border-radius:4px}.container-checkbox .checkmark:after{content:\"\";position:absolute;display:none;left:5px;top:2px;width:4px;height:7px;border:solid #fff;border-width:0 2px 2px 0;-webkit-transform:rotate(45deg);transform:rotate(45deg)}.container-checkbox:hover input~.checkmark{background-color:#ccc}.container-checkbox input:checked~.checkmark{background-color:#2196f3;border:1px solid #2196f3}.container-checkbox input:checked~.checkmark:after{display:block}.container-checkbox:hover{color:#66afe9}.container-selection,.container-selection-selected{padding-left:12px}.container-selection-selected:hover,.container-selection:hover{color:#495057;background:#e0ffff}.container-selection-selected{color:#fff;background:#6495ed}"]
465
- }] }
466
- ];
467
- ItemComponent.propDecorators = {
468
- checkbox: [{ type: Input }],
469
- item: [{ type: Input }],
470
- formatNumber: [{ type: Input }],
471
- suffixText: [{ type: Input }],
472
- itemClick: [{ type: Output }],
473
- checkStatusChange: [{ type: Output }]
474
- };
475
- return ItemComponent;
476
- }());
477
-
478
- /**
479
- * @fileoverview added by tsickle
480
- * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
481
- */
482
- var GroupItemComponent = /** @class */ (function () {
483
- function GroupItemComponent() {
484
- }
485
- /**
486
- * prevent all clicking event from happening
487
- */
488
- /**
489
- * prevent all clicking event from happening
490
- * @param {?} event
491
- * @return {?}
492
- */
493
- GroupItemComponent.prototype.onItemGroupClick = /**
494
- * prevent all clicking event from happening
495
- * @param {?} event
496
- * @return {?}
497
- */
498
- function (event) {
499
- event.stopImmediatePropagation();
500
- event.stopPropagation();
501
- event.preventDefault();
502
- };
503
- GroupItemComponent.decorators = [
504
- { type: Component, args: [{
505
- selector: 'group-item',
506
- template: "\n <label class=\"dropdown-item dropdown-item-group\" (mousedown)=\"onItemGroupClick($event)\">{{item.group}}</label>\n ",
507
- styles: ["*,:after,:before{font-size:inherit;font-weight:inherit;font-family:inherit;box-sizing:inherit;background:inherit}.container-checkbox,.container-selection,.container-selection-selected,.dropdown-item{background:0 0;display:list-item;list-style:none;position:relative;width:100%;height:auto;cursor:pointer;color:#495057;padding-bottom:5px;padding-top:5px;padding-left:12px}.container-checkbox{padding-left:35px}.container-checkbox input{position:absolute;opacity:0;cursor:pointer}.container-checkbox .checkmark{position:absolute;top:5px;left:10px;height:15px;width:15px;border:1px solid rgba(0,0,0,.3);background-color:#fff;border-radius:4px}.container-checkbox .checkmark:after{content:\"\";position:absolute;display:none;left:5px;top:2px;width:4px;height:7px;border:solid #fff;border-width:0 2px 2px 0;-webkit-transform:rotate(45deg);transform:rotate(45deg)}.container-checkbox:hover input~.checkmark{background-color:#ccc}.container-checkbox input:checked~.checkmark{background-color:#2196f3;border:1px solid #2196f3}.container-checkbox input:checked~.checkmark:after{display:block}.container-checkbox:hover{color:#66afe9}.container-selection,.container-selection-selected{padding-left:12px}.container-selection-selected:hover,.container-selection:hover{color:#495057;background:#e0ffff}.container-selection-selected{color:#fff;background:#6495ed}.dropdown-item-group{font-weight:700}.dropdown-item-group:hover{cursor:default}"]
508
- }] }
509
- ];
510
- GroupItemComponent.propDecorators = {
511
- item: [{ type: Input }]
512
- };
513
- return GroupItemComponent;
514
- }());
515
-
516
- /**
517
- * @fileoverview added by tsickle
518
- * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
519
- */
520
- var InputFilterComponent = /** @class */ (function () {
521
- function InputFilterComponent() {
522
- /**
523
- * bind to [inputFilterBlur], emits with (blur) of filter input box
524
- */
525
- this.inputFilterBlur = new EventEmitter();
526
- /**
527
- * bind to [filterValueChange], for 2-way binding of filterValue
528
- */
529
- this.filterValueChange = new EventEmitter();
530
- }
531
- /**
532
- * triggers with (blur) event, emits the (inputFilterBlur) event
533
- */
534
- /**
535
- * triggers with (blur) event, emits the (inputFilterBlur) event
536
- * @param {?} event
537
- * @return {?}
538
- */
539
- InputFilterComponent.prototype.onFilterTextBlur = /**
540
- * triggers with (blur) event, emits the (inputFilterBlur) event
541
- * @param {?} event
542
- * @return {?}
543
- */
544
- function (event) {
545
- this.inputFilterBlur.emit(event);
546
- };
547
- /**
548
- * triggers with (input) event, emits the (filterValueChange) event for 2-way binding of filterValue
549
- */
550
- /**
551
- * triggers with (input) event, emits the (filterValueChange) event for 2-way binding of filterValue
552
- * @return {?}
553
- */
554
- InputFilterComponent.prototype.onChange = /**
555
- * triggers with (input) event, emits the (filterValueChange) event for 2-way binding of filterValue
556
- * @return {?}
557
- */
558
- function () {
559
- this.filterValueChange.emit(this.filterValue);
560
- };
561
- InputFilterComponent.decorators = [
562
- { type: Component, args: [{
563
- selector: 'input-filter',
564
- template: "\n <input type=\"text\" class=\"filter-box\" [(ngModel)]=\"filterValue\" (input)=\"onChange()\" (blur)=\"onFilterTextBlur($event)\">\n ",
565
- styles: ["*,:after,:before{font-size:inherit;font-weight:inherit;font-family:inherit;box-sizing:inherit;background:inherit}.filter-box{width:calc(100% - 10px);height:28px;border-radius:4px;border:1px solid #ccc;margin:1px 5px 5px;padding-left:5px;font-size:12px;box-sizing:border-box;color:#495057}.filter-box:focus{outline:0;border-color:#ccc}"]
566
- }] }
567
- ];
568
- InputFilterComponent.propDecorators = {
569
- filterValue: [{ type: Input }],
570
- inputFilterBlur: [{ type: Output }],
571
- filterValueChange: [{ type: Output }]
572
- };
573
- return InputFilterComponent;
574
- }());
575
-
576
- /**
577
- * @fileoverview added by tsickle
578
- * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
579
- */
580
- var AnchorComponent = /** @class */ (function () {
581
- function AnchorComponent(_decimalPipe) {
582
- this._decimalPipe = _decimalPipe;
583
- /**
584
- * bind to [checkbox] for checking whether the clearance flag should be shown or not.
585
- */
586
- this.checkbox = false;
587
- /**
588
- * bind to [allowClear] for enabling the clearance (clearance is not avaiable when checkbox is enabled)
589
- */
590
- this.allowClear = true;
591
- /**
592
- * bind to [openStatus], it's the visibility status of dropdown, for showing the arrow on anchor
593
- */
594
- this.openStatus = false;
595
- /**
596
- * bind to [disabled] for disabling the anchor
597
- */
598
- this.disabled = false;
599
- /**
600
- * will be triggered when clicking the anchor
601
- */
602
- this.anchorClick = new EventEmitter();
603
- /**
604
- * will be triggered when clicking the clearance
605
- */
606
- this.clearanceClick = new EventEmitter();
607
- }
608
- Object.defineProperty(AnchorComponent.prototype, "showClearanceFlag", {
609
- /**
610
- * flag for showing the clearance flag
611
- */
612
- get: /**
613
- * flag for showing the clearance flag
614
- * @return {?}
615
- */
616
- function () {
617
- return !this.checkbox && this.selectedText && this.allowClear;
618
- },
619
- enumerable: true,
620
- configurable: true
621
- });
622
- Object.defineProperty(AnchorComponent.prototype, "anchorDisplayText", {
623
- /**
624
- * the text displays on anchor
625
- */
626
- get: /**
627
- * the text displays on anchor
628
- * @return {?}
629
- */
630
- function () {
631
- /** @type {?} */
632
- var anchorDisplayText = this.selectedText ? (this.formatNumber ? (isNumber(this.selectedText) ?
633
- this._decimalPipe.transform(this.selectedText, '1.0-2') : this.selectedText) :
634
- this.selectedText) + (this.suffixText ? this.suffixText : '') : this.placeHolder;
635
- /** @type {?} */
636
- var charLength = 1;
637
- if (this.showClearanceFlag && this.anchorLength > 0) {
638
- charLength = Math.floor((this.anchorLength - 50) / 7);
639
- }
640
- else {
641
- charLength = Math.floor((this.anchorLength - 50) / 7);
642
- }
643
- if (anchorDisplayText.length > charLength) {
644
- anchorDisplayText = anchorDisplayText.slice(0, charLength - 2) + '...';
645
- }
646
- return anchorDisplayText;
647
- },
648
- enumerable: true,
649
- configurable: true
650
- });
651
- Object.defineProperty(AnchorComponent.prototype, "anchorClass", {
652
- /**
653
- * anchor CSS class
654
- */
655
- get: /**
656
- * anchor CSS class
657
- * @return {?}
658
- */
659
- function () {
660
- /** @type {?} */
661
- var anchorClassStatusPart;
662
- /** @type {?} */
663
- var anchorClassFontColor;
664
- if (this.disabled) {
665
- anchorClassStatusPart = 'selection-anchor-disabled';
666
- anchorClassFontColor = 'place-holder';
667
- }
668
- else {
669
- if (this.openStatus) {
670
- anchorClassStatusPart = 'selection-anchor-open';
671
- }
672
- else {
673
- anchorClassStatusPart = 'selection-anchor-close';
674
- }
675
- if (this.selectedText != null) {
676
- anchorClassFontColor = 'selected-item';
677
- }
678
- else {
679
- anchorClassFontColor = 'place-holder';
680
- }
681
- }
682
- return anchorClassStatusPart + " " + anchorClassFontColor;
683
- },
684
- enumerable: true,
685
- configurable: true
686
- });
687
- /**
688
- * triggered when clicking the anchor
689
- */
690
- /**
691
- * triggered when clicking the anchor
692
- * @param {?} event
693
- * @return {?}
694
- */
695
- AnchorComponent.prototype.onAnchorClick = /**
696
- * triggered when clicking the anchor
697
- * @param {?} event
698
- * @return {?}
699
- */
700
- function (event) {
701
- this.anchorClick.emit(event);
702
- };
703
- /**
704
- * triggered with (blur) of anchor
705
- */
706
- /**
707
- * triggered with (blur) of anchor
708
- * @param {?} event
709
- * @return {?}
710
- */
711
- AnchorComponent.prototype.onAnchorBlur = /**
712
- * triggered with (blur) of anchor
713
- * @param {?} event
714
- * @return {?}
715
- */
716
- function (event) {
717
- stopPropagationAndDefault(event);
718
- };
719
- /**
720
- * triggered when clicking the clearance
721
- */
722
- /**
723
- * triggered when clicking the clearance
724
- * @param {?} event
725
- * @return {?}
726
- */
727
- AnchorComponent.prototype.onClearanceClick = /**
728
- * triggered when clicking the clearance
729
- * @param {?} event
730
- * @return {?}
731
- */
732
- function (event) {
733
- this.clearanceClick.emit(event);
734
- };
735
- /**
736
- * triggered when resizing, get the clientWidth of anchor
737
- */
738
- /**
739
- * triggered when resizing, get the clientWidth of anchor
740
- * @return {?}
741
- */
742
- AnchorComponent.prototype.onResize = /**
743
- * triggered when resizing, get the clientWidth of anchor
744
- * @return {?}
745
- */
746
- function () {
747
- this.anchorLength = this.anchorRef ? this.anchorRef.nativeElement ? this.anchorRef.nativeElement.clientWidth : 0 : 0;
748
- };
749
- AnchorComponent.decorators = [
750
- { type: Component, args: [{
751
- selector: 'anchor',
752
- template: "\n <span #anchor tabindex=\"2\" [ngClass]=\"anchorClass\" (window:resize)=\"onResize()\"\n (mousedown)=\"onAnchorClick($event)\" (blur)=\"onAnchorBlur($event)\"> {{anchorDisplayText}}\n <span #selectionClearance class=\"selection-clearance\" (mousedown)=\"onClearanceClick($event)\" *ngIf=\"showClearanceFlag\">&times;</span>\n </span>\n ",
753
- providers: [DecimalPipe],
754
- styles: ["*,:after,:before{font-size:inherit;font-weight:inherit;font-family:inherit;box-sizing:inherit;background:inherit}.selection-anchor-close:after,.selection-anchor-disabled:after,.selection-anchor-open:after,.vertical-center{position:absolute;top:50%;-webkit-transform:translateY(-50%);transform:translateY(-50%)}.hover-box,.selection-anchor-close:hover{outline:0;box-shadow:0 0 6px #23adff;border-radius:4px}.anchor-box,.selection-anchor,.selection-anchor-close,.selection-anchor-disabled,.selection-anchor-open{height:100%;border-radius:4px;width:100%;position:relative;display:inline-block;padding:8px 12px 5px;border:1px solid;outline:0;box-shadow:inset 0 1px 1px rgba(0,0,0,.075);box-sizing:border-box;white-space:nowrap}.selection-anchor,.selection-anchor-close,.selection-anchor-open{cursor:pointer}.selection-anchor .selection-clearance,.selection-anchor-close .selection-clearance,.selection-anchor-open .selection-clearance{position:absolute;right:35px;font-weight:700}.selection-anchor .selection-clearance:hover,.selection-anchor-close .selection-clearance:hover,.selection-anchor-open .selection-clearance:hover{color:#000}.selection-anchor-close:focus,.selection-anchor-open:focus,.selection-anchor:focus{box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 8px rgba(102,175,233,.6);transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out;border-color:#66afe9}.selection-anchor-disabled{border-color:#ccc;cursor:default;pointer-events:none;background:#f8f8f8;-webkit-filter:opacity(50%);filter:opacity(50%)}.selection-anchor-disabled:after{font-size:12px;content:'\\0023F7';right:10px;padding-bottom:3px}.selection-anchor-open{border-bottom:none;border-bottom-right-radius:0;border-bottom-left-radius:0;border-color:#66afe9}.selection-anchor-open:after{font-size:12px;content:\"\\0023F6\";right:10px;padding-bottom:3px}.selection-anchor-close{border-color:#ccc}.selection-anchor-close:after{font-size:12px;content:'\\0023F7';right:10px;padding-bottom:3px}.place-holder{color:#999}.selected-item{color:#495057}"]
755
- }] }
756
- ];
757
- /** @nocollapse */
758
- AnchorComponent.ctorParameters = function () { return [
759
- { type: DecimalPipe }
760
- ]; };
761
- AnchorComponent.propDecorators = {
762
- anchorRef: [{ type: ViewChild, args: ['anchor', { read: ElementRef },] }],
763
- placeHolder: [{ type: Input }],
764
- checkbox: [{ type: Input }],
765
- suffixText: [{ type: Input }],
766
- allowClear: [{ type: Input }],
767
- formatNumber: [{ type: Input }],
768
- selectedText: [{ type: Input }],
769
- openStatus: [{ type: Input }],
770
- disabled: [{ type: Input }],
771
- anchorClick: [{ type: Output }],
772
- clearanceClick: [{ type: Output }]
773
- };
774
- return AnchorComponent;
775
- }());
776
-
777
- /**
778
- * @fileoverview added by tsickle
779
- * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
780
- */
781
- var DropdownComponent = /** @class */ (function () {
782
- function DropdownComponent() {
783
- /**
784
- * bind to [checkbox], the flag for multi-select (checkbox) mode.
785
- */
786
- this.checkbox = false;
787
- /**
788
- * bind to [filterBox] for displaying the filter input text box
789
- */
790
- this.filterBox = false;
791
- /**
792
- * bind to [allowClear] for enabling the clearance (clearance is not avaiable when checkbox is enabled)
793
- */
794
- this.allowClear = true;
795
- /**
796
- * bind to [formatNumber] for show formatted number text
797
- */
798
- this.formatNumber = false;
799
- /**
800
- * for 2-way binding of [selectedValue]
801
- */
802
- this.selectedValueChange = new EventEmitter(true);
803
- /**
804
- * [selectionChange] event that will be triggered when changing of the selection
805
- */
806
- this.selectionChange = new EventEmitter(true);
807
- /**
808
- * [dropdownBlur] event that will be triggered with (blur) of dropdown
809
- */
810
- this.dropdownBlur = new EventEmitter();
811
- /**
812
- * [itemClick] event that will be triggered when clicking the option of dropdown
813
- */
814
- this.itemClick = new EventEmitter();
815
- /**
816
- * flag of clicking dropdown. It's to prevent (blur) of dropdown from happening in checkbox mode.
817
- */
818
- this._clickedItems = false;
819
- }
820
- /**
821
- * @param {?} changes
822
- * @return {?}
823
- */
824
- DropdownComponent.prototype.ngOnChanges = /**
825
- * @param {?} changes
826
- * @return {?}
827
- */
828
- function (changes) {
829
- if (changes.items) {
830
- this._checkSelectionChange(changes.items.previousValue, changes.items.currentValue);
831
- }
832
- };
833
- /**
834
- * triggered when clicking the dropdown
835
- */
836
- /**
837
- * triggered when clicking the dropdown
838
- * @param {?} event
839
- * @return {?}
840
- */
841
- DropdownComponent.prototype.onItemsClick = /**
842
- * triggered when clicking the dropdown
843
- * @param {?} event
844
- * @return {?}
845
- */
846
- function (event) {
847
- if (event.offsetX > (event.target.clientWidth + event.target.clientLeft)) {
848
- stopPropagationAndDefault(event);
849
- return;
850
- }
851
- // should ignore clicking on filter
852
- if (this.checkbox && event.target.type !== 'text') {
853
- this._clickedItems = true;
854
- }
855
- };
856
- /**
857
- * triggered when clicking the item
858
- */
859
- /**
860
- * triggered when clicking the item
861
- * @param {?} currentItem
862
- * @return {?}
863
- */
864
- DropdownComponent.prototype.onItemClick = /**
865
- * triggered when clicking the item
866
- * @param {?} currentItem
867
- * @return {?}
868
- */
869
- function (currentItem) {
870
- if (!this.checkbox) {
871
- this.selectedValue = this._getItemValue(currentItem); // currentItem.value != null ? currentItem.value : currentItem.text;
872
- clearAllSelection(this.items);
873
- // set the selection of current one
874
- currentItem.selected = true;
875
- this.itemClick.emit(currentItem);
876
- this._onSelectionChange(this.selectedValue);
877
- }
878
- };
879
- /**
880
- * triggers with (blur) event of filter input box
881
- */
882
- /**
883
- * triggers with (blur) event of filter input box
884
- * @param {?} event
885
- * @return {?}
886
- */
887
- DropdownComponent.prototype.onFilterTextBlur = /**
888
- * triggers with (blur) event of filter input box
889
- * @param {?} event
890
- * @return {?}
891
- */
892
- function (event) {
893
- this.dropdownBlur.emit(event);
894
- };
895
- /**
896
- * triggers with (blur) event of dropdown
897
- */
898
- /**
899
- * triggers with (blur) event of dropdown
900
- * @param {?} event
901
- * @return {?}
902
- */
903
- DropdownComponent.prototype.onItemsBlur = /**
904
- * triggers with (blur) event of dropdown
905
- * @param {?} event
906
- * @return {?}
907
- */
908
- function (event) {
909
- if (this.checkbox) {
910
- if (this._clickedItems) {
911
- // in checkbox mode, this blur event will be ignored when clicking the dropdown (check the checkbox)
912
- event.target.focus();
913
- this._clickedItems = false;
914
- return;
915
- }
916
- }
917
- this.dropdownBlur.emit(event);
918
- };
919
- /**
920
- * toggle the selection when checking status changed (in checkbox mode)
921
- */
922
- /**
923
- * toggle the selection when checking status changed (in checkbox mode)
924
- * @param {?} item
925
- * @return {?}
926
- */
927
- DropdownComponent.prototype.toggleSelection = /**
928
- * toggle the selection when checking status changed (in checkbox mode)
929
- * @param {?} item
930
- * @return {?}
931
- */
932
- function (item) {
933
- item.selected = !item.selected;
934
- this.selectionChange.emit(this._getItemValue(item)); // item.value != null ? item.value : item.text);
935
- };
936
- Object.defineProperty(DropdownComponent.prototype, "itemsValues", {
937
- /**
938
- * items values list after applying the filter
939
- */
940
- get: /**
941
- * items values list after applying the filter
942
- * @return {?}
943
- */
944
- function () {
945
- /** @type {?} */
946
- var filter;
947
- if (this.filterValue) {
948
- filter = this.filterValue.toUpperCase();
949
- }
950
- if (filter == null) {
951
- return this.items;
952
- }
953
- if (!this.items || this.items.length === 0) {
954
- return [];
955
- }
956
- if (hasGroup(this.items)) {
957
- /** @type {?} */
958
- var items_1 = [];
959
- this.items.forEach(function (groupItem) {
960
- if (groupItem.group != null && groupItem.group.toString().toUpperCase().includes(filter)) {
961
- // if groupItem contains the filters, the groupItem needs to be displayed as well
962
- items_1.push(groupItem);
963
- }
964
- else {
965
- /** @type {?} */
966
- var filteredItems = groupItem.items.filter(function (item) { return item.text != null && item.text.toString().toUpperCase().includes(filter); });
967
- if (filteredItems && filteredItems.length > 0) {
968
- items_1.push({ group: groupItem.group, items: filteredItems });
969
- }
970
- }
971
- });
972
- return items_1;
973
- }
974
- else {
975
- return this.items.filter(function (item) { return (item.text != null && item.text.toString().toUpperCase().includes(filter)); });
976
- }
977
- },
978
- enumerable: true,
979
- configurable: true
980
- });
981
- Object.defineProperty(DropdownComponent.prototype, "optionsClass", {
982
- /**
983
- * options CSS class
984
- */
985
- get: /**
986
- * options CSS class
987
- * @return {?}
988
- */
989
- function () {
990
- if (this.filterBox && !this.checkbox) {
991
- return 'options with-filter';
992
- }
993
- else {
994
- return 'options no-filter';
995
- }
996
- },
997
- enumerable: true,
998
- configurable: true
999
- });
1000
- /**
1001
- * get item value. Return text if value is not available
1002
- */
1003
- /**
1004
- * get item value. Return text if value is not available
1005
- * @private
1006
- * @param {?} item
1007
- * @return {?}
1008
- */
1009
- DropdownComponent.prototype._getItemValue = /**
1010
- * get item value. Return text if value is not available
1011
- * @private
1012
- * @param {?} item
1013
- * @return {?}
1014
- */
1015
- function (item) {
1016
- return item ? item.value != null ? item.value : item.text : undefined;
1017
- };
1018
- /**
1019
- * selection changed, emits events: (selectedValueChange) and (selectionChange);
1020
- */
1021
- /**
1022
- * selection changed, emits events: (selectedValueChange) and (selectionChange);
1023
- * @private
1024
- * @param {?} value
1025
- * @return {?}
1026
- */
1027
- DropdownComponent.prototype._onSelectionChange = /**
1028
- * selection changed, emits events: (selectedValueChange) and (selectionChange);
1029
- * @private
1030
- * @param {?} value
1031
- * @return {?}
1032
- */
1033
- function (value) {
1034
- this.selectedValueChange.emit(value);
1035
- this.selectionChange.emit(value);
1036
- };
1037
- /**
1038
- * check whether the selection is changed. Emits relative events when if changed.
1039
- */
1040
- /**
1041
- * check whether the selection is changed. Emits relative events when if changed.
1042
- * @private
1043
- * @param {?} previousValue
1044
- * @param {?} currentValue
1045
- * @return {?}
1046
- */
1047
- DropdownComponent.prototype._checkSelectionChange = /**
1048
- * check whether the selection is changed. Emits relative events when if changed.
1049
- * @private
1050
- * @param {?} previousValue
1051
- * @param {?} currentValue
1052
- * @return {?}
1053
- */
1054
- function (previousValue, currentValue) {
1055
- /** @type {?} */
1056
- var curSelectedItem = getFirstSelectedItem(currentValue);
1057
- /** @type {?} */
1058
- var lastSelectedItem = getFirstSelectedItem(previousValue);
1059
- /** @type {?} */
1060
- var curSelectedItemId = curSelectedItem ? curSelectedItem.id : undefined;
1061
- /** @type {?} */
1062
- var lastSelectedItemId = lastSelectedItem ? lastSelectedItem.id : undefined;
1063
- if (curSelectedItemId !== lastSelectedItemId && !this.checkbox) {
1064
- this._onSelectionChange(this._getItemValue(curSelectedItem));
1065
- }
1066
- };
1067
- DropdownComponent.decorators = [
1068
- { type: Component, args: [{
1069
- selector: 'dropdown',
1070
- 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 ",
1071
- 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}"]
1072
- }] }
1073
- ];
1074
- DropdownComponent.propDecorators = {
1075
- dropdownRef: [{ type: ViewChild, args: ['dropdown', { read: ElementRef },] }],
1076
- filterInputRef: [{ type: ViewChild, args: ['filterInput', { read: ElementRef },] }],
1077
- placeHolder: [{ type: Input }],
1078
- items: [{ type: Input }],
1079
- checkbox: [{ type: Input }],
1080
- selectedValue: [{ type: Input }],
1081
- filterBox: [{ type: Input }],
1082
- suffixText: [{ type: Input }],
1083
- disabled: [{ type: Input }],
1084
- allowClear: [{ type: Input }],
1085
- formatNumber: [{ type: Input }],
1086
- selectedValueChange: [{ type: Output }],
1087
- selectionChange: [{ type: Output }],
1088
- dropdownBlur: [{ type: Output }],
1089
- itemClick: [{ type: Output }]
1090
- };
1091
- return DropdownComponent;
1092
- }());
1093
-
1094
- /**
1095
- * @fileoverview added by tsickle
1096
- * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
1097
- */
1098
- var DropdownListModule = /** @class */ (function () {
1099
- function DropdownListModule() {
1100
- }
1101
- DropdownListModule.decorators = [
1102
- { type: NgModule, args: [{
1103
- declarations: [
1104
- DropdownListComponent,
1105
- ItemComponent,
1106
- GroupItemComponent,
1107
- InputFilterComponent,
1108
- AnchorComponent,
1109
- DropdownComponent
1110
- ],
1111
- exports: [DropdownListComponent],
1112
- imports: [CommonModule, FormsModule],
1113
- providers: [],
1114
- bootstrap: [],
1115
- },] }
1116
- ];
1117
- return DropdownListModule;
1118
- }());
1119
-
1120
- /**
1121
- * @fileoverview added by tsickle
1122
- * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
1123
- */
1124
-
1125
- /**
1126
- * @fileoverview added by tsickle
1127
- * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
1128
- */
1129
-
1130
- /**
1131
- * @fileoverview added by tsickle
1132
- * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
1133
- */
1134
-
1135
- export { DropdownListComponent, DropdownListModule, AnchorComponent as ɵd, DropdownComponent as ɵe, InputFilterComponent as ɵc, GroupItemComponent as ɵb, ItemComponent as ɵa };
1136
-
1137
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ngx-dropdown-list.js.map","sources":["ng://ngx-dropdown-list/src/ngx-dropdown-list/utils/util.ts","ng://ngx-dropdown-list/src/ngx-dropdown-list/dropdown-list.component.ts","ng://ngx-dropdown-list/src/ngx-dropdown-list/item/item.component.ts","ng://ngx-dropdown-list/src/ngx-dropdown-list/group-item/group-item.component.ts","ng://ngx-dropdown-list/src/ngx-dropdown-list/filter/input-filter.component.ts","ng://ngx-dropdown-list/src/ngx-dropdown-list/anchor/anchor.component.ts","ng://ngx-dropdown-list/src/ngx-dropdown-list/dropdown/dropdown.component.ts","ng://ngx-dropdown-list/src/ngx-dropdown-list/dropdown-list.module.ts"],"sourcesContent":["/**\r\n * check whether the provided items contains group\r\n */\r\nexport function hasGroup(items): boolean {\r\n  return items ? (items.find(item => item.group) != null) : false;\r\n}\r\n\r\n/**\r\n * clear all selections from the provide items.\r\n * @param items the dropdown items, can be group or item\r\n */\r\nexport function clearAllSelection(items: any): void {\r\n  if (hasGroup(items)) {\r\n    for (const groupItem of items) {\r\n      if (groupItem.items) {\r\n        groupItem.items.filter(item => item.selected).forEach(item => item.selected = false);\r\n      }\r\n    }\r\n  } else {\r\n    // clear the selection of previous selected item\r\n    items.filter(item => item.selected).forEach(item => item.selected = false);\r\n  }\r\n}\r\n\r\n/**\r\n * stop all propagation and default actions\r\n */\r\nexport function stopPropagationAndDefault(event: Event): void {\r\n  event.stopImmediatePropagation();\r\n  event.stopPropagation();\r\n  event.preventDefault();\r\n}\r\n\r\n/**\r\n * check whether the provided value is number of not\r\n */\r\nexport function isNumber(value: any): boolean {\r\n  return !(value == null || isNaN(value) || value.length === 0);\r\n}\r\n\r\n/**\r\n * get the selected item from the items list (including item and group)\r\n */\r\nexport function getFirstSelectedItem(items: any): any {\r\n  if (!items) {\r\n    return undefined;\r\n  }\r\n  let selectedItem;\r\n  if (hasGroup(items)) {\r\n    for (const item of items) {\r\n      selectedItem = item.items ? item.items.find(subItem => subItem.selected) : undefined;\r\n      if (selectedItem) {\r\n        break;\r\n      }\r\n    }\r\n  } else {\r\n    selectedItem = items ? items.find(item => item.selected) : undefined;\r\n  }\r\n  return selectedItem;\r\n}\r\n","import {Component, ElementRef, EventEmitter, Input, Output, ViewChild} from '@angular/core';\nimport {clearAllSelection, getFirstSelectedItem, stopPropagationAndDefault} from './utils/util';\n\n@Component({\n  selector: 'ngx-dropdown-list',\n  template: `\n    <span class=\"ngx-select\">\n        <anchor (anchorClick)=\"onAnchorClick($event)\" (clearanceClick)=\"onClearanceClick($event)\"\n                [checkbox]=\"multiSelection\"\n                [formatNumber]=\"formatNumber\"\n                [suffixText]=\"suffixText\"\n                [placeHolder]=\"placeHolder\"\n                [allowClear]=\"allowClear\"\n                [openStatus]=\"dropdownVisibility\"\n                [selectedText]=\"selectedText\"\n                [disabled]=\"disabled\">\n        </anchor>\n        <dropdown #dropdown (dropdownBlur) = \"onItemsBlur()\" (selectionChange)=\"onSelectionChange($event)\"\n                [items]=\"items\"\n                [checkbox]=\"multiSelection\"\n                [filterBox]=\"filterBox\"\n                [formatNumber]=\"formatNumber\"\n                [suffixText]=\"suffixText\"\n                [(selectedValue)]=\"selectedValue\"\n                (itemClick) = \"onItemClick()\"\n                [disabled]=\"disabled\">\n        </dropdown>\n    </span>\n  `,\n  styleUrls: ['./dropdown-list.component.scss'],\n})\n\nexport class DropdownListComponent {\n  @ViewChild('dropdown', { read: ElementRef }) dropdownRef: ElementRef;\n\n  /**\n   * bind to [placeHolder] for displaying the place holder string of the anchor.\n   */\n  @Input() placeHolder: string;\n  /**\n   * bind to [items] for the options/groups in the dropdown\n   */\n  @Input() items: any[];\n  /**\n   * bind to [multiSelection], the flag for multi-select (checkbox) mode.\n   */\n  @Input() multiSelection = false;\n  /**\n   * bind to [selectedValue] for the value of the selected option from dropdown\n   */\n  @Input() selectedValue: any;\n  /**\n   * bind to [filterBox] for displaying the filter input text box\n   */\n  @Input() filterBox = false;\n  /**\n   * bind to [suffixText] for displaying the suffix of the selected text of anchor\n   */\n  @Input() suffixText: string;\n  /**\n   * bind to [disabled] for disabling the dropdown\n   */\n  @Input() disabled: boolean;\n  /**\n   * bind to [allowClear] for enabling the clearance (clearance is not avaiable when checkbox is enabled)\n   */\n  @Input() allowClear = true;\n  /**\n   * bind to [formatNumber] for show formatted number text\n   */\n  @Input() formatNumber = false;\n  /**\n   * for 2-way binding of [selectedValue], using async event to\n   * prevent \"ExpressionChangedAfterItHasBeenCheckedError\".\n   */\n  @Output() selectedValueChange = new EventEmitter<string>(true);\n  /**\n   * [selectionChange] event that will be triggered when changing of the selection.\n   * Using async event to prevent \"ExpressionChangedAfterItHasBeenCheckedError\".\n   */\n  @Output() selectionChange = new EventEmitter<any>(true);\n\n  /**\n   * visibility flag of drop down\n   */\n  dropdownVisibility = false;\n\n  /**\n   * current selected text\n   */\n  get selectedText(): any {\n    if (!this.multiSelection) {\n      const selectedItem = getFirstSelectedItem(this.items);\n      return selectedItem ? selectedItem.text : undefined;\n    }\n  }\n\n  /**\n   * triggered with (selectionChange) event, emits (selectedValueChange) and (selectionChange)\n   */\n  onSelectionChange(event) {\n    this.selectedValueChange.emit(event);\n    this.selectionChange.emit(event);\n  }\n\n  /**\n   * triggered with (anchorClick) event, controlling the \"open\" and \"close\" of the dropdown\n   */\n  onAnchorClick(event: Event): void {\n    if (this.disabled) {\n      stopPropagationAndDefault(event);\n      return;\n    }\n    if (this._isSelectionOpen()) {\n      this._hideItemList();\n    } else {\n      this._showItemsList();\n    }\n    stopPropagationAndDefault(event);\n  }\n\n  /**\n   * triggered with (itemClick) event, closes the dropdown in non-checkbox mode\n   */\n  onItemClick(): void {\n    if (!this.multiSelection) {\n      this._hideItemList();\n    }\n  }\n\n  /**\n   * triggered with (clearanceClick) event, clearing all selections\n   * and emits (selectedValueChange) and (selectionChange) event for empty value\n   */\n  onClearanceClick(event: Event): void {\n    if (!this.multiSelection) {\n      this.selectedValue = void 0;\n      this.selectedValueChange.emit(undefined);\n      this.selectionChange.emit(undefined);\n      clearAllSelection(this.items);\n    }\n    stopPropagationAndDefault(event);\n  }\n\n  /**\n   * triggered with (dropdownBlur) event, closes the dropdown\n   */\n  onItemsBlur(): void {\n    if (this._isSelectionOpen()) {\n      this._hideItemList();\n    }\n  }\n\n  /**\n   * close the dropdown\n   */\n  private _hideItemList(): void {\n    // hide the dropdown element (has some problem for using CSS directly, using this as a workaround)\n    this._dropdownElement.classList.remove('visible');\n    this._dropdownElement.style.display = 'none';\n    this.dropdownVisibility = false;\n  }\n\n  /**\n   * open the dropdown\n   */\n  private _showItemsList(): void {\n    // display the dropdown element (has some problem for using CSS directly, using this as a workaround)\n    this._dropdownElement.classList.add('visible');\n    this._dropdownElement.style.display = 'block';\n\n    this.dropdownVisibility = true;\n\n    // scrolling to the selected item\n    if (this._selectedElement) {\n      this._selectedElement.scrollIntoView({ behavior: 'instant', block: 'center' });\n    }\n\n    // setting the focus\n    if (this.filterBox && !this.multiSelection) {\n      this._filterInputElement.focus();\n    } else {\n      this._dropdownElement.focus();\n    }\n  }\n\n  /**\n   * visibility status of dropdown\n   */\n  private _isSelectionOpen(): boolean {\n    return this.dropdownVisibility;\n  }\n\n  /**\n   * get the real dropdown element (for focusing and visibility controlling), the <span> not the <dropdown>\n   */\n  private get _dropdownElement(): any {\n    return this.dropdownRef ? this.dropdownRef.nativeElement ? this.dropdownRef.nativeElement.firstElementChild : null : null;\n  }\n\n  /**\n   * get the real filter element (for focusing), the <input> not the <input-filter>\n   */\n  private get _filterInputElement(): any {\n    return this._dropdownElement ?\n      this._dropdownElement.firstElementChild ? this._dropdownElement.firstElementChild.firstElementChild : null : null;\n  }\n\n  /**\n   * get the HTMLElement of selected item, for doing (scrollIntoView) scrolling to the selected item\n   */\n  private get _selectedElement(): HTMLElement {\n    const selectedItem = getFirstSelectedItem(this.items);\n    return selectedItem ? document.getElementById(selectedItem.id) as HTMLElement : undefined;\n  }\n}\n","import {Component, EventEmitter, Input, Output} from '@angular/core';\nimport {SelectionItem} from '../types';\nimport {isNumber} from '../utils/util';\n\n@Component({\n  selector: 'item',\n  template: `\n    <label [class.container-checkbox]=\"checkbox\"\n           [class.container-selection]=\"!checkbox && !item.selected\"\n           [class.container-selection-selected]=\"!checkbox && item.selected\"\n           [id]=\"item.id\" (mousedown)=\"onItemClick(item)\">\n      {{needFormatNumber(item.text)? (item.text | number:'1.0-2') : item.text}}{{suffixText? suffixText : ''}}\n      <ng-container *ngIf=\"checkbox\">\n        <input type='checkbox' [id]=\"'checkbox-'+item.text\" (change)=\"onCheckStatusChange(item)\" [checked]=\"item.selected\">\n        <span class=\"checkmark\" [id]=\"'checkmark-'+item.text\"></span>\n      </ng-container>\n    </label>`,\n  styleUrls: ['./item.component.scss']\n})\n\nexport class ItemComponent {\n  /**\n   * bind to [checkbox], the flag of checkbox mode\n   */\n  @Input() checkbox: boolean;\n  /**\n   * bind to [item], the dropdown option item\n   */\n  @Input() item: SelectionItem;\n  /**\n   * bind to [formatNumber], the flag for formatting the number\n   */\n  @Input() formatNumber = false;\n  /**\n   * bind to [suffixText], the suffixText that will be displayed in the dropdown\n   */\n  @Input() suffixText: string;\n  /**\n   * bind to [itemClick] event, triggers when clicking the item of dropdown\n   */\n  @Output() itemClick = new EventEmitter<string>();\n  /**\n   * bind to [checkStatusChange] event, triggers when check status is changed in checkbox mode.\n   */\n  @Output() checkStatusChange = new EventEmitter<string>();\n\n  /**\n   * check whether needs to format number for the provided text\n   */\n  needFormatNumber(value: any): boolean {\n    return isNumber(value) && this.formatNumber;\n  }\n\n  /**\n   * triggered when clicking the item, emits the [itemClick] event\n   */\n  onItemClick(item) {\n    this.itemClick.emit(item);\n  }\n\n  /**\n   * triggered when checking status changed in checkbox mode, emits the [checkStatusChange] event\n   */\n  onCheckStatusChange(item) {\n    this.checkStatusChange.emit(item);\n  }\n}\n","import {Component, Input} from '@angular/core';\nimport {SelectionGroupItems} from '../types';\n\n@Component({\n  selector: 'group-item',\n  template: `\n    <label class=\"dropdown-item dropdown-item-group\" (mousedown)=\"onItemGroupClick($event)\">{{item.group}}</label>\n  `,\n  styleUrls: ['./group-item.component.scss']\n})\n\nexport class GroupItemComponent {\n  /**\n   * bind to [item], the group item of dropdown\n   */\n  @Input() item: SelectionGroupItems;\n\n  /**\n   * prevent all clicking event from happening\n   */\n  onItemGroupClick(event) {\n    event.stopImmediatePropagation();\n    event.stopPropagation();\n    event.preventDefault();\n  }\n}\n","import {Component, EventEmitter, Input, Output} from '@angular/core';\n\n@Component({\n  selector: 'input-filter',\n  template: `\n    <input type=\"text\" class=\"filter-box\" [(ngModel)]=\"filterValue\" (input)=\"onChange()\" (blur)=\"onFilterTextBlur($event)\">\n  `,\n  styleUrls: ['./input-filter.component.scss']\n})\n\nexport class InputFilterComponent {\n  /**\n   * bind to [filterValue], the value of the filter\n   */\n  @Input() filterValue: string;\n  /**\n   * bind to [inputFilterBlur], emits with (blur) of filter input box\n   */\n  @Output() inputFilterBlur = new EventEmitter<string>();\n  /**\n   * bind to [filterValueChange], for 2-way binding of filterValue\n   */\n  @Output() filterValueChange = new EventEmitter<string>();\n\n  /**\n   * triggers with (blur) event, emits the (inputFilterBlur) event\n   */\n  onFilterTextBlur(event) {\n    this.inputFilterBlur.emit(event);\n  }\n\n  /**\n   * triggers with (input) event, emits the (filterValueChange) event for 2-way binding of filterValue\n   */\n  onChange() {\n    this.filterValueChange.emit(this.filterValue);\n  }\n}\n","import {Component, ElementRef, EventEmitter, Input, Output, ViewChild} from '@angular/core';\nimport {stopPropagationAndDefault, isNumber} from '../utils/util';\nimport {DecimalPipe} from '@angular/common';\n\n@Component({\n  selector: 'anchor',\n  template: `\n    <span #anchor tabindex=\"2\" [ngClass]=\"anchorClass\" (window:resize)=\"onResize()\"\n          (mousedown)=\"onAnchorClick($event)\" (blur)=\"onAnchorBlur($event)\"> {{anchorDisplayText}}\n      <span #selectionClearance class=\"selection-clearance\" (mousedown)=\"onClearanceClick($event)\" *ngIf=\"showClearanceFlag\">&times;</span>\n    </span>\n  `,\n  styleUrls: ['./anchor.component.scss'],\n  providers: [DecimalPipe]\n})\n\nexport class AnchorComponent {\n  /**\n   * Child element reference of anchor\n   */\n  @ViewChild('anchor', { read: ElementRef }) anchorRef: ElementRef;\n\n  /**\n   * bind to [placeHolder] for displaying the place holder string of the anchor.\n   */\n  @Input() placeHolder: string;\n  /**\n   * bind to [checkbox] for checking whether the clearance flag should be shown or not.\n   */\n  @Input() checkbox = false;\n  /**\n   * bind to [suffixText] for displaying the suffix of the selected text of anchor\n   */\n  @Input() suffixText: string;\n  /**\n   * bind to [allowClear] for enabling the clearance (clearance is not avaiable when checkbox is enabled)\n   */\n  @Input() allowClear = true;\n  /**\n   * bind to [formatNumber] for show formatted number text\n   */\n  @Input() formatNumber: boolean;\n  /**\n   * bind to [selectedText] for displaying the selected text on anchor\n   */\n  @Input() selectedText: any;\n  /**\n   * bind to [openStatus], it's the visibility status of dropdown, for showing the arrow on anchor\n   */\n  @Input() openStatus = false;\n  /**\n   * bind to [disabled] for disabling the anchor\n   */\n  @Input() disabled = false;\n  /**\n   * will be triggered when clicking the anchor\n   */\n  @Output() anchorClick = new EventEmitter<any>();\n  /**\n   * will be triggered when clicking the clearance\n   */\n  @Output() clearanceClick = new EventEmitter<any>();\n\n  /**\n   * length of anchor element, used for calculate the string length of the anchor displayed text.\n   */\n  anchorLength: number;\n\n  constructor(private _decimalPipe: DecimalPipe) {}\n\n  /**\n   * flag for showing the clearance flag\n   */\n  get showClearanceFlag(): boolean {\n    return !this.checkbox && this.selectedText && this.allowClear;\n  }\n\n  /**\n   * the text displays on anchor\n   */\n  get anchorDisplayText(): string {\n    let anchorDisplayText =  this.selectedText ? (this.formatNumber ? (isNumber(this.selectedText) ?\n      this._decimalPipe.transform(this.selectedText, '1.0-2') : this.selectedText) :\n      this.selectedText) + (this.suffixText ? this.suffixText : '') : this.placeHolder;\n\n    let charLength = 1;\n    if (this.showClearanceFlag && this.anchorLength > 0) {\n      charLength = Math.floor((this.anchorLength - 50) / 7);\n    } else {\n      charLength = Math.floor((this.anchorLength - 50) / 7);\n    }\n\n    if (anchorDisplayText.length > charLength) {\n      anchorDisplayText = anchorDisplayText.slice(0, charLength - 2) + '...';\n    }\n    return anchorDisplayText;\n  }\n\n  /**\n   * anchor CSS class\n   */\n  get anchorClass(): string {\n    let anchorClassStatusPart;\n    let anchorClassFontColor;\n    if (this.disabled) {\n      anchorClassStatusPart = 'selection-anchor-disabled';\n      anchorClassFontColor = 'place-holder';\n    } else {\n      if (this.openStatus) {\n        anchorClassStatusPart = 'selection-anchor-open';\n      } else {\n        anchorClassStatusPart = 'selection-anchor-close';\n      }\n      if (this.selectedText != null) {\n        anchorClassFontColor = 'selected-item';\n      } else {\n        anchorClassFontColor = 'place-holder';\n      }\n    }\n    return `${anchorClassStatusPart} ${anchorClassFontColor}`;\n  }\n\n  /**\n   * triggered when clicking the anchor\n   */\n  onAnchorClick(event: Event): void {\n    this.anchorClick.emit(event);\n  }\n\n  /**\n   * triggered with (blur) of anchor\n   */\n  onAnchorBlur(event: Event): void {\n    stopPropagationAndDefault(event);\n  }\n\n  /**\n   * triggered when clicking the clearance\n   */\n  onClearanceClick(event: Event): void {\n    this.clearanceClick.emit(event);\n  }\n\n  /**\n   * triggered when resizing, get the clientWidth of anchor\n   */\n  onResize() {\n    this.anchorLength = this.anchorRef ? this.anchorRef.nativeElement ? this.anchorRef.nativeElement.clientWidth : 0 : 0;\n  }\n}\n","import {Component, ElementRef, EventEmitter, Input, OnChanges, Output, SimpleChanges, ViewChild} from '@angular/core';\nimport {clearAllSelection, getFirstSelectedItem, hasGroup, stopPropagationAndDefault} from '../utils/util';\n\n@Component({\n  selector: 'dropdown',\n  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  `,\n  styleUrls: ['./dropdown.component.scss']\n})\n\nexport class DropdownComponent implements OnChanges {\n  /**\n   * Child element reference of dropdown\n   */\n  @ViewChild('dropdown', { read: ElementRef }) dropdownRef: ElementRef;\n  /**\n   * Child element reference of filter input text\n   */\n  @ViewChild('filterInput', { read: ElementRef }) filterInputRef: ElementRef;\n  /**\n   * bind to [placeHolder] for displaying the place holder string of the anchor.\n   */\n  @Input() placeHolder: string;\n  /**\n   * bind to [items] for the options/groups in the dropdown\n   */\n  @Input() items: any[];\n  /**\n   * bind to [checkbox], the flag for multi-select (checkbox) mode.\n   */\n  @Input() checkbox = false;\n  /**\n   * bind to [selectedValue] for the value of the selected option from dropdown\n   */\n  @Input() selectedValue: any;\n  /**\n   * bind to [filterBox] for displaying the filter input text box\n   */\n  @Input() filterBox = false;\n  /**\n   * bind to [suffixText] for displaying the suffix of the selected text of anchor\n   */\n  @Input() suffixText: string;\n  /**\n   * bind to [disabled] for disabling the dropdown\n   */\n  @Input() disabled: boolean;\n  /**\n   * bind to [allowClear] for enabling the clearance (clearance is not avaiable when checkbox is enabled)\n   */\n  @Input() allowClear = true;\n  /**\n   * bind to [formatNumber] for show formatted number text\n   */\n  @Input() formatNumber = false;\n  /**\n   * for 2-way binding of [selectedValue]\n   */\n  @Output() selectedValueChange = new EventEmitter<string>(true);\n  /**\n   * [selectionChange] event that will be triggered when changing of the selection\n   */\n  @Output() selectionChange = new EventEmitter<any>(true);\n  /**\n   * [dropdownBlur] event that will be triggered with (blur) of dropdown\n   */\n  @Output() dropdownBlur = new EventEmitter<any>();\n  /**\n   * [itemClick] event that will be triggered when clicking the option of dropdown\n   */\n  @Output() itemClick = new EventEmitter<any>();\n  /**\n   * filter value\n   */\n  filterValue: string;\n  /**\n   * flag of clicking dropdown. It's to prevent (blur) of dropdown from happening in checkbox mode.\n   */\n  private _clickedItems = false;\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.items) {\n      this._checkSelectionChange(changes.items.previousValue, changes.items.currentValue);\n    }\n  }\n\n  /**\n   * triggered when clicking the dropdown\n   */\n  onItemsClick(event: any): void {\n    if (event.offsetX > (event.target.clientWidth + event.target.clientLeft)) {\n      stopPropagationAndDefault(event);\n      return;\n    }\n    // should ignore clicking on filter\n    if (this.checkbox && event.target.type !== 'text') {\n      this._clickedItems = true;\n    }\n  }\n\n  /**\n   * triggered when clicking the item\n   */\n  onItemClick(currentItem): void {\n    if (!this.checkbox) {\n      this.selectedValue = this._getItemValue(currentItem); // currentItem.value != null ? currentItem.value : currentItem.text;\n      clearAllSelection(this.items);\n      // set the selection of current one\n      currentItem.selected = true;\n      this.itemClick.emit(currentItem);\n      this._onSelectionChange(this.selectedValue);\n    }\n  }\n\n  /**\n   * triggers with (blur) event of filter input box\n   */\n  onFilterTextBlur(event): void {\n    this.dropdownBlur.emit(event);\n  }\n\n  /**\n   * triggers with (blur) event of dropdown\n   */\n  onItemsBlur(event): void {\n    if (this.checkbox) {\n      if (this._clickedItems) {\n        // in checkbox mode, this blur event will be ignored when clicking the dropdown (check the checkbox)\n        event.target.focus();\n        this._clickedItems = false;\n        return;\n      }\n    }\n    this.dropdownBlur.emit(event);\n  }\n\n  /**\n   * toggle the selection when checking status changed (in checkbox mode)\n   */\n  toggleSelection(item: {id: string, value?: any, text: any, selected?: boolean}): void {\n    item.selected = !item.selected;\n    this.selectionChange.emit(this._getItemValue(item)); // item.value != null ? item.value : item.text);\n  }\n\n  /**\n   * items values list after applying the filter\n   */\n  get itemsValues(): any[] {\n    let filter;\n    if (this.filterValue) {\n      filter = this.filterValue.toUpperCase();\n    }\n\n    if (filter == null) {\n      return this.items;\n    }\n    if (!this.items || this.items.length === 0) {\n      return [];\n    }\n    if (hasGroup(this.items)) {\n      const items = [];\n      this.items.forEach(groupItem => {\n        if (groupItem.group != null && groupItem.group.toString().toUpperCase().includes(filter)) {\n          // if groupItem contains the filters, the groupItem needs to be displayed as well\n          items.push(groupItem);\n        } else {\n          const filteredItems = groupItem.items.filter(item => item.text != null && item.text.toString().toUpperCase().includes(filter));\n          if (filteredItems && filteredItems.length > 0) {\n            items.push({group: groupItem.group, items: filteredItems});\n          }\n        }\n      });\n      return items;\n    } else {\n      return this.items.filter(item => (item.text != null && item.text.toString().toUpperCase().includes(filter)));\n    }\n  }\n  /**\n   * options CSS class\n   */\n  get optionsClass(): string {\n    if (this.filterBox && !this.checkbox) {\n      return 'options with-filter';\n    } else {\n      return 'options no-filter';\n    }\n  }\n\n  /**\n   * get item value. Return text if value is not available\n   */\n  private _getItemValue(item): any {\n    return item ? item.value != null ? item.value : item.text : undefined;\n  }\n\n  /**\n   * selection changed, emits events: (selectedValueChange) and (selectionChange);\n   */\n  private _onSelectionChange(value) {\n    this.selectedValueChange.emit(value);\n    this.selectionChange.emit(value);\n  }\n\n  /**\n   * check whether the selection is changed. Emits relative events when if changed.\n   */\n  private _checkSelectionChange(previousValue, currentValue) {\n    const curSelectedItem = getFirstSelectedItem(currentValue);\n    const lastSelectedItem = getFirstSelectedItem(previousValue);\n    const curSelectedItemId = curSelectedItem ? curSelectedItem.id : undefined;\n    const lastSelectedItemId = lastSelectedItem ? lastSelectedItem.id : undefined;\n    if (curSelectedItemId !== lastSelectedItemId && !this.checkbox) {\n      this._onSelectionChange(this._getItemValue(curSelectedItem));\n    }\n  }\n}\n","import { NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { ItemComponent } from './item/item.component';\r\nimport { GroupItemComponent } from './group-item/group-item.component';\r\nimport { InputFilterComponent } from './filter/input-filter.component';\r\nimport { AnchorComponent } from './anchor/anchor.component';\r\nimport { DropdownComponent } from './dropdown/dropdown.component';\r\nimport { DropdownListComponent } from './dropdown-list.component';\r\n\r\n@NgModule({\r\n  declarations: [\r\n    DropdownListComponent,\r\n    ItemComponent,\r\n    GroupItemComponent,\r\n    InputFilterComponent,\r\n    AnchorComponent,\r\n    DropdownComponent\r\n  ],\r\n  exports: [ DropdownListComponent],\r\n  imports: [ CommonModule, FormsModule ],\r\n  providers: [],\r\n  bootstrap: [],\r\n})\r\nexport class DropdownListModule {}\r\n"],"names":["tslib_1.__values"],"mappings":"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"}