@po-ui/ng-components 16.4.1 → 16.5.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/esm2022/lib/components/po-field/po-field.module.mjs +17 -13
- package/esm2022/lib/components/po-field/po-lookup/po-lookup-modal/po-lookup-modal.component.mjs +4 -4
- package/esm2022/lib/components/po-field/po-multiselect/po-multiselect-base.component.mjs +30 -7
- package/esm2022/lib/components/po-field/po-multiselect/po-multiselect-dropdown/po-multiselect-dropdown.component.mjs +4 -4
- package/esm2022/lib/components/po-field/po-multiselect/po-multiselect-literals.interface.mjs +1 -1
- package/esm2022/lib/components/po-field/po-multiselect/po-multiselect.component.mjs +220 -51
- package/esm2022/lib/components/po-field/po-rich-text/po-rich-text-toolbar/po-rich-text-toolbar.component.mjs +3 -3
- package/esm2022/lib/components/po-listbox/po-item-list/po-item-list.component.mjs +2 -2
- package/esm2022/lib/components/po-table/po-table-base.component.mjs +5 -5
- package/esm2022/lib/components/po-tag/index.mjs +2 -1
- package/esm2022/lib/components/po-tag/interfaces/po-tag-literals.interface.mjs +2 -0
- package/esm2022/lib/components/po-tag/po-tag-base.component.mjs +70 -4
- package/esm2022/lib/components/po-tag/po-tag.component.mjs +52 -44
- package/esm2022/lib/enums/po-key-code.enum.mjs +5 -1
- package/fesm2022/po-ui-ng-components.mjs +701 -532
- package/fesm2022/po-ui-ng-components.mjs.map +1 -1
- package/lib/components/po-field/po-field.module.d.ts +44 -44
- package/lib/components/po-field/po-multiselect/po-multiselect-base.component.d.ts +21 -2
- package/lib/components/po-field/po-multiselect/po-multiselect-literals.interface.d.ts +2 -0
- package/lib/components/po-field/po-multiselect/po-multiselect.component.d.ts +18 -6
- package/lib/components/po-table/po-table-base.component.d.ts +2 -2
- package/lib/components/po-tag/index.d.ts +1 -0
- package/lib/components/po-tag/interfaces/po-tag-literals.interface.d.ts +11 -0
- package/lib/components/po-tag/po-tag-base.component.d.ts +50 -2
- package/lib/components/po-tag/po-tag.component.d.ts +6 -6
- package/lib/enums/po-key-code.enum.d.ts +5 -1
- package/package.json +4 -4
- package/po-ui-ng-components-16.5.0.tgz +0 -0
- package/schematics/ng-add/index.js +1 -1
- package/schematics/ng-update/v14/index.js +1 -1
- package/schematics/ng-update/v15/index.js +1 -1
- package/schematics/ng-update/v16/index.js +1 -1
- package/schematics/ng-update/v2/index.js +1 -1
- package/schematics/ng-update/v3/index.js +1 -1
- package/schematics/ng-update/v4/index.js +1 -1
- package/schematics/ng-update/v5/index.js +1 -1
- package/schematics/ng-update/v6/index.js +1 -1
- package/esm2022/lib/components/po-field/po-multiselect/po-multiselect-search/po-multiselect-search.component.mjs +0 -91
- package/esm2022/lib/components/po-tag/po-tag.literals.mjs +0 -15
- package/lib/components/po-field/po-multiselect/po-multiselect-search/po-multiselect-search.component.d.ts +0 -40
- package/lib/components/po-tag/po-tag.literals.d.ts +0 -14
- package/po-ui-ng-components-16.4.1.tgz +0 -0
|
@@ -1,10 +1,11 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component,
|
|
1
|
+
import { ChangeDetectionStrategy, Component, ContentChild, ElementRef, ViewChild, forwardRef } from '@angular/core';
|
|
2
2
|
import { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
-
import { of } from 'rxjs';
|
|
4
|
-
import {
|
|
5
|
-
import { isMobile } from './../../../utils/util';
|
|
6
|
-
import { PoControlPositionService } from './../../../services/po-control-position/po-control-position.service';
|
|
3
|
+
import { Subscription, fromEvent, of } from 'rxjs';
|
|
4
|
+
import { catchError, tap } from 'rxjs/operators';
|
|
7
5
|
import { PoKeyCodeEnum } from './../../../enums/po-key-code.enum';
|
|
6
|
+
import { PoControlPositionService } from './../../../services/po-control-position/po-control-position.service';
|
|
7
|
+
import { isMobile } from './../../../utils/util';
|
|
8
|
+
import { poLocaleDefault } from '../../../services/po-language/po-language.constant';
|
|
8
9
|
import { PoMultiselectBaseComponent } from './po-multiselect-base.component';
|
|
9
10
|
import { PoMultiselectFilterService } from './po-multiselect-filter.service';
|
|
10
11
|
import { PoMultiselectOptionTemplateDirective } from './po-multiselect-option-template/po-multiselect-option-template.directive';
|
|
@@ -22,18 +23,19 @@ function PoMultiselectComponent_span_5_Template(rf, ctx) { if (rf & 1) {
|
|
|
22
23
|
} if (rf & 2) {
|
|
23
24
|
const ctx_r2 = i0.ɵɵnextContext();
|
|
24
25
|
i0.ɵɵadvance(1);
|
|
25
|
-
i0.ɵɵtextInterpolate1(" ", ctx_r2.placeholder, " ");
|
|
26
|
+
i0.ɵɵtextInterpolate1(" ", ctx_r2.placeholder ? ctx_r2.placeholder : ctx_r2.literals.selectItem, " ");
|
|
26
27
|
} }
|
|
27
|
-
function
|
|
28
|
-
const
|
|
29
|
-
i0.ɵɵelementStart(0, "po-
|
|
30
|
-
i0.ɵɵlistener("
|
|
28
|
+
function PoMultiselectComponent_po_tag_6_Template(rf, ctx) { if (rf & 1) {
|
|
29
|
+
const _r15 = i0.ɵɵgetCurrentView();
|
|
30
|
+
i0.ɵɵelementStart(0, "po-tag", 16);
|
|
31
|
+
i0.ɵɵlistener("p-close", function PoMultiselectComponent_po_tag_6_Template_po_tag_p_close_0_listener($event) { const restoredCtx = i0.ɵɵrestoreView(_r15); const tag_r12 = restoredCtx.$implicit; const ctx_r14 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r14.closeTag(tag_r12[ctx_r14.fieldValue], $event)); });
|
|
31
32
|
i0.ɵɵelementEnd();
|
|
32
33
|
} if (rf & 2) {
|
|
33
|
-
const
|
|
34
|
+
const tag_r12 = ctx.$implicit;
|
|
35
|
+
const i_r13 = ctx.index;
|
|
34
36
|
const ctx_r3 = i0.ɵɵnextContext();
|
|
35
|
-
i0.ɵɵclassProp("po-clickable",
|
|
36
|
-
i0.ɵɵproperty("p-
|
|
37
|
+
i0.ɵɵclassProp("po-clickable", tag_r12[ctx_r3.fieldValue] === "" && !ctx_r3.disabled);
|
|
38
|
+
i0.ɵɵproperty("p-value", tag_r12[ctx_r3.fieldLabel])("p-literals", i_r13 + 1 === ctx_r3.visibleTags.length && ctx_r3.hasMoreTag ? ctx_r3.literalsTag : undefined)("p-removable", true)("p-disabled", ctx_r3.disabled);
|
|
37
39
|
} }
|
|
38
40
|
function PoMultiselectComponent_ng_container_10_Template(rf, ctx) { if (rf & 1) {
|
|
39
41
|
i0.ɵɵelementContainer(0);
|
|
@@ -68,7 +70,7 @@ function PoMultiselectComponent_ng_template_13_Template(rf, ctx) { if (rf & 1) {
|
|
|
68
70
|
function PoMultiselectComponent_ng_template_16_Template(rf, ctx) { if (rf & 1) {
|
|
69
71
|
const _r21 = i0.ɵɵgetCurrentView();
|
|
70
72
|
i0.ɵɵelementStart(0, "po-multiselect-dropdown", 19, 20);
|
|
71
|
-
i0.ɵɵlistener("p-change", function PoMultiselectComponent_ng_template_16_Template_po_multiselect_dropdown_p_change_0_listener($event) { i0.ɵɵrestoreView(_r21); const ctx_r20 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r20.changeItems($event)); })("p-change-search", function PoMultiselectComponent_ng_template_16_Template_po_multiselect_dropdown_p_change_search_0_listener($event) { i0.ɵɵrestoreView(_r21); const ctx_r22 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r22.changeSearch($event)); })("p-close-dropdown", function PoMultiselectComponent_ng_template_16_Template_po_multiselect_dropdown_p_close_dropdown_0_listener() { i0.ɵɵrestoreView(_r21); const ctx_r23 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r23.controlDropdownVisibility(false)); });
|
|
73
|
+
i0.ɵɵlistener("p-change", function PoMultiselectComponent_ng_template_16_Template_po_multiselect_dropdown_p_change_0_listener($event) { i0.ɵɵrestoreView(_r21); const ctx_r20 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r20.changeItems($event)); })("p-change-search", function PoMultiselectComponent_ng_template_16_Template_po_multiselect_dropdown_p_change_search_0_listener($event) { i0.ɵɵrestoreView(_r21); const ctx_r22 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r22.changeSearch($event)); })("p-close-dropdown", function PoMultiselectComponent_ng_template_16_Template_po_multiselect_dropdown_p_close_dropdown_0_listener() { i0.ɵɵrestoreView(_r21); const ctx_r23 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r23.controlDropdownVisibility(false)); })("keydown", function PoMultiselectComponent_ng_template_16_Template_po_multiselect_dropdown_keydown_0_listener($event) { i0.ɵɵrestoreView(_r21); const ctx_r24 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r24.onKeyDownDropdown($event, 0)); });
|
|
72
74
|
i0.ɵɵelementEnd();
|
|
73
75
|
} if (rf & 2) {
|
|
74
76
|
const ctx_r11 = i0.ɵɵnextContext();
|
|
@@ -76,6 +78,22 @@ function PoMultiselectComponent_ng_template_16_Template(rf, ctx) { if (rf & 1) {
|
|
|
76
78
|
} }
|
|
77
79
|
const poMultiselectContainerOffset = 8;
|
|
78
80
|
const poMultiselectContainerPositionDefault = 'bottom';
|
|
81
|
+
const poMultiselectInputPaddingRight = 52;
|
|
82
|
+
const poMultiselectSpaceBetweenTags = 8;
|
|
83
|
+
const literalsTagRemoveOthers = {
|
|
84
|
+
pt: {
|
|
85
|
+
remove: 'Remover todos os itens selecionados'
|
|
86
|
+
},
|
|
87
|
+
ru: {
|
|
88
|
+
remove: 'Удалить все выбранные элементы'
|
|
89
|
+
},
|
|
90
|
+
es: {
|
|
91
|
+
remove: 'Eliminar todos los elementos seleccionados'
|
|
92
|
+
},
|
|
93
|
+
en: {
|
|
94
|
+
remove: 'Clear all selected items'
|
|
95
|
+
}
|
|
96
|
+
};
|
|
79
97
|
/* istanbul ignore next */
|
|
80
98
|
const providers = [
|
|
81
99
|
PoMultiselectFilterService,
|
|
@@ -146,13 +164,16 @@ export class PoMultiselectComponent extends PoMultiselectBaseComponent {
|
|
|
146
164
|
dropdown;
|
|
147
165
|
iconElement;
|
|
148
166
|
inputElement;
|
|
149
|
-
|
|
167
|
+
literalsTag;
|
|
150
168
|
dropdownIcon = 'po-icon-arrow-down';
|
|
151
169
|
dropdownOpen = false;
|
|
152
170
|
initialized = false;
|
|
153
|
-
|
|
171
|
+
hasMoreTag;
|
|
154
172
|
timeoutResize;
|
|
155
173
|
visibleElement = false;
|
|
174
|
+
subscription = new Subscription();
|
|
175
|
+
enterCloseTag = false;
|
|
176
|
+
initCalculateItems = true;
|
|
156
177
|
isCalculateVisibleItems = true;
|
|
157
178
|
cacheOptions;
|
|
158
179
|
constructor(renderer, changeDetector, el, controlPosition, defaultService, languageService) {
|
|
@@ -162,6 +183,11 @@ export class PoMultiselectComponent extends PoMultiselectBaseComponent {
|
|
|
162
183
|
this.el = el;
|
|
163
184
|
this.controlPosition = controlPosition;
|
|
164
185
|
this.defaultService = defaultService;
|
|
186
|
+
const language = languageService.getShortLanguage();
|
|
187
|
+
this.literalsTag = {
|
|
188
|
+
...literalsTagRemoveOthers[poLocaleDefault],
|
|
189
|
+
...literalsTagRemoveOthers[language]
|
|
190
|
+
};
|
|
165
191
|
}
|
|
166
192
|
ngAfterViewInit() {
|
|
167
193
|
if (this.autoFocus) {
|
|
@@ -176,7 +202,7 @@ export class PoMultiselectComponent extends PoMultiselectBaseComponent {
|
|
|
176
202
|
}
|
|
177
203
|
ngDoCheck() {
|
|
178
204
|
const inputWidth = this.inputElement.nativeElement.offsetWidth;
|
|
179
|
-
// Permite que
|
|
205
|
+
// Permite que as tags sejam calculadas na primeira vez que o componente torna-se visível,
|
|
180
206
|
// evitando com isso, problemas com Tabs ou Divs que iniciem escondidas.
|
|
181
207
|
if ((inputWidth && !this.visibleElement && this.initialized) || (inputWidth && this.isCalculateVisibleItems)) {
|
|
182
208
|
this.debounceResize();
|
|
@@ -187,6 +213,7 @@ export class PoMultiselectComponent extends PoMultiselectBaseComponent {
|
|
|
187
213
|
this.removeListeners();
|
|
188
214
|
this.getObjectsByValuesSubscription?.unsubscribe();
|
|
189
215
|
this.filterSubject?.unsubscribe();
|
|
216
|
+
this.subscription.unsubscribe();
|
|
190
217
|
}
|
|
191
218
|
/**
|
|
192
219
|
* Função que atribui foco ao componente.
|
|
@@ -211,46 +238,54 @@ export class PoMultiselectComponent extends PoMultiselectBaseComponent {
|
|
|
211
238
|
}
|
|
212
239
|
}
|
|
213
240
|
getInputWidth() {
|
|
214
|
-
return this.el.nativeElement.querySelector('.po-input').offsetWidth -
|
|
241
|
+
return this.el.nativeElement.querySelector('.po-multiselect-input').offsetWidth - poMultiselectInputPaddingRight;
|
|
215
242
|
}
|
|
216
|
-
|
|
217
|
-
const
|
|
218
|
-
return Array.from(
|
|
243
|
+
getTagsWidth() {
|
|
244
|
+
const tags = this.el.nativeElement.querySelectorAll('po-tag');
|
|
245
|
+
return Array.from(tags).map(tag => tag['offsetWidth']);
|
|
219
246
|
}
|
|
220
247
|
calculateVisibleItems() {
|
|
221
|
-
|
|
248
|
+
this.hasMoreTag = false;
|
|
249
|
+
const tagsWidth = this.getTagsWidth();
|
|
222
250
|
const inputWidth = this.getInputWidth();
|
|
223
|
-
const
|
|
224
|
-
const
|
|
225
|
-
this.
|
|
251
|
+
const extraTagSize = 63;
|
|
252
|
+
const tagsVisible = tagsWidth[0];
|
|
253
|
+
this.visibleTags = [];
|
|
226
254
|
if (inputWidth > 0) {
|
|
227
255
|
let sum = 0;
|
|
228
256
|
let i = 0;
|
|
229
257
|
for (i = 0; i < this.selectedOptions.length; i++) {
|
|
230
|
-
sum +=
|
|
231
|
-
this.
|
|
258
|
+
sum += tagsWidth[i] + poMultiselectSpaceBetweenTags;
|
|
259
|
+
this.visibleTags.push(this.selectedOptions[i]);
|
|
232
260
|
if (sum > inputWidth) {
|
|
233
|
-
sum -=
|
|
261
|
+
sum -= tagsWidth[i];
|
|
234
262
|
this.isCalculateVisibleItems = false;
|
|
235
263
|
break;
|
|
236
264
|
}
|
|
237
265
|
}
|
|
238
|
-
if (
|
|
266
|
+
if (tagsVisible || !this.selectedOptions.length) {
|
|
239
267
|
if (i === this.selectedOptions.length) {
|
|
240
268
|
this.isCalculateVisibleItems = false;
|
|
241
269
|
return;
|
|
242
270
|
}
|
|
243
|
-
|
|
244
|
-
|
|
271
|
+
this.hasMoreTag = true;
|
|
272
|
+
if (sum + extraTagSize > inputWidth) {
|
|
273
|
+
this.visibleTags.splice(-2, 2);
|
|
245
274
|
const label = '+' + (this.selectedOptions.length + 1 - i).toString();
|
|
246
|
-
this.
|
|
275
|
+
this.visibleTags.push({ [this.fieldValue]: '', [this.fieldLabel]: label });
|
|
247
276
|
}
|
|
248
277
|
else {
|
|
249
|
-
this.
|
|
278
|
+
this.visibleTags.splice(-1, 1);
|
|
250
279
|
const label = '+' + (this.selectedOptions.length - i).toString();
|
|
251
|
-
this.
|
|
280
|
+
this.visibleTags.push({ [this.fieldValue]: '', [this.fieldLabel]: label });
|
|
252
281
|
}
|
|
253
282
|
}
|
|
283
|
+
if (this.initCalculateItems) {
|
|
284
|
+
setTimeout(() => {
|
|
285
|
+
this.handleKeyboardNavigationTag();
|
|
286
|
+
}, 300);
|
|
287
|
+
}
|
|
288
|
+
this.initCalculateItems = false;
|
|
254
289
|
}
|
|
255
290
|
this.changeDetector.markForCheck();
|
|
256
291
|
}
|
|
@@ -261,10 +296,13 @@ export class PoMultiselectComponent extends PoMultiselectBaseComponent {
|
|
|
261
296
|
this.changeDetector.detectChanges();
|
|
262
297
|
this.adjustContainerPosition();
|
|
263
298
|
}
|
|
299
|
+
setTimeout(() => {
|
|
300
|
+
this.handleKeyboardNavigationTag();
|
|
301
|
+
}, 300);
|
|
264
302
|
}
|
|
265
303
|
updateVisibleItems() {
|
|
266
304
|
if (this.selectedOptions) {
|
|
267
|
-
this.
|
|
305
|
+
this.visibleTags = [].concat(this.selectedOptions);
|
|
268
306
|
}
|
|
269
307
|
this.debounceResize();
|
|
270
308
|
// quando estiver dentro de modal
|
|
@@ -282,17 +320,45 @@ export class PoMultiselectComponent extends PoMultiselectBaseComponent {
|
|
|
282
320
|
this.changeDetector.markForCheck();
|
|
283
321
|
}
|
|
284
322
|
onBlur() {
|
|
323
|
+
if (typeof this.inputElement.nativeElement.getAttribute('aria-label') === 'string' &&
|
|
324
|
+
this.inputElement.nativeElement.getAttribute('aria-label').includes('Unselected')) {
|
|
325
|
+
this.inputElement.nativeElement.setAttribute('aria-label', this.label ? this.label : '');
|
|
326
|
+
}
|
|
285
327
|
this.onModelTouched?.();
|
|
286
328
|
}
|
|
287
329
|
onKeyDown(event) {
|
|
288
|
-
if (event.keyCode === PoKeyCodeEnum.
|
|
330
|
+
if ((event.keyCode === PoKeyCodeEnum.tab && this.visibleTags.length > 1) ||
|
|
331
|
+
(event.keyCode === PoKeyCodeEnum.tab && this.visibleTags.length < 1)) {
|
|
332
|
+
return;
|
|
333
|
+
}
|
|
334
|
+
if (event.keyCode === PoKeyCodeEnum.esc) {
|
|
335
|
+
event.preventDefault();
|
|
336
|
+
this.controlDropdownVisibility(false);
|
|
337
|
+
return;
|
|
338
|
+
}
|
|
339
|
+
if (event.keyCode === PoKeyCodeEnum.arrowDown && this.visibleTags.length > 0) {
|
|
289
340
|
event.preventDefault();
|
|
290
341
|
this.controlDropdownVisibility(true);
|
|
342
|
+
this.dropdown?.listbox?.setFocus();
|
|
291
343
|
return;
|
|
292
344
|
}
|
|
293
|
-
if (event.keyCode === PoKeyCodeEnum.
|
|
294
|
-
this.
|
|
345
|
+
if (event.keyCode === PoKeyCodeEnum.enter && !this.enterCloseTag) {
|
|
346
|
+
if (this.visibleTags.length === 0) {
|
|
347
|
+
this.toggleDropdownVisibility();
|
|
348
|
+
this.focus();
|
|
349
|
+
return;
|
|
350
|
+
}
|
|
351
|
+
else {
|
|
352
|
+
event.preventDefault();
|
|
353
|
+
this.toggleDropdownVisibility();
|
|
354
|
+
return;
|
|
355
|
+
}
|
|
356
|
+
}
|
|
357
|
+
if (event.keyCode === PoKeyCodeEnum.space) {
|
|
358
|
+
event.preventDefault();
|
|
359
|
+
this.toggleDropdownVisibility();
|
|
295
360
|
}
|
|
361
|
+
this.enterCloseTag = false;
|
|
296
362
|
}
|
|
297
363
|
toggleDropdownVisibility() {
|
|
298
364
|
if (this.disabled) {
|
|
@@ -303,6 +369,13 @@ export class PoMultiselectComponent extends PoMultiselectBaseComponent {
|
|
|
303
369
|
}
|
|
304
370
|
this.controlDropdownVisibility(!this.dropdownOpen);
|
|
305
371
|
}
|
|
372
|
+
onKeyDownDropdown(event, index) {
|
|
373
|
+
if (event.key === 'Escape') {
|
|
374
|
+
event.preventDefault();
|
|
375
|
+
this.controlDropdownVisibility(false);
|
|
376
|
+
this.inputElement.nativeElement.focus();
|
|
377
|
+
}
|
|
378
|
+
}
|
|
306
379
|
openDropdown(toOpen) {
|
|
307
380
|
if (toOpen && !this.disabled) {
|
|
308
381
|
this.controlDropdownVisibility(true);
|
|
@@ -336,11 +409,29 @@ export class PoMultiselectComponent extends PoMultiselectBaseComponent {
|
|
|
336
409
|
// timeout necessário para reposicionar corretamente quando dropdown estiver pra cima do input e realizar busca no input
|
|
337
410
|
setTimeout(() => this.adjustContainerPosition());
|
|
338
411
|
}
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
this.
|
|
342
|
-
|
|
343
|
-
|
|
412
|
+
closeTag(value, event) {
|
|
413
|
+
let index;
|
|
414
|
+
this.enterCloseTag = true;
|
|
415
|
+
if (!value || (typeof value === 'string' && value.includes('+'))) {
|
|
416
|
+
index = null;
|
|
417
|
+
const itemsNotInVisibleTags = this.selectedOptions.filter(option => !this.visibleTags.includes(option));
|
|
418
|
+
for (const option of this.visibleTags) {
|
|
419
|
+
if (!this.selectedOptions.includes(option)) {
|
|
420
|
+
this.selectedOptions.splice(this.visibleTags.length - 1, itemsNotInVisibleTags.length);
|
|
421
|
+
this.updateVisibleItems();
|
|
422
|
+
this.callOnChange(this.selectedOptions);
|
|
423
|
+
}
|
|
424
|
+
}
|
|
425
|
+
}
|
|
426
|
+
else {
|
|
427
|
+
index = this.selectedOptions.findIndex(option => option[this.fieldValue] === value);
|
|
428
|
+
this.selectedOptions.splice(index, 1);
|
|
429
|
+
this.updateVisibleItems();
|
|
430
|
+
this.callOnChange(this.selectedOptions);
|
|
431
|
+
}
|
|
432
|
+
setTimeout(() => {
|
|
433
|
+
this.focusOnNextTag(index, event);
|
|
434
|
+
}, 300);
|
|
344
435
|
}
|
|
345
436
|
wasClickedOnToggle(event) {
|
|
346
437
|
if (this.dropdownOpen &&
|
|
@@ -389,6 +480,84 @@ export class PoMultiselectComponent extends PoMultiselectBaseComponent {
|
|
|
389
480
|
this.setVisibleOptionsDropdown(this.options);
|
|
390
481
|
this.removeListeners();
|
|
391
482
|
}
|
|
483
|
+
focusOnNextTag(indexClosed, clickOrEnter) {
|
|
484
|
+
if (clickOrEnter === 'enter') {
|
|
485
|
+
const tagRemoveElements = this.el.nativeElement.querySelectorAll('.po-tag-remove');
|
|
486
|
+
indexClosed = indexClosed || indexClosed === 0 ? indexClosed : tagRemoveElements.length;
|
|
487
|
+
if (tagRemoveElements.length === 0) {
|
|
488
|
+
this.inputElement.nativeElement.focus();
|
|
489
|
+
this.inputElement.nativeElement.setAttribute('aria-label', `Unselected items ${this.label}`);
|
|
490
|
+
this.controlDropdownVisibility(true);
|
|
491
|
+
}
|
|
492
|
+
this.focusOnRemoveTag(tagRemoveElements, indexClosed);
|
|
493
|
+
}
|
|
494
|
+
else {
|
|
495
|
+
indexClosed = 0;
|
|
496
|
+
}
|
|
497
|
+
this.handleKeyboardNavigationTag(indexClosed);
|
|
498
|
+
}
|
|
499
|
+
focusOnRemoveTag(tag, indexClosed) {
|
|
500
|
+
if (tag.length === indexClosed) {
|
|
501
|
+
tag[indexClosed - 1]?.focus();
|
|
502
|
+
}
|
|
503
|
+
else {
|
|
504
|
+
tag[indexClosed]?.focus();
|
|
505
|
+
}
|
|
506
|
+
}
|
|
507
|
+
handleKeyboardNavigationTag(initialIndex = 0) {
|
|
508
|
+
this.subscription.unsubscribe();
|
|
509
|
+
this.subscription = new Subscription();
|
|
510
|
+
const tagRemoveElements = this.el.nativeElement.querySelectorAll('.po-tag-remove');
|
|
511
|
+
this.initializeTagRemoveElements(tagRemoveElements, initialIndex);
|
|
512
|
+
}
|
|
513
|
+
setTabIndex(element, tabIndex) {
|
|
514
|
+
element.setAttribute('tabindex', tabIndex);
|
|
515
|
+
}
|
|
516
|
+
handleArrowLeft(tagRemoveElements, index) {
|
|
517
|
+
if (index > 0) {
|
|
518
|
+
this.setTabIndex(tagRemoveElements[index], -1);
|
|
519
|
+
tagRemoveElements[index - 1].focus();
|
|
520
|
+
this.setTabIndex(tagRemoveElements[index - 1], 0);
|
|
521
|
+
}
|
|
522
|
+
}
|
|
523
|
+
handleArrowRight(tagRemoveElements, index) {
|
|
524
|
+
if (index < tagRemoveElements.length - 1) {
|
|
525
|
+
this.setTabIndex(tagRemoveElements[index], -1);
|
|
526
|
+
tagRemoveElements[index + 1].focus();
|
|
527
|
+
this.setTabIndex(tagRemoveElements[index + 1], 0);
|
|
528
|
+
}
|
|
529
|
+
}
|
|
530
|
+
handleKeyDown(event, tagRemoveElements, index) {
|
|
531
|
+
const KEY_SPACE = 'Space';
|
|
532
|
+
const KEY_ARROW_LEFT = 'ArrowLeft';
|
|
533
|
+
const KEY_ARROW_RIGHT = 'ArrowRight';
|
|
534
|
+
if (event.code === KEY_SPACE) {
|
|
535
|
+
event.preventDefault();
|
|
536
|
+
event.stopPropagation();
|
|
537
|
+
}
|
|
538
|
+
if (event.key === KEY_ARROW_LEFT) {
|
|
539
|
+
this.handleArrowLeft(tagRemoveElements, index);
|
|
540
|
+
}
|
|
541
|
+
else if (event.key === KEY_ARROW_RIGHT) {
|
|
542
|
+
this.handleArrowRight(tagRemoveElements, index);
|
|
543
|
+
}
|
|
544
|
+
}
|
|
545
|
+
initializeTagRemoveElements(tagRemoveElements, initialIndex) {
|
|
546
|
+
tagRemoveElements.forEach((tagRemoveElement, index) => {
|
|
547
|
+
if (index === initialIndex) {
|
|
548
|
+
this.setTabIndex(tagRemoveElements[initialIndex], 0);
|
|
549
|
+
}
|
|
550
|
+
else if (tagRemoveElements.length === initialIndex) {
|
|
551
|
+
this.setTabIndex(tagRemoveElements[initialIndex - 1], 0);
|
|
552
|
+
}
|
|
553
|
+
else {
|
|
554
|
+
this.setTabIndex(tagRemoveElement, -1);
|
|
555
|
+
}
|
|
556
|
+
this.subscription.add(fromEvent(tagRemoveElement, 'keydown').subscribe((event) => {
|
|
557
|
+
this.handleKeyDown(event, tagRemoveElements, index);
|
|
558
|
+
}));
|
|
559
|
+
});
|
|
560
|
+
}
|
|
392
561
|
initializeListeners() {
|
|
393
562
|
this.clickOutListener = this.renderer.listen('document', 'click', (event) => {
|
|
394
563
|
this.wasClickedOnToggle(event);
|
|
@@ -443,11 +612,11 @@ export class PoMultiselectComponent extends PoMultiselectBaseComponent {
|
|
|
443
612
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.dropdown = _t.first);
|
|
444
613
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.iconElement = _t.first);
|
|
445
614
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.inputElement = _t.first);
|
|
446
|
-
} }, features: [i0.ɵɵProvidersFeature(providers), i0.ɵɵInheritDefinitionFeature, i0.ɵɵNgOnChangesFeature], decls: 18, vars:
|
|
615
|
+
} }, features: [i0.ɵɵProvidersFeature(providers), i0.ɵɵInheritDefinitionFeature, i0.ɵɵNgOnChangesFeature], decls: 18, vars: 30, consts: [[3, "p-disabled", "p-label", "p-optional", "p-required", "p-show-required"], ["cdkOverlayOrigin", "", 1, "po-field-container-content"], ["trigger", "cdkOverlayOrigin"], [1, "po-input-icon-right", "po-multiselect-input", 3, "tabindex", "keydown", "click", "blur"], ["inputElement", ""], ["class", "po-multiselect-input-placeholder", "aria-hidden", "true", 4, "ngIf"], [3, "p-value", "p-literals", "p-removable", "po-clickable", "p-disabled", "p-close", 4, "ngFor", "ngForOf"], [1, "po-field-icon-container-right"], [3, "ngClass"], ["iconElement", ""], [4, "ngIf", "ngIfThen", "ngIfElse"], ["dropdownDefault", ""], ["dropdownCDK", ""], [3, "p-help", "p-disabled"], ["dropdownListbox", ""], ["aria-hidden", "true", 1, "po-multiselect-input-placeholder"], [3, "p-value", "p-literals", "p-removable", "p-disabled", "p-close"], [4, "ngTemplateOutlet"], ["cdkConnectedOverlay", "", 3, "cdkConnectedOverlayOrigin", "cdkConnectedOverlayOpen"], [3, "p-searching", "p-hide-search", "p-hide-select-all", "p-literals", "p-options", "p-visible-options", "p-selected-options", "p-placeholder-search", "p-field-value", "p-field-label", "p-multiselect-template", "p-change", "p-change-search", "p-close-dropdown", "keydown"], ["dropdownElement", ""]], template: function PoMultiselectComponent_Template(rf, ctx) { if (rf & 1) {
|
|
447
616
|
i0.ɵɵelementStart(0, "po-field-container", 0)(1, "div", 1, 2)(3, "div", 3, 4);
|
|
448
|
-
i0.ɵɵlistener("
|
|
617
|
+
i0.ɵɵlistener("keydown", function PoMultiselectComponent_Template_div_keydown_3_listener($event) { return ctx.onKeyDown($event); })("click", function PoMultiselectComponent_Template_div_click_3_listener() { return ctx.toggleDropdownVisibility(); })("blur", function PoMultiselectComponent_Template_div_blur_3_listener() { return ctx.onBlur(); });
|
|
449
618
|
i0.ɵɵtemplate(5, PoMultiselectComponent_span_5_Template, 2, 1, "span", 5);
|
|
450
|
-
i0.ɵɵtemplate(6,
|
|
619
|
+
i0.ɵɵtemplate(6, PoMultiselectComponent_po_tag_6_Template, 1, 6, "po-tag", 6);
|
|
451
620
|
i0.ɵɵelementStart(7, "div", 7);
|
|
452
621
|
i0.ɵɵelement(8, "span", 8, 9);
|
|
453
622
|
i0.ɵɵelementEnd()()();
|
|
@@ -464,13 +633,13 @@ export class PoMultiselectComponent extends PoMultiselectBaseComponent {
|
|
|
464
633
|
i0.ɵɵadvance(1);
|
|
465
634
|
i0.ɵɵclassProp("po-multiselect-show", ctx.dropdownOpen);
|
|
466
635
|
i0.ɵɵadvance(2);
|
|
467
|
-
i0.ɵɵclassProp("po-multiselect-input-auto", ctx.autoHeight)("po-multiselect-input-static", !ctx.autoHeight)("po-multiselect-input-disabled", ctx.disabled);
|
|
636
|
+
i0.ɵɵclassProp("po-multiselect-input-auto", ctx.autoHeight)("po-multiselect-input-static", !ctx.autoHeight)("po-multiselect-input-disabled", ctx.disabled)("po-multiselect-input-font", !ctx.disabled && !(ctx.visibleTags == null ? null : ctx.visibleTags.length));
|
|
468
637
|
i0.ɵɵproperty("tabindex", ctx.disabled ? -1 : 0);
|
|
469
638
|
i0.ɵɵattribute("disabled", ctx.disabled)("aria-label", ctx.label);
|
|
470
639
|
i0.ɵɵadvance(2);
|
|
471
|
-
i0.ɵɵproperty("ngIf",
|
|
640
|
+
i0.ɵɵproperty("ngIf", !ctx.disabled && !(ctx.visibleTags == null ? null : ctx.visibleTags.length));
|
|
472
641
|
i0.ɵɵadvance(1);
|
|
473
|
-
i0.ɵɵproperty("ngForOf", ctx.
|
|
642
|
+
i0.ɵɵproperty("ngForOf", ctx.visibleTags);
|
|
474
643
|
i0.ɵɵadvance(2);
|
|
475
644
|
i0.ɵɵclassMapInterpolate2("po-icon po-field-icon ", ctx.dropdownIcon, " ", ctx.disabled ? "po-icon-input-disabled" : "po-icon-input", "");
|
|
476
645
|
i0.ɵɵproperty("ngClass", ctx.disabled ? "po-field-icon-disabled" : "");
|
|
@@ -482,7 +651,7 @@ export class PoMultiselectComponent extends PoMultiselectBaseComponent {
|
|
|
482
651
|
}
|
|
483
652
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoMultiselectComponent, [{
|
|
484
653
|
type: Component,
|
|
485
|
-
args: [{ selector: 'po-multiselect', changeDetection: ChangeDetectionStrategy.OnPush, providers: providers, template: "<po-field-container\n [p-disabled]=\"disabled\"\n [p-label]=\"label\"\n [p-optional]=\"optional\"\n [p-required]=\"required\"\n [p-show-required]=\"showRequired\"\n>\n <div\n cdkOverlayOrigin\n #trigger=\"cdkOverlayOrigin\"\n class=\"po-field-container-content\"\n [class.po-multiselect-show]=\"dropdownOpen\"\n >\n <div\n #inputElement\n [tabindex]=\"disabled ? -1 : 0\"\n [attr.disabled]=\"disabled\"\n [attr.aria-label]=\"label\"\n class=\"po-input
|
|
654
|
+
args: [{ selector: 'po-multiselect', changeDetection: ChangeDetectionStrategy.OnPush, providers: providers, template: "<po-field-container\n [p-disabled]=\"disabled\"\n [p-label]=\"label\"\n [p-optional]=\"optional\"\n [p-required]=\"required\"\n [p-show-required]=\"showRequired\"\n>\n <div\n cdkOverlayOrigin\n #trigger=\"cdkOverlayOrigin\"\n class=\"po-field-container-content\"\n [class.po-multiselect-show]=\"dropdownOpen\"\n >\n <div\n #inputElement\n [tabindex]=\"disabled ? -1 : 0\"\n [attr.disabled]=\"disabled\"\n [attr.aria-label]=\"label\"\n class=\"po-input-icon-right po-multiselect-input\"\n [class.po-multiselect-input-auto]=\"autoHeight\"\n [class.po-multiselect-input-static]=\"!autoHeight\"\n [class.po-multiselect-input-disabled]=\"disabled\"\n [class.po-multiselect-input-font]=\"!disabled && !visibleTags?.length\"\n (keydown)=\"onKeyDown($event)\"\n (click)=\"toggleDropdownVisibility()\"\n (blur)=\"onBlur()\"\n >\n <span *ngIf=\"!disabled && !visibleTags?.length\" class=\"po-multiselect-input-placeholder\" aria-hidden=\"true\">\n {{ placeholder ? placeholder : literals.selectItem }}\n </span>\n\n <po-tag\n *ngFor=\"let tag of visibleTags; index as i\"\n [p-value]=\"tag[fieldLabel]\"\n [p-literals]=\"i + 1 === visibleTags.length && hasMoreTag ? literalsTag : undefined\"\n [p-removable]=\"true\"\n [class.po-clickable]=\"tag[fieldValue] === '' && !disabled\"\n [p-disabled]=\"disabled\"\n (p-close)=\"closeTag(tag[fieldValue], $event)\"\n ></po-tag>\n\n <div class=\"po-field-icon-container-right\">\n <span\n #iconElement\n class=\"po-icon po-field-icon {{ dropdownIcon }} {{ disabled ? 'po-icon-input-disabled' : 'po-icon-input' }}\"\n [ngClass]=\"disabled ? 'po-field-icon-disabled' : ''\"\n >\n </span>\n </div>\n </div>\n </div>\n\n <ng-container *ngIf=\"appendBox; then dropdownCDK; else dropdownDefault\"> </ng-container>\n\n <ng-template #dropdownDefault>\n <ng-container *ngTemplateOutlet=\"dropdownListbox\"> </ng-container>\n </ng-template>\n\n <ng-template #dropdownCDK>\n <ng-template cdkConnectedOverlay [cdkConnectedOverlayOrigin]=\"trigger\" [cdkConnectedOverlayOpen]=\"true\">\n <ng-container *ngTemplateOutlet=\"dropdownListbox\"></ng-container>\n </ng-template>\n </ng-template>\n\n <po-field-container-bottom [p-help]=\"help\" [p-disabled]=\"disabled\"></po-field-container-bottom>\n</po-field-container>\n\n<ng-template #dropdownListbox>\n <po-multiselect-dropdown\n #dropdownElement\n [p-searching]=\"isServerSearching\"\n [p-hide-search]=\"hideSearch\"\n [p-hide-select-all]=\"hideSelectAll\"\n [p-literals]=\"literals\"\n [p-options]=\"options\"\n [p-visible-options]=\"visibleOptionsDropdown\"\n [p-selected-options]=\"selectedOptions\"\n [p-placeholder-search]=\"placeholderSearch\"\n [p-field-value]=\"fieldValue\"\n [p-field-label]=\"fieldLabel\"\n [p-multiselect-template]=\"multiselectOptionTemplate\"\n (p-change)=\"changeItems($event)\"\n (p-change-search)=\"changeSearch($event)\"\n (p-close-dropdown)=\"controlDropdownVisibility(false)\"\n (keydown)=\"onKeyDownDropdown($event, 0)\"\n >\n </po-multiselect-dropdown>\n</ng-template>\n" }]
|
|
486
655
|
}], function () { return [{ type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i1.PoControlPositionService }, { type: i2.PoMultiselectFilterService }, { type: i3.PoLanguageService }]; }, { multiselectOptionTemplate: [{
|
|
487
656
|
type: ContentChild,
|
|
488
657
|
args: [PoMultiselectOptionTemplateDirective, { static: true }]
|
|
@@ -499,4 +668,4 @@ export class PoMultiselectComponent extends PoMultiselectBaseComponent {
|
|
|
499
668
|
type: ViewChild,
|
|
500
669
|
args: ['inputElement', { read: ElementRef, static: true }]
|
|
501
670
|
}] }); })();
|
|
502
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-multiselect.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-multiselect/po-multiselect.component.ts","../../../../../../../projects/ui/src/lib/components/po-field/po-multiselect/po-multiselect.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DoCheck,\n  ElementRef,\n  forwardRef,\n  OnChanges,\n  OnDestroy,\n  Renderer2,\n  SimpleChanges,\n  ViewChild,\n  ContentChild\n} from '@angular/core';\nimport { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { Observable, of } from 'rxjs';\nimport { tap, catchError } from 'rxjs/operators';\n\nimport { isMobile } from './../../../utils/util';\nimport { PoControlPositionService } from './../../../services/po-control-position/po-control-position.service';\nimport { PoKeyCodeEnum } from './../../../enums/po-key-code.enum';\nimport { PoLanguageService } from '../../../services/po-language/po-language.service';\n\nimport { PoMultiselectBaseComponent } from './po-multiselect-base.component';\nimport { PoMultiselectOption } from './po-multiselect-option.interface';\nimport { PoMultiselectFilterService } from './po-multiselect-filter.service';\nimport { PoMultiselectOptionTemplateDirective } from './po-multiselect-option-template/po-multiselect-option-template.directive';\n\nconst poMultiselectContainerOffset = 8;\nconst poMultiselectContainerPositionDefault = 'bottom';\n\n/* istanbul ignore next */\nconst providers = [\n  PoMultiselectFilterService,\n  PoControlPositionService,\n  {\n    provide: NG_VALUE_ACCESSOR,\n    // eslint-disable-next-line\n    useExisting: forwardRef(() => PoMultiselectComponent),\n    multi: true\n  },\n  {\n    provide: NG_VALIDATORS,\n    // eslint-disable-next-line\n    useExisting: forwardRef(() => PoMultiselectComponent),\n    multi: true\n  }\n];\n\n/**\n * @docsExtends PoMultiselectBaseComponent\n *\n * @example\n *\n * <example name=\"po-multiselect-basic\" title=\"PO Multiselect Basic\">\n *   <file name=\"sample-po-multiselect-basic/sample-po-multiselect-basic.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-basic/sample-po-multiselect-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-labs\" title=\"PO Multiselect Labs\">\n *   <file name=\"sample-po-multiselect-labs/sample-po-multiselect-labs.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-labs/sample-po-multiselect-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-vacation\" title=\"PO Multiselect - Vacation\">\n *   <file name=\"sample-po-multiselect-vacation/sample-po-multiselect-vacation.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-vacation/sample-po-multiselect-vacation.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-vacation-reactive-form\" title=\"PO Multiselect - Vacation Reactive Form\">\n *   <file name=\"sample-po-multiselect-vacation-reactive-form/sample-po-multiselect-vacation-reactive-form.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-vacation-reactive-form/sample-po-multiselect-vacation-reactive-form.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-template\" title=\"PO Multiselect - Template\">\n *   <file name=\"sample-po-multiselect-template/sample-po-multiselect-template.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-template/sample-po-multiselect-template.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-heroes\" title=\"PO Multiselect - Heroes - using API\">\n *   <file name=\"sample-po-multiselect-heroes/sample-po-multiselect-heroes.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-heroes/sample-po-multiselect-heroes.component.ts\"> </file>\n *   <file name=\"sample-po-multiselect-heroes/sample-po-multiselect-heroes.service.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-any-array\" title=\"PO Multiselect - Array Any\">\n *   <file name=\"sample-po-multiselect-any-array/sample-po-multiselect-any-array.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-any-array/sample-po-multiselect-any-array.component.ts\"> </file>\n * </example>\n *\n */\n@Component({\n  selector: 'po-multiselect',\n  templateUrl: './po-multiselect.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers\n})\nexport class PoMultiselectComponent\n  extends PoMultiselectBaseComponent\n  implements AfterViewInit, DoCheck, OnDestroy, OnChanges {\n  @ContentChild(PoMultiselectOptionTemplateDirective, { static: true })\n  multiselectOptionTemplate: PoMultiselectOptionTemplateDirective;\n\n  @ViewChild('dropdownElement', { read: ElementRef }) dropdownElement: ElementRef;\n  @ViewChild('dropdownElement') dropdown;\n  @ViewChild('iconElement', { read: ElementRef, static: true }) iconElement: ElementRef;\n  @ViewChild('inputElement', { read: ElementRef, static: true }) inputElement: ElementRef;\n\n  disclaimerOffset = 0;\n  dropdownIcon: string = 'po-icon-arrow-down';\n  dropdownOpen: boolean = false;\n  initialized = false;\n  positionDisclaimerExtra;\n  timeoutResize;\n  visibleElement = false;\n\n  private isCalculateVisibleItems: boolean = true;\n  private cacheOptions: Array<PoMultiselectOption | any>;\n\n  constructor(\n    private renderer: Renderer2,\n    private changeDetector: ChangeDetectorRef,\n    private el: ElementRef,\n    private controlPosition: PoControlPositionService,\n    public defaultService: PoMultiselectFilterService,\n    languageService: PoLanguageService\n  ) {\n    super(languageService);\n  }\n\n  ngAfterViewInit() {\n    if (this.autoFocus) {\n      this.focus();\n    }\n    this.initialized = true;\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (this.filterService && (changes.filterService || changes.fieldValue || changes.fieldLabel)) {\n      this.setService(this.filterService);\n    }\n  }\n\n  ngDoCheck() {\n    const inputWidth = this.inputElement.nativeElement.offsetWidth;\n    // Permite que os disclaimers sejam calculados na primeira vez que o componente torna-se visível,\n    // evitando com isso, problemas com Tabs ou Divs que iniciem escondidas.\n    if ((inputWidth && !this.visibleElement && this.initialized) || (inputWidth && this.isCalculateVisibleItems)) {\n      this.debounceResize();\n      this.visibleElement = true;\n    }\n  }\n\n  ngOnDestroy() {\n    this.removeListeners();\n    this.getObjectsByValuesSubscription?.unsubscribe();\n    this.filterSubject?.unsubscribe();\n  }\n\n  /**\n   * Função que atribui foco ao componente.\n   *\n   * Para utilizá-la é necessário ter a instância do componente no DOM, podendo ser utilizado o ViewChild da seguinte forma:\n   *\n   * ```\n   * import { PoMultiselectComponent } from '@po-ui/ng-components';\n   *\n   * ...\n   *\n   * @ViewChild(PoMultiselectComponent, { static: true }) multiselect: PoMultiselectComponent;\n   *\n   * focusMultiselect() {\n   *   this.multiselect.focus();\n   * }\n   * ```\n   */\n  focus(): void {\n    if (!this.disabled) {\n      this.inputElement.nativeElement.focus();\n    }\n  }\n\n  getInputWidth() {\n    return this.el.nativeElement.querySelector('.po-input').offsetWidth - 40;\n  }\n\n  getDisclaimersWidth() {\n    const disclaimers = this.el.nativeElement.querySelectorAll('po-disclaimer');\n    return Array.from(disclaimers).map(disclaimer => disclaimer['offsetWidth']);\n  }\n\n  calculateVisibleItems() {\n    const disclaimersWidth = this.getDisclaimersWidth();\n    const inputWidth = this.getInputWidth();\n    const extraDisclaimerSize = 38;\n    const disclaimersVisible = disclaimersWidth[0];\n\n    this.visibleDisclaimers = [];\n\n    if (inputWidth > 0) {\n      let sum = 0;\n      let i = 0;\n      for (i = 0; i < this.selectedOptions.length; i++) {\n        sum += disclaimersWidth[i];\n        this.visibleDisclaimers.push(this.selectedOptions[i]);\n\n        if (sum > inputWidth) {\n          sum -= disclaimersWidth[i];\n          this.isCalculateVisibleItems = false;\n          break;\n        }\n      }\n\n      if (disclaimersVisible || !this.selectedOptions.length) {\n        if (i === this.selectedOptions.length) {\n          this.isCalculateVisibleItems = false;\n          return;\n        }\n\n        if (sum + extraDisclaimerSize > inputWidth) {\n          this.visibleDisclaimers.splice(-2, 2);\n          const label = '+' + (this.selectedOptions.length + 1 - i).toString();\n          this.visibleDisclaimers.push({ [this.fieldValue]: '', [this.fieldLabel]: label });\n        } else {\n          this.visibleDisclaimers.splice(-1, 1);\n          const label = '+' + (this.selectedOptions.length - i).toString();\n          this.visibleDisclaimers.push({ [this.fieldValue]: '', [this.fieldLabel]: label });\n        }\n      }\n    }\n    this.changeDetector.markForCheck();\n  }\n\n  changeItems(changedItems) {\n    this.updateSelectedOptions(changedItems);\n    this.callOnChange(this.selectedOptions);\n\n    if (this.autoHeight && this.dropdownOpen) {\n      this.changeDetector.detectChanges();\n      this.adjustContainerPosition();\n    }\n  }\n\n  updateVisibleItems() {\n    if (this.selectedOptions) {\n      this.visibleDisclaimers = [].concat(this.selectedOptions);\n    }\n\n    this.debounceResize();\n\n    // quando estiver dentro de modal\n    if (!this.inputElement.nativeElement.offsetWidth) {\n      this.isCalculateVisibleItems = true;\n    }\n  }\n\n  debounceResize() {\n    if (!this.autoHeight) {\n      clearTimeout(this.timeoutResize);\n      this.timeoutResize = setTimeout(() => {\n        this.calculateVisibleItems();\n      }, 200);\n    }\n    this.changeDetector.markForCheck();\n  }\n\n  onBlur() {\n    this.onModelTouched?.();\n  }\n\n  onKeyDown(event?: any) {\n    if (event.keyCode === PoKeyCodeEnum.arrowUp || event.keyCode === PoKeyCodeEnum.arrowDown) {\n      event.preventDefault();\n      this.controlDropdownVisibility(true);\n      return;\n    }\n\n    if (event.keyCode === PoKeyCodeEnum.tab) {\n      this.controlDropdownVisibility(false);\n    }\n  }\n\n  toggleDropdownVisibility() {\n    if (this.disabled) {\n      return;\n    }\n\n    if (this.filterService) {\n      this.applyFilterInFirstClick();\n    }\n\n    this.controlDropdownVisibility(!this.dropdownOpen);\n  }\n\n  openDropdown(toOpen) {\n    if (toOpen && !this.disabled) {\n      this.controlDropdownVisibility(true);\n    }\n  }\n\n  controlDropdownVisibility(toOpen: boolean) {\n    toOpen ? this.open() : this.close();\n  }\n\n  scrollToSelectedOptions() {\n    if (this.selectedOptions && this.selectedOptions.length) {\n      const index = this.options.findIndex(\n        option => option[this.fieldValue] === this.selectedOptions[0][this.fieldValue]\n      );\n      this.dropdown.scrollTo(index);\n    }\n  }\n\n  setVisibleOptionsDropdown(options) {\n    this.visibleOptionsDropdown = options;\n    this.changeDetector.markForCheck();\n  }\n\n  changeSearch(event) {\n    if (event && event[this.fieldValue] !== undefined) {\n      if (this.filterService) {\n        this.filterSubject.next(event[this.fieldValue]);\n      } else {\n        this.searchByLabel(event[this.fieldValue], this.options, this.filterMode);\n      }\n    } else {\n      this.setVisibleOptionsDropdown(this.options);\n    }\n\n    // timeout necessário para reposicionar corretamente quando dropdown estiver pra cima do input e realizar busca no input\n    setTimeout(() => this.adjustContainerPosition());\n  }\n\n  closeDisclaimer(value) {\n    const index = this.selectedOptions.findIndex(option => option[this.fieldValue] === value);\n    this.selectedOptions.splice(index, 1);\n\n    this.updateVisibleItems();\n    this.callOnChange(this.selectedOptions);\n  }\n\n  wasClickedOnToggle(event: MouseEvent): void {\n    if (\n      this.dropdownOpen &&\n      !this.inputElement.nativeElement.contains(event.target) &&\n      !this.iconElement.nativeElement.contains(event.target) &&\n      !this.dropdownElement.nativeElement.contains(event.target)\n    ) {\n      this.controlDropdownVisibility(false);\n    }\n  }\n\n  applyFilter(value: string = ''): Observable<Array<PoMultiselectOption | any>> {\n    const param = { property: this.fieldLabel, value: value };\n    return this.service.getFilteredData(param).pipe(\n      catchError(err => {\n        this.isServerSearching = false;\n        return of([]);\n      }),\n      tap((options: Array<PoMultiselectOption | any>) => {\n        this.setOptionsByApplyFilter(options);\n      })\n    );\n  }\n\n  private applyFilterInFirstClick() {\n    if (this.isFirstFilter) {\n      this.isServerSearching = true;\n\n      // necessario enviar um objeto string vazia para refazer a busca, quando alterar filterService, fieldValue e fieldLabel\n      // pois temos o distinctUntilChange no pipe do filterSubject\n      /* eslint-disable no-new-wrappers */\n      this.filterSubject.next(new String());\n    } else {\n      this.options = [...this.cacheOptions];\n    }\n  }\n\n  private setOptionsByApplyFilter(items: Array<PoMultiselectOption | any>) {\n    if (this.isFirstFilter) {\n      this.cacheOptions = [...items];\n      this.isFirstFilter = false;\n    }\n\n    this.options = [...items];\n    this.setVisibleOptionsDropdown(this.options);\n  }\n\n  private adjustContainerPosition(): void {\n    this.controlPosition.adjustPosition(poMultiselectContainerPositionDefault);\n  }\n\n  private close(): void {\n    this.dropdownIcon = 'po-icon-arrow-down';\n    this.dropdownOpen = false;\n\n    this.dropdown.controlVisibility(false);\n    this.setVisibleOptionsDropdown(this.options);\n\n    this.removeListeners();\n  }\n\n  private initializeListeners(): void {\n    this.clickOutListener = this.renderer.listen('document', 'click', (event: MouseEvent) => {\n      this.wasClickedOnToggle(event);\n    });\n\n    this.resizeListener = this.renderer.listen('window', 'resize', () => {\n      this.updateVisibleItems();\n\n      isMobile() ? this.adjustContainerPosition() : this.close();\n    });\n\n    window.addEventListener('scroll', this.onScroll, true);\n  }\n\n  private onScroll = (): void => {\n    this.adjustContainerPosition();\n  };\n\n  private open(): void {\n    this.dropdownIcon = 'po-icon-arrow-up';\n    this.dropdownOpen = true;\n\n    this.dropdown.controlVisibility(true);\n    this.setVisibleOptionsDropdown(this.options);\n    this.initializeListeners();\n    this.scrollToSelectedOptions();\n\n    this.changeDetector.detectChanges();\n    this.setPositionDropdown();\n  }\n\n  private removeListeners(): void {\n    if (this.clickOutListener) {\n      this.clickOutListener();\n    }\n\n    if (this.resizeListener) {\n      this.resizeListener();\n    }\n\n    window.removeEventListener('scroll', this.onScroll, true);\n    this.changeDetector.markForCheck();\n  }\n\n  private setPositionDropdown(): void {\n    this.controlPosition.setElements(\n      this.dropdown.container.nativeElement,\n      poMultiselectContainerOffset,\n      this.inputElement,\n      ['top', 'bottom'],\n      true\n    );\n\n    this.adjustContainerPosition();\n  }\n}\n","<po-field-container\n  [p-disabled]=\"disabled\"\n  [p-label]=\"label\"\n  [p-optional]=\"optional\"\n  [p-required]=\"required\"\n  [p-show-required]=\"showRequired\"\n>\n  <div\n    cdkOverlayOrigin\n    #trigger=\"cdkOverlayOrigin\"\n    class=\"po-field-container-content\"\n    [class.po-multiselect-show]=\"dropdownOpen\"\n  >\n    <div\n      #inputElement\n      [tabindex]=\"disabled ? -1 : 0\"\n      [attr.disabled]=\"disabled\"\n      [attr.aria-label]=\"label\"\n      class=\"po-input po-input-icon-right po-multiselect-input po-clickable\"\n      [class.po-multiselect-input-auto]=\"autoHeight\"\n      [class.po-multiselect-input-static]=\"!autoHeight\"\n      [class.po-multiselect-input-disabled]=\"disabled\"\n      (keyup.enter)=\"toggleDropdownVisibility()\"\n      (keydown)=\"onKeyDown($event)\"\n      (click)=\"toggleDropdownVisibility()\"\n      (blur)=\"onBlur()\"\n    >\n      <span *ngIf=\"placeholder && !disabled && !visibleDisclaimers?.length\" class=\"po-multiselect-input-placeholder\">\n        {{ placeholder }}\n      </span>\n\n      <po-disclaimer\n        *ngFor=\"let disclaimer of visibleDisclaimers\"\n        class=\"po-multiselect-input-disclaimer\"\n        [p-label]=\"disclaimer[fieldLabel]\"\n        [p-value]=\"disclaimer[fieldValue]\"\n        [p-hide-close]=\"disclaimer[fieldValue] === '' || disabled\"\n        [class.po-clickable]=\"disclaimer[fieldValue] === '' && !disabled\"\n        (click)=\"openDropdown(disclaimer[fieldValue] === '')\"\n        (p-close-action)=\"closeDisclaimer(disclaimer[fieldValue])\"\n      >\n      </po-disclaimer>\n\n      <div class=\"po-field-icon-container-right\">\n        <span\n          #iconElement\n          class=\"po-icon po-field-icon {{ dropdownIcon }} {{ disabled ? 'po-icon-input-disabled' : 'po-icon-input' }}\"\n          [ngClass]=\"disabled ? 'po-field-icon-disabled' : ''\"\n        >\n        </span>\n      </div>\n    </div>\n  </div>\n\n  <ng-container *ngIf=\"appendBox; then dropdownCDK; else dropdownDefault\"> </ng-container>\n\n  <ng-template #dropdownDefault>\n    <ng-container *ngTemplateOutlet=\"dropdownListbox\"> </ng-container>\n  </ng-template>\n\n  <ng-template #dropdownCDK>\n    <ng-template cdkConnectedOverlay [cdkConnectedOverlayOrigin]=\"trigger\" [cdkConnectedOverlayOpen]=\"true\">\n      <ng-container *ngTemplateOutlet=\"dropdownListbox\"></ng-container>\n    </ng-template>\n  </ng-template>\n\n  <po-field-container-bottom [p-help]=\"help\" [p-disabled]=\"disabled\"></po-field-container-bottom>\n</po-field-container>\n\n<ng-template #dropdownListbox>\n  <po-multiselect-dropdown\n    #dropdownElement\n    [p-searching]=\"isServerSearching\"\n    [p-hide-search]=\"hideSearch\"\n    [p-hide-select-all]=\"hideSelectAll\"\n    [p-literals]=\"literals\"\n    [p-options]=\"options\"\n    [p-visible-options]=\"visibleOptionsDropdown\"\n    [p-selected-options]=\"selectedOptions\"\n    [p-placeholder-search]=\"placeholderSearch\"\n    [p-field-value]=\"fieldValue\"\n    [p-field-label]=\"fieldLabel\"\n    [p-multiselect-template]=\"multiselectOptionTemplate\"\n    (p-change)=\"changeItems($event)\"\n    (p-change-search)=\"changeSearch($event)\"\n    (p-close-dropdown)=\"controlDropdownVisibility(false)\"\n  >\n  </po-multiselect-dropdown>\n</ng-template>\n"]}
|
|
671
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-multiselect.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-multiselect/po-multiselect.component.ts","../../../../../../../projects/ui/src/lib/components/po-field/po-multiselect/po-multiselect.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  DoCheck,\n  ElementRef,\n  OnChanges,\n  OnDestroy,\n  Renderer2,\n  SimpleChanges,\n  ViewChild,\n  forwardRef\n} from '@angular/core';\nimport { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { Observable, Subscription, fromEvent, of } from 'rxjs';\nimport { catchError, tap } from 'rxjs/operators';\n\nimport { PoLanguageService } from '../../../services/po-language/po-language.service';\nimport { PoKeyCodeEnum } from './../../../enums/po-key-code.enum';\nimport { PoControlPositionService } from './../../../services/po-control-position/po-control-position.service';\nimport { isMobile } from './../../../utils/util';\n\nimport { poLocaleDefault } from '../../../services/po-language/po-language.constant';\nimport { PoMultiselectBaseComponent } from './po-multiselect-base.component';\nimport { PoMultiselectFilterService } from './po-multiselect-filter.service';\nimport { PoMultiselectOptionTemplateDirective } from './po-multiselect-option-template/po-multiselect-option-template.directive';\nimport { PoMultiselectOption } from './po-multiselect-option.interface';\n\nconst poMultiselectContainerOffset = 8;\nconst poMultiselectContainerPositionDefault = 'bottom';\nconst poMultiselectInputPaddingRight = 52;\nconst poMultiselectSpaceBetweenTags = 8;\n\nconst literalsTagRemoveOthers = {\n  pt: {\n    remove: 'Remover todos os itens selecionados'\n  },\n  ru: {\n    remove: 'Удалить все выбранные элементы'\n  },\n  es: {\n    remove: 'Eliminar todos los elementos seleccionados'\n  },\n  en: {\n    remove: 'Clear all selected items'\n  }\n};\n\n/* istanbul ignore next */\nconst providers = [\n  PoMultiselectFilterService,\n  PoControlPositionService,\n  {\n    provide: NG_VALUE_ACCESSOR,\n    // eslint-disable-next-line\n    useExisting: forwardRef(() => PoMultiselectComponent),\n    multi: true\n  },\n  {\n    provide: NG_VALIDATORS,\n    // eslint-disable-next-line\n    useExisting: forwardRef(() => PoMultiselectComponent),\n    multi: true\n  }\n];\n\n/**\n * @docsExtends PoMultiselectBaseComponent\n *\n * @example\n *\n * <example name=\"po-multiselect-basic\" title=\"PO Multiselect Basic\">\n *   <file name=\"sample-po-multiselect-basic/sample-po-multiselect-basic.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-basic/sample-po-multiselect-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-labs\" title=\"PO Multiselect Labs\">\n *   <file name=\"sample-po-multiselect-labs/sample-po-multiselect-labs.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-labs/sample-po-multiselect-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-vacation\" title=\"PO Multiselect - Vacation\">\n *   <file name=\"sample-po-multiselect-vacation/sample-po-multiselect-vacation.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-vacation/sample-po-multiselect-vacation.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-vacation-reactive-form\" title=\"PO Multiselect - Vacation Reactive Form\">\n *   <file name=\"sample-po-multiselect-vacation-reactive-form/sample-po-multiselect-vacation-reactive-form.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-vacation-reactive-form/sample-po-multiselect-vacation-reactive-form.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-template\" title=\"PO Multiselect - Template\">\n *   <file name=\"sample-po-multiselect-template/sample-po-multiselect-template.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-template/sample-po-multiselect-template.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-heroes\" title=\"PO Multiselect - Heroes - using API\">\n *   <file name=\"sample-po-multiselect-heroes/sample-po-multiselect-heroes.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-heroes/sample-po-multiselect-heroes.component.ts\"> </file>\n *   <file name=\"sample-po-multiselect-heroes/sample-po-multiselect-heroes.service.ts\"> </file>\n * </example>\n *\n * <example name=\"po-multiselect-any-array\" title=\"PO Multiselect - Array Any\">\n *   <file name=\"sample-po-multiselect-any-array/sample-po-multiselect-any-array.component.html\"> </file>\n *   <file name=\"sample-po-multiselect-any-array/sample-po-multiselect-any-array.component.ts\"> </file>\n * </example>\n *\n */\n@Component({\n  selector: 'po-multiselect',\n  templateUrl: './po-multiselect.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers\n})\nexport class PoMultiselectComponent\n  extends PoMultiselectBaseComponent\n  implements AfterViewInit, DoCheck, OnDestroy, OnChanges {\n  @ContentChild(PoMultiselectOptionTemplateDirective, { static: true })\n  multiselectOptionTemplate: PoMultiselectOptionTemplateDirective;\n\n  @ViewChild('dropdownElement', { read: ElementRef }) dropdownElement: ElementRef;\n  @ViewChild('dropdownElement') dropdown;\n  @ViewChild('iconElement', { read: ElementRef, static: true }) iconElement: ElementRef;\n  @ViewChild('inputElement', { read: ElementRef, static: true }) inputElement: ElementRef;\n\n  literalsTag;\n  dropdownIcon: string = 'po-icon-arrow-down';\n  dropdownOpen: boolean = false;\n  initialized = false;\n  hasMoreTag: boolean;\n  timeoutResize;\n  visibleElement = false;\n  private subscription: Subscription = new Subscription();\n  private enterCloseTag = false;\n  private initCalculateItems = true;\n  private isCalculateVisibleItems: boolean = true;\n  private cacheOptions: Array<PoMultiselectOption | any>;\n\n  constructor(\n    private renderer: Renderer2,\n    private changeDetector: ChangeDetectorRef,\n    private el: ElementRef,\n    private controlPosition: PoControlPositionService,\n    public defaultService: PoMultiselectFilterService,\n    languageService: PoLanguageService\n  ) {\n    super(languageService);\n    const language = languageService.getShortLanguage();\n    this.literalsTag = {\n      ...literalsTagRemoveOthers[poLocaleDefault],\n      ...literalsTagRemoveOthers[language]\n    };\n  }\n\n  ngAfterViewInit() {\n    if (this.autoFocus) {\n      this.focus();\n    }\n    this.initialized = true;\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (this.filterService && (changes.filterService || changes.fieldValue || changes.fieldLabel)) {\n      this.setService(this.filterService);\n    }\n  }\n\n  ngDoCheck() {\n    const inputWidth = this.inputElement.nativeElement.offsetWidth;\n    // Permite que as tags sejam calculadas na primeira vez que o componente torna-se visível,\n    // evitando com isso, problemas com Tabs ou Divs que iniciem escondidas.\n    if ((inputWidth && !this.visibleElement && this.initialized) || (inputWidth && this.isCalculateVisibleItems)) {\n      this.debounceResize();\n      this.visibleElement = true;\n    }\n  }\n\n  ngOnDestroy() {\n    this.removeListeners();\n    this.getObjectsByValuesSubscription?.unsubscribe();\n    this.filterSubject?.unsubscribe();\n    this.subscription.unsubscribe();\n  }\n\n  /**\n   * Função que atribui foco ao componente.\n   *\n   * Para utilizá-la é necessário ter a instância do componente no DOM, podendo ser utilizado o ViewChild da seguinte forma:\n   *\n   * ```\n   * import { PoMultiselectComponent } from '@po-ui/ng-components';\n   *\n   * ...\n   *\n   * @ViewChild(PoMultiselectComponent, { static: true }) multiselect: PoMultiselectComponent;\n   *\n   * focusMultiselect() {\n   *   this.multiselect.focus();\n   * }\n   * ```\n   */\n  focus(): void {\n    if (!this.disabled) {\n      this.inputElement.nativeElement.focus();\n    }\n  }\n\n  getInputWidth() {\n    return this.el.nativeElement.querySelector('.po-multiselect-input').offsetWidth - poMultiselectInputPaddingRight;\n  }\n\n  getTagsWidth() {\n    const tags = this.el.nativeElement.querySelectorAll('po-tag');\n    return Array.from(tags).map(tag => tag['offsetWidth']);\n  }\n\n  calculateVisibleItems() {\n    this.hasMoreTag = false;\n    const tagsWidth = this.getTagsWidth();\n    const inputWidth = this.getInputWidth();\n    const extraTagSize = 63;\n    const tagsVisible = tagsWidth[0];\n\n    this.visibleTags = [];\n\n    if (inputWidth > 0) {\n      let sum = 0;\n      let i = 0;\n      for (i = 0; i < this.selectedOptions.length; i++) {\n        sum += tagsWidth[i] + poMultiselectSpaceBetweenTags;\n        this.visibleTags.push(this.selectedOptions[i]);\n\n        if (sum > inputWidth) {\n          sum -= tagsWidth[i];\n          this.isCalculateVisibleItems = false;\n          break;\n        }\n      }\n\n      if (tagsVisible || !this.selectedOptions.length) {\n        if (i === this.selectedOptions.length) {\n          this.isCalculateVisibleItems = false;\n          return;\n        }\n\n        this.hasMoreTag = true;\n        if (sum + extraTagSize > inputWidth) {\n          this.visibleTags.splice(-2, 2);\n          const label = '+' + (this.selectedOptions.length + 1 - i).toString();\n          this.visibleTags.push({ [this.fieldValue]: '', [this.fieldLabel]: label });\n        } else {\n          this.visibleTags.splice(-1, 1);\n          const label = '+' + (this.selectedOptions.length - i).toString();\n          this.visibleTags.push({ [this.fieldValue]: '', [this.fieldLabel]: label });\n        }\n      }\n      if (this.initCalculateItems) {\n        setTimeout(() => {\n          this.handleKeyboardNavigationTag();\n        }, 300);\n      }\n      this.initCalculateItems = false;\n    }\n    this.changeDetector.markForCheck();\n  }\n\n  changeItems(changedItems) {\n    this.updateSelectedOptions(changedItems);\n    this.callOnChange(this.selectedOptions);\n\n    if (this.autoHeight && this.dropdownOpen) {\n      this.changeDetector.detectChanges();\n      this.adjustContainerPosition();\n    }\n    setTimeout(() => {\n      this.handleKeyboardNavigationTag();\n    }, 300);\n  }\n\n  updateVisibleItems() {\n    if (this.selectedOptions) {\n      this.visibleTags = [].concat(this.selectedOptions);\n    }\n\n    this.debounceResize();\n\n    // quando estiver dentro de modal\n    if (!this.inputElement.nativeElement.offsetWidth) {\n      this.isCalculateVisibleItems = true;\n    }\n  }\n\n  debounceResize() {\n    if (!this.autoHeight) {\n      clearTimeout(this.timeoutResize);\n      this.timeoutResize = setTimeout(() => {\n        this.calculateVisibleItems();\n      }, 200);\n    }\n    this.changeDetector.markForCheck();\n  }\n\n  onBlur() {\n    if (\n      typeof this.inputElement.nativeElement.getAttribute('aria-label') === 'string' &&\n      this.inputElement.nativeElement.getAttribute('aria-label').includes('Unselected')\n    ) {\n      this.inputElement.nativeElement.setAttribute('aria-label', this.label ? this.label : '');\n    }\n    this.onModelTouched?.();\n  }\n\n  onKeyDown(event?: any) {\n    if (\n      (event.keyCode === PoKeyCodeEnum.tab && this.visibleTags.length > 1) ||\n      (event.keyCode === PoKeyCodeEnum.tab && this.visibleTags.length < 1)\n    ) {\n      return;\n    }\n\n    if (event.keyCode === PoKeyCodeEnum.esc) {\n      event.preventDefault();\n      this.controlDropdownVisibility(false);\n      return;\n    }\n\n    if (event.keyCode === PoKeyCodeEnum.arrowDown && this.visibleTags.length > 0) {\n      event.preventDefault();\n      this.controlDropdownVisibility(true);\n      this.dropdown?.listbox?.setFocus();\n      return;\n    }\n\n    if (event.keyCode === PoKeyCodeEnum.enter && !this.enterCloseTag) {\n      if (this.visibleTags.length === 0) {\n        this.toggleDropdownVisibility();\n        this.focus();\n        return;\n      } else {\n        event.preventDefault();\n        this.toggleDropdownVisibility();\n        return;\n      }\n    }\n\n    if (event.keyCode === PoKeyCodeEnum.space) {\n      event.preventDefault();\n      this.toggleDropdownVisibility();\n    }\n    this.enterCloseTag = false;\n  }\n\n  toggleDropdownVisibility() {\n    if (this.disabled) {\n      return;\n    }\n\n    if (this.filterService) {\n      this.applyFilterInFirstClick();\n    }\n\n    this.controlDropdownVisibility(!this.dropdownOpen);\n  }\n\n  onKeyDownDropdown(event: KeyboardEvent, index: number) {\n    if (event.key === 'Escape') {\n      event.preventDefault();\n      this.controlDropdownVisibility(false);\n      this.inputElement.nativeElement.focus();\n    }\n  }\n\n  openDropdown(toOpen) {\n    if (toOpen && !this.disabled) {\n      this.controlDropdownVisibility(true);\n    }\n  }\n\n  controlDropdownVisibility(toOpen: boolean) {\n    toOpen ? this.open() : this.close();\n  }\n\n  scrollToSelectedOptions() {\n    if (this.selectedOptions && this.selectedOptions.length) {\n      const index = this.options.findIndex(\n        option => option[this.fieldValue] === this.selectedOptions[0][this.fieldValue]\n      );\n      this.dropdown.scrollTo(index);\n    }\n  }\n\n  setVisibleOptionsDropdown(options) {\n    this.visibleOptionsDropdown = options;\n    this.changeDetector.markForCheck();\n  }\n\n  changeSearch(event) {\n    if (event && event[this.fieldValue] !== undefined) {\n      if (this.filterService) {\n        this.filterSubject.next(event[this.fieldValue]);\n      } else {\n        this.searchByLabel(event[this.fieldValue], this.options, this.filterMode);\n      }\n    } else {\n      this.setVisibleOptionsDropdown(this.options);\n    }\n\n    // timeout necessário para reposicionar corretamente quando dropdown estiver pra cima do input e realizar busca no input\n    setTimeout(() => this.adjustContainerPosition());\n  }\n\n  closeTag(value, event) {\n    let index;\n    this.enterCloseTag = true;\n    if (!value || (typeof value === 'string' && value.includes('+'))) {\n      index = null;\n      const itemsNotInVisibleTags = this.selectedOptions.filter(option => !this.visibleTags.includes(option));\n      for (const option of this.visibleTags) {\n        if (!this.selectedOptions.includes(option)) {\n          this.selectedOptions.splice(this.visibleTags.length - 1, itemsNotInVisibleTags.length);\n          this.updateVisibleItems();\n          this.callOnChange(this.selectedOptions);\n        }\n      }\n    } else {\n      index = this.selectedOptions.findIndex(option => option[this.fieldValue] === value);\n      this.selectedOptions.splice(index, 1);\n      this.updateVisibleItems();\n      this.callOnChange(this.selectedOptions);\n    }\n\n    setTimeout(() => {\n      this.focusOnNextTag(index, event);\n    }, 300);\n  }\n\n  wasClickedOnToggle(event: MouseEvent): void {\n    if (\n      this.dropdownOpen &&\n      !this.inputElement.nativeElement.contains(event.target) &&\n      !this.iconElement.nativeElement.contains(event.target) &&\n      !this.dropdownElement.nativeElement.contains(event.target)\n    ) {\n      this.controlDropdownVisibility(false);\n    }\n  }\n\n  applyFilter(value: string = ''): Observable<Array<PoMultiselectOption | any>> {\n    const param = { property: this.fieldLabel, value: value };\n    return this.service.getFilteredData(param).pipe(\n      catchError(err => {\n        this.isServerSearching = false;\n        return of([]);\n      }),\n      tap((options: Array<PoMultiselectOption | any>) => {\n        this.setOptionsByApplyFilter(options);\n      })\n    );\n  }\n\n  private applyFilterInFirstClick() {\n    if (this.isFirstFilter) {\n      this.isServerSearching = true;\n\n      // necessario enviar um objeto string vazia para refazer a busca, quando alterar filterService, fieldValue e fieldLabel\n      // pois temos o distinctUntilChange no pipe do filterSubject\n      /* eslint-disable no-new-wrappers */\n      this.filterSubject.next(new String());\n    } else {\n      this.options = [...this.cacheOptions];\n    }\n  }\n\n  private setOptionsByApplyFilter(items: Array<PoMultiselectOption | any>) {\n    if (this.isFirstFilter) {\n      this.cacheOptions = [...items];\n      this.isFirstFilter = false;\n    }\n\n    this.options = [...items];\n    this.setVisibleOptionsDropdown(this.options);\n  }\n\n  private adjustContainerPosition(): void {\n    this.controlPosition.adjustPosition(poMultiselectContainerPositionDefault);\n  }\n\n  private close(): void {\n    this.dropdownIcon = 'po-icon-arrow-down';\n    this.dropdownOpen = false;\n\n    this.dropdown.controlVisibility(false);\n    this.setVisibleOptionsDropdown(this.options);\n\n    this.removeListeners();\n  }\n\n  private focusOnNextTag(indexClosed: number, clickOrEnter: string) {\n    if (clickOrEnter === 'enter') {\n      const tagRemoveElements: Array<any> = this.el.nativeElement.querySelectorAll('.po-tag-remove');\n      indexClosed = indexClosed || indexClosed === 0 ? indexClosed : tagRemoveElements.length;\n      if (tagRemoveElements.length === 0) {\n        this.inputElement.nativeElement.focus();\n        this.inputElement.nativeElement.setAttribute('aria-label', `Unselected items ${this.label}`);\n        this.controlDropdownVisibility(true);\n      }\n      this.focusOnRemoveTag(tagRemoveElements, indexClosed);\n    } else {\n      indexClosed = 0;\n    }\n    this.handleKeyboardNavigationTag(indexClosed);\n  }\n\n  private focusOnRemoveTag(tag: any, indexClosed: number) {\n    if (tag.length === indexClosed) {\n      tag[indexClosed - 1]?.focus();\n    } else {\n      tag[indexClosed]?.focus();\n    }\n  }\n\n  public handleKeyboardNavigationTag(initialIndex = 0) {\n    this.subscription.unsubscribe();\n    this.subscription = new Subscription();\n    const tagRemoveElements = this.el.nativeElement.querySelectorAll('.po-tag-remove');\n    this.initializeTagRemoveElements(tagRemoveElements, initialIndex);\n  }\n\n  private setTabIndex(element, tabIndex) {\n    element.setAttribute('tabindex', tabIndex);\n  }\n\n  private handleArrowLeft(tagRemoveElements, index) {\n    if (index > 0) {\n      this.setTabIndex(tagRemoveElements[index], -1);\n      tagRemoveElements[index - 1].focus();\n      this.setTabIndex(tagRemoveElements[index - 1], 0);\n    }\n  }\n\n  private handleArrowRight(tagRemoveElements, index) {\n    if (index < tagRemoveElements.length - 1) {\n      this.setTabIndex(tagRemoveElements[index], -1);\n      tagRemoveElements[index + 1].focus();\n      this.setTabIndex(tagRemoveElements[index + 1], 0);\n    }\n  }\n\n  private handleKeyDown(event: KeyboardEvent, tagRemoveElements, index) {\n    const KEY_SPACE = 'Space';\n    const KEY_ARROW_LEFT = 'ArrowLeft';\n    const KEY_ARROW_RIGHT = 'ArrowRight';\n\n    if (event.code === KEY_SPACE) {\n      event.preventDefault();\n      event.stopPropagation();\n    }\n\n    if (event.key === KEY_ARROW_LEFT) {\n      this.handleArrowLeft(tagRemoveElements, index);\n    } else if (event.key === KEY_ARROW_RIGHT) {\n      this.handleArrowRight(tagRemoveElements, index);\n    }\n  }\n\n  private initializeTagRemoveElements(tagRemoveElements, initialIndex) {\n    tagRemoveElements.forEach((tagRemoveElement, index) => {\n      if (index === initialIndex) {\n        this.setTabIndex(tagRemoveElements[initialIndex], 0);\n      } else if (tagRemoveElements.length === initialIndex) {\n        this.setTabIndex(tagRemoveElements[initialIndex - 1], 0);\n      } else {\n        this.setTabIndex(tagRemoveElement, -1);\n      }\n\n      this.subscription.add(\n        fromEvent(tagRemoveElement, 'keydown').subscribe((event: KeyboardEvent) => {\n          this.handleKeyDown(event, tagRemoveElements, index);\n        })\n      );\n    });\n  }\n\n  private initializeListeners(): void {\n    this.clickOutListener = this.renderer.listen('document', 'click', (event: MouseEvent) => {\n      this.wasClickedOnToggle(event);\n    });\n\n    this.resizeListener = this.renderer.listen('window', 'resize', () => {\n      this.updateVisibleItems();\n\n      isMobile() ? this.adjustContainerPosition() : this.close();\n    });\n\n    window.addEventListener('scroll', this.onScroll, true);\n  }\n\n  private onScroll = (): void => {\n    this.adjustContainerPosition();\n  };\n\n  private open(): void {\n    this.dropdownIcon = 'po-icon-arrow-up';\n    this.dropdownOpen = true;\n\n    this.dropdown.controlVisibility(true);\n    this.setVisibleOptionsDropdown(this.options);\n    this.initializeListeners();\n    this.scrollToSelectedOptions();\n\n    this.changeDetector.detectChanges();\n    this.setPositionDropdown();\n  }\n\n  private removeListeners(): void {\n    if (this.clickOutListener) {\n      this.clickOutListener();\n    }\n\n    if (this.resizeListener) {\n      this.resizeListener();\n    }\n\n    window.removeEventListener('scroll', this.onScroll, true);\n    this.changeDetector.markForCheck();\n  }\n\n  private setPositionDropdown(): void {\n    this.controlPosition.setElements(\n      this.dropdown.container.nativeElement,\n      poMultiselectContainerOffset,\n      this.inputElement,\n      ['top', 'bottom'],\n      true\n    );\n\n    this.adjustContainerPosition();\n  }\n}\n","<po-field-container\n  [p-disabled]=\"disabled\"\n  [p-label]=\"label\"\n  [p-optional]=\"optional\"\n  [p-required]=\"required\"\n  [p-show-required]=\"showRequired\"\n>\n  <div\n    cdkOverlayOrigin\n    #trigger=\"cdkOverlayOrigin\"\n    class=\"po-field-container-content\"\n    [class.po-multiselect-show]=\"dropdownOpen\"\n  >\n    <div\n      #inputElement\n      [tabindex]=\"disabled ? -1 : 0\"\n      [attr.disabled]=\"disabled\"\n      [attr.aria-label]=\"label\"\n      class=\"po-input-icon-right po-multiselect-input\"\n      [class.po-multiselect-input-auto]=\"autoHeight\"\n      [class.po-multiselect-input-static]=\"!autoHeight\"\n      [class.po-multiselect-input-disabled]=\"disabled\"\n      [class.po-multiselect-input-font]=\"!disabled && !visibleTags?.length\"\n      (keydown)=\"onKeyDown($event)\"\n      (click)=\"toggleDropdownVisibility()\"\n      (blur)=\"onBlur()\"\n    >\n      <span *ngIf=\"!disabled && !visibleTags?.length\" class=\"po-multiselect-input-placeholder\" aria-hidden=\"true\">\n        {{ placeholder ? placeholder : literals.selectItem }}\n      </span>\n\n      <po-tag\n        *ngFor=\"let tag of visibleTags; index as i\"\n        [p-value]=\"tag[fieldLabel]\"\n        [p-literals]=\"i + 1 === visibleTags.length && hasMoreTag ? literalsTag : undefined\"\n        [p-removable]=\"true\"\n        [class.po-clickable]=\"tag[fieldValue] === '' && !disabled\"\n        [p-disabled]=\"disabled\"\n        (p-close)=\"closeTag(tag[fieldValue], $event)\"\n      ></po-tag>\n\n      <div class=\"po-field-icon-container-right\">\n        <span\n          #iconElement\n          class=\"po-icon po-field-icon {{ dropdownIcon }} {{ disabled ? 'po-icon-input-disabled' : 'po-icon-input' }}\"\n          [ngClass]=\"disabled ? 'po-field-icon-disabled' : ''\"\n        >\n        </span>\n      </div>\n    </div>\n  </div>\n\n  <ng-container *ngIf=\"appendBox; then dropdownCDK; else dropdownDefault\"> </ng-container>\n\n  <ng-template #dropdownDefault>\n    <ng-container *ngTemplateOutlet=\"dropdownListbox\"> </ng-container>\n  </ng-template>\n\n  <ng-template #dropdownCDK>\n    <ng-template cdkConnectedOverlay [cdkConnectedOverlayOrigin]=\"trigger\" [cdkConnectedOverlayOpen]=\"true\">\n      <ng-container *ngTemplateOutlet=\"dropdownListbox\"></ng-container>\n    </ng-template>\n  </ng-template>\n\n  <po-field-container-bottom [p-help]=\"help\" [p-disabled]=\"disabled\"></po-field-container-bottom>\n</po-field-container>\n\n<ng-template #dropdownListbox>\n  <po-multiselect-dropdown\n    #dropdownElement\n    [p-searching]=\"isServerSearching\"\n    [p-hide-search]=\"hideSearch\"\n    [p-hide-select-all]=\"hideSelectAll\"\n    [p-literals]=\"literals\"\n    [p-options]=\"options\"\n    [p-visible-options]=\"visibleOptionsDropdown\"\n    [p-selected-options]=\"selectedOptions\"\n    [p-placeholder-search]=\"placeholderSearch\"\n    [p-field-value]=\"fieldValue\"\n    [p-field-label]=\"fieldLabel\"\n    [p-multiselect-template]=\"multiselectOptionTemplate\"\n    (p-change)=\"changeItems($event)\"\n    (p-change-search)=\"changeSearch($event)\"\n    (p-close-dropdown)=\"controlDropdownVisibility(false)\"\n    (keydown)=\"onKeyDownDropdown($event, 0)\"\n  >\n  </po-multiselect-dropdown>\n</ng-template>\n"]}
|