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