@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.
Files changed (42) hide show
  1. package/esm2022/lib/components/po-field/po-field.module.mjs +17 -13
  2. package/esm2022/lib/components/po-field/po-lookup/po-lookup-modal/po-lookup-modal.component.mjs +4 -4
  3. package/esm2022/lib/components/po-field/po-multiselect/po-multiselect-base.component.mjs +30 -7
  4. package/esm2022/lib/components/po-field/po-multiselect/po-multiselect-dropdown/po-multiselect-dropdown.component.mjs +4 -4
  5. package/esm2022/lib/components/po-field/po-multiselect/po-multiselect-literals.interface.mjs +1 -1
  6. package/esm2022/lib/components/po-field/po-multiselect/po-multiselect.component.mjs +220 -51
  7. package/esm2022/lib/components/po-field/po-rich-text/po-rich-text-toolbar/po-rich-text-toolbar.component.mjs +3 -3
  8. package/esm2022/lib/components/po-listbox/po-item-list/po-item-list.component.mjs +2 -2
  9. package/esm2022/lib/components/po-table/po-table-base.component.mjs +5 -5
  10. package/esm2022/lib/components/po-tag/index.mjs +2 -1
  11. package/esm2022/lib/components/po-tag/interfaces/po-tag-literals.interface.mjs +2 -0
  12. package/esm2022/lib/components/po-tag/po-tag-base.component.mjs +70 -4
  13. package/esm2022/lib/components/po-tag/po-tag.component.mjs +52 -44
  14. package/esm2022/lib/enums/po-key-code.enum.mjs +5 -1
  15. package/fesm2022/po-ui-ng-components.mjs +701 -532
  16. package/fesm2022/po-ui-ng-components.mjs.map +1 -1
  17. package/lib/components/po-field/po-field.module.d.ts +44 -44
  18. package/lib/components/po-field/po-multiselect/po-multiselect-base.component.d.ts +21 -2
  19. package/lib/components/po-field/po-multiselect/po-multiselect-literals.interface.d.ts +2 -0
  20. package/lib/components/po-field/po-multiselect/po-multiselect.component.d.ts +18 -6
  21. package/lib/components/po-table/po-table-base.component.d.ts +2 -2
  22. package/lib/components/po-tag/index.d.ts +1 -0
  23. package/lib/components/po-tag/interfaces/po-tag-literals.interface.d.ts +11 -0
  24. package/lib/components/po-tag/po-tag-base.component.d.ts +50 -2
  25. package/lib/components/po-tag/po-tag.component.d.ts +6 -6
  26. package/lib/enums/po-key-code.enum.d.ts +5 -1
  27. package/package.json +4 -4
  28. package/po-ui-ng-components-16.5.0.tgz +0 -0
  29. package/schematics/ng-add/index.js +1 -1
  30. package/schematics/ng-update/v14/index.js +1 -1
  31. package/schematics/ng-update/v15/index.js +1 -1
  32. package/schematics/ng-update/v16/index.js +1 -1
  33. package/schematics/ng-update/v2/index.js +1 -1
  34. package/schematics/ng-update/v3/index.js +1 -1
  35. package/schematics/ng-update/v4/index.js +1 -1
  36. package/schematics/ng-update/v5/index.js +1 -1
  37. package/schematics/ng-update/v6/index.js +1 -1
  38. package/esm2022/lib/components/po-field/po-multiselect/po-multiselect-search/po-multiselect-search.component.mjs +0 -91
  39. package/esm2022/lib/components/po-tag/po-tag.literals.mjs +0 -15
  40. package/lib/components/po-field/po-multiselect/po-multiselect-search/po-multiselect-search.component.d.ts +0 -40
  41. package/lib/components/po-tag/po-tag.literals.d.ts +0 -14
  42. package/po-ui-ng-components-16.4.1.tgz +0 -0
@@ -1,10 +1,11 @@
1
- import { ChangeDetectionStrategy, Component, ElementRef, forwardRef, ViewChild, ContentChild } from '@angular/core';
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 { tap, catchError } from 'rxjs/operators';
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 PoMultiselectComponent_po_disclaimer_6_Template(rf, ctx) { if (rf & 1) {
28
- const _r14 = i0.ɵɵgetCurrentView();
29
- i0.ɵɵelementStart(0, "po-disclaimer", 16);
30
- i0.ɵɵlistener("click", function PoMultiselectComponent_po_disclaimer_6_Template_po_disclaimer_click_0_listener() { const restoredCtx = i0.ɵɵrestoreView(_r14); const disclaimer_r12 = restoredCtx.$implicit; const ctx_r13 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r13.openDropdown(disclaimer_r12[ctx_r13.fieldValue] === "")); })("p-close-action", function PoMultiselectComponent_po_disclaimer_6_Template_po_disclaimer_p_close_action_0_listener() { const restoredCtx = i0.ɵɵrestoreView(_r14); const disclaimer_r12 = restoredCtx.$implicit; const ctx_r15 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r15.closeDisclaimer(disclaimer_r12[ctx_r15.fieldValue])); });
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 disclaimer_r12 = ctx.$implicit;
34
+ const tag_r12 = ctx.$implicit;
35
+ const i_r13 = ctx.index;
34
36
  const ctx_r3 = i0.ɵɵnextContext();
