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