35
- i0.ɵɵclassProp("po-clickable", disclaimer_r12[ctx_r3.fieldValue] === "" && !ctx_r3.disabled);
36
- i0.ɵɵproperty("p-label", disclaimer_r12[ctx_r3.fieldLabel])("p-value", disclaimer_r12[ctx_r3.fieldValue])("p-hide-close", disclaimer_r12[ctx_r3.fieldValue] === "" || ctx_r3.disabled);
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
- disclaimerOffset = 0;
167
+ literalsTag;
150
168
  dropdownIcon = 'po-icon-arrow-down';
151
169
  dropdownOpen = false;
152
170
  initialized = false;
153
- positionDisclaimerExtra;
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 os disclaimers sejam calculados na primeira vez que o componente torna-se visível,
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 - 40;
241
+ return this.el.nativeElement.querySelector('.po-multiselect-input').offsetWidth - poMultiselectInputPaddingRight;
215
242
  }
216
- getDisclaimersWidth() {
217
- const disclaimers = this.el.nativeElement.querySelectorAll('po-disclaimer');
218
- return Array.from(disclaimers).map(disclaimer => disclaimer['offsetWidth']);
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
- const disclaimersWidth = this.getDisclaimersWidth();
248
+ this.hasMoreTag = false;
249
+ const tagsWidth = this.getTagsWidth();
222
250
  const inputWidth = this.getInputWidth();
223
- const extraDisclaimerSize = 38;
224
- const disclaimersVisible = disclaimersWidth[0];
225
- this.visibleDisclaimers = [];
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 += disclaimersWidth[i];
231
- this.visibleDisclaimers.push(this.selectedOptions[i]);
258
+ sum += tagsWidth[i] + poMultiselectSpaceBetweenTags;
259
+ this.visibleTags.push(this.selectedOptions[i]);
232
260
  if (sum > inputWidth) {
233
- sum -= disclaimersWidth[i];
261
+ sum -= tagsWidth[i];
234
262
  this.isCalculateVisibleItems = false;
235
263
  break;
236
264
  }
237
265
  }
238
- if (disclaimersVisible || !this.selectedOptions.length) {
266
+ if (tagsVisible || !this.selectedOptions.length) {
239
267
  if (i === this.selectedOptions.length) {
240
268
  this.isCalculateVisibleItems = false;
241
269
  return;
242
270
  }
243
- if (sum + extraDisclaimerSize > inputWidth) {
244
- this.visibleDisclaimers.splice(-2, 2);
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.visibleDisclaimers.push({ [this.fieldValue]: '', [this.fieldLabel]: label });
275
+ this.visibleTags.push({ [this.fieldValue]: '', [this.fieldLabel]: label });
247
276
  }
248
277
  else {
249
- this.visibleDisclaimers.splice(-1, 1);
278
+ this.visibleTags.splice(-1, 1);
250
279
  const label = '+' + (this.selectedOptions.length - i).toString();
251
- this.visibleDisclaimers.push({ [this.fieldValue]: '', [this.fieldLabel]: label });
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.visibleDisclaimers = [].concat(this.selectedOptions);
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.arrowUp || event.keyCode === PoKeyCodeEnum.arrowDown) {
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.tab) {
294
- this.controlDropdownVisibility(false);
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
- closeDisclaimer(value) {
340
- const index = this.selectedOptions.findIndex(option => option[this.fieldValue] === value);
341
- this.selectedOptions.splice(index, 1);
342
- this.updateVisibleItems();
343
- this.callOnChange(this.selectedOptions);
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: 28, consts: [[3, "p-disabled", "p-label", "p-optional", "p-required", "p-show-required"], ["cdkOverlayOrigin", "", 1, "po-field-container-content"], ["trigger", "cdkOverlayOrigin"], [1, "po-input", "po-input-icon-right", "po-multiselect-input", "po-clickable", 3, "tabindex", "keyup.enter", "keydown", "click", "blur"], ["inputElement", ""], ["class", "po-multiselect-input-placeholder", 4, "ngIf"], ["class", "po-multiselect-input-disclaimer", 3, "p-label", "p-value", "p-hide-close", "po-clickable", "click", "p-close-action", 4, "ngFor", "ngForOf"], [1, "po-field-icon-container-right"], [3, "ngClass"], ["iconElement", ""], [4, "ngIf", "ngIfThen", "ngIfElse"], ["dropdownDefault", ""], ["dropdownCDK", ""], [3, "p-help", "p-disabled"], ["dropdownListbox", ""], [1, "po-multiselect-input-placeholder"], [1, "po-multiselect-input-disclaimer", 3, "p-label", "p-value", "p-hide-close", "click", "p-close-action"], [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"], ["dropdownElement", ""]], template: function PoMultiselectComponent_Template(rf, ctx) { if (rf & 1) {
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("keyup.enter", function PoMultiselectComponent_Template_div_keyup_enter_3_listener() { return ctx.toggleDropdownVisibility(); })("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(); });
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, PoMultiselectComponent_po_disclaimer_6_Template, 1, 5, "po-disclaimer", 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", ctx.placeholder && !ctx.disabled && !(ctx.visibleDisclaimers == null ? null : ctx.visibleDisclaimers.length));
640
+ i0.ɵɵproperty("ngIf", !ctx.disabled && !(ctx.visibleTags == null ? null : ctx.visibleTags.length));
472
641
  i0.ɵɵadvance(1);
473
- i0.ɵɵproperty("ngForOf", ctx.visibleDisclaimers);
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 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" }]
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"]}