primeng 16.6.0 → 16.7.1
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/animate/animate.d.ts +3 -2
- package/animateonscroll/animateonscroll.d.ts +73 -0
- package/animateonscroll/index.d.ts +5 -0
- package/animateonscroll/public_api.d.ts +1 -0
- package/api/primengconfig.d.ts +1 -0
- package/autocomplete/autocomplete.d.ts +177 -54
- package/autocomplete/autocomplete.interface.d.ts +30 -0
- package/cascadeselect/cascadeselect.d.ts +188 -68
- package/cascadeselect/cascadeselect.interface.d.ts +19 -0
- package/checkbox/checkbox.d.ts +1 -4
- package/chips/chips.d.ts +21 -5
- package/colorpicker/colorpicker.d.ts +5 -5
- package/contextmenu/contextmenu.d.ts +1 -0
- package/dialog/dialog.d.ts +1 -2
- package/dom/domhandler.d.ts +4 -1
- package/dropdown/dropdown.d.ts +115 -37
- package/esm2022/accordion/accordion.mjs +11 -7
- package/esm2022/animate/animate.mjs +4 -1
- package/esm2022/animateonscroll/animateonscroll.mjs +185 -0
- package/esm2022/animateonscroll/primeng-animateonscroll.mjs +5 -0
- package/esm2022/animateonscroll/public_api.mjs +2 -0
- package/esm2022/api/primengconfig.mjs +2 -1
- package/esm2022/autocomplete/autocomplete.interface.mjs +1 -1
- package/esm2022/autocomplete/autocomplete.mjs +893 -617
- package/esm2022/carousel/carousel.mjs +5 -1
- package/esm2022/cascadeselect/cascadeselect.interface.mjs +1 -1
- package/esm2022/cascadeselect/cascadeselect.mjs +921 -482
- package/esm2022/checkbox/checkbox.mjs +90 -73
- package/esm2022/chips/chips.mjs +197 -53
- package/esm2022/colorpicker/colorpicker.mjs +56 -37
- package/esm2022/contextmenu/contextmenu.mjs +10 -1
- package/esm2022/dialog/dialog.mjs +6 -11
- package/esm2022/dom/domhandler.mjs +26 -8
- package/esm2022/dropdown/dropdown.mjs +711 -587
- package/esm2022/inputmask/inputmask.mjs +22 -9
- package/esm2022/inputnumber/inputnumber.mjs +142 -83
- package/esm2022/inputswitch/inputswitch.mjs +55 -49
- package/esm2022/knob/knob.mjs +92 -5
- package/esm2022/listbox/listbox.interface.mjs +1 -1
- package/esm2022/listbox/listbox.mjs +998 -455
- package/esm2022/multiselect/multiselect.mjs +1024 -604
- package/esm2022/overlaypanel/overlaypanel.mjs +2 -2
- package/esm2022/paginator/paginator.mjs +2 -2
- package/esm2022/password/password.mjs +29 -28
- package/esm2022/radiobutton/radiobutton.mjs +46 -33
- package/esm2022/rating/rating.mjs +172 -80
- package/esm2022/selectbutton/selectbutton.mjs +105 -33
- package/esm2022/slider/slider.mjs +151 -66
- package/esm2022/table/table.mjs +3 -3
- package/esm2022/togglebutton/togglebutton.mjs +47 -10
- package/esm2022/treetable/treetable.mjs +21 -25
- package/esm2022/tristatecheckbox/tristatecheckbox.mjs +53 -35
- package/fesm2022/primeng-accordion.mjs +10 -6
- package/fesm2022/primeng-accordion.mjs.map +1 -1
- package/fesm2022/primeng-animate.mjs +3 -0
- package/fesm2022/primeng-animate.mjs.map +1 -1
- package/fesm2022/primeng-animateonscroll.mjs +190 -0
- package/fesm2022/primeng-animateonscroll.mjs.map +1 -0
- package/fesm2022/primeng-api.mjs +1 -0
- package/fesm2022/primeng-api.mjs.map +1 -1
- package/fesm2022/primeng-autocomplete.mjs +893 -617
- package/fesm2022/primeng-autocomplete.mjs.map +1 -1
- package/fesm2022/primeng-carousel.mjs +4 -0
- package/fesm2022/primeng-carousel.mjs.map +1 -1
- package/fesm2022/primeng-cascadeselect.mjs +920 -481
- package/fesm2022/primeng-cascadeselect.mjs.map +1 -1
- package/fesm2022/primeng-checkbox.mjs +89 -72
- package/fesm2022/primeng-checkbox.mjs.map +1 -1
- package/fesm2022/primeng-chips.mjs +195 -51
- package/fesm2022/primeng-chips.mjs.map +1 -1
- package/fesm2022/primeng-colorpicker.mjs +55 -36
- package/fesm2022/primeng-colorpicker.mjs.map +1 -1
- package/fesm2022/primeng-contextmenu.mjs +9 -0
- package/fesm2022/primeng-contextmenu.mjs.map +1 -1
- package/fesm2022/primeng-dialog.mjs +5 -10
- package/fesm2022/primeng-dialog.mjs.map +1 -1
- package/fesm2022/primeng-dom.mjs +25 -7
- package/fesm2022/primeng-dom.mjs.map +1 -1
- package/fesm2022/primeng-dropdown.mjs +710 -586
- package/fesm2022/primeng-dropdown.mjs.map +1 -1
- package/fesm2022/primeng-inputmask.mjs +20 -7
- package/fesm2022/primeng-inputmask.mjs.map +1 -1
- package/fesm2022/primeng-inputnumber.mjs +140 -81
- package/fesm2022/primeng-inputnumber.mjs.map +1 -1
- package/fesm2022/primeng-inputswitch.mjs +55 -49
- package/fesm2022/primeng-inputswitch.mjs.map +1 -1
- package/fesm2022/primeng-knob.mjs +92 -5
- package/fesm2022/primeng-knob.mjs.map +1 -1
- package/fesm2022/primeng-listbox.mjs +997 -454
- package/fesm2022/primeng-listbox.mjs.map +1 -1
- package/fesm2022/primeng-multiselect.mjs +1023 -603
- package/fesm2022/primeng-multiselect.mjs.map +1 -1
- package/fesm2022/primeng-overlaypanel.mjs +1 -1
- package/fesm2022/primeng-overlaypanel.mjs.map +1 -1
- package/fesm2022/primeng-paginator.mjs +1 -1
- package/fesm2022/primeng-paginator.mjs.map +1 -1
- package/fesm2022/primeng-password.mjs +27 -26
- package/fesm2022/primeng-password.mjs.map +1 -1
- package/fesm2022/primeng-radiobutton.mjs +46 -33
- package/fesm2022/primeng-radiobutton.mjs.map +1 -1
- package/fesm2022/primeng-rating.mjs +171 -79
- package/fesm2022/primeng-rating.mjs.map +1 -1
- package/fesm2022/primeng-selectbutton.mjs +104 -32
- package/fesm2022/primeng-selectbutton.mjs.map +1 -1
- package/fesm2022/primeng-slider.mjs +150 -65
- package/fesm2022/primeng-slider.mjs.map +1 -1
- package/fesm2022/primeng-table.mjs +2 -2
- package/fesm2022/primeng-table.mjs.map +1 -1
- package/fesm2022/primeng-togglebutton.mjs +46 -9
- package/fesm2022/primeng-togglebutton.mjs.map +1 -1
- package/fesm2022/primeng-treetable.mjs +23 -27
- package/fesm2022/primeng-treetable.mjs.map +1 -1
- package/fesm2022/primeng-tristatecheckbox.mjs +53 -35
- package/fesm2022/primeng-tristatecheckbox.mjs.map +1 -1
- package/inputmask/inputmask.d.ts +6 -1
- package/inputnumber/inputnumber.d.ts +6 -1
- package/inputswitch/inputswitch.d.ts +6 -9
- package/knob/knob.d.ts +20 -3
- package/listbox/listbox.d.ts +208 -39
- package/listbox/listbox.interface.d.ts +16 -1
- package/multiselect/multiselect.d.ts +171 -60
- package/package.json +138 -132
- package/password/password.d.ts +3 -4
- package/radiobutton/radiobutton.d.ts +1 -2
- package/rating/rating.d.ts +29 -7
- package/resources/components/dropdown/dropdown.css +16 -2
- package/resources/themes/arya-blue/theme.css +106 -84
- package/resources/themes/arya-green/theme.css +106 -84
- package/resources/themes/arya-orange/theme.css +106 -84
- package/resources/themes/arya-purple/theme.css +106 -84
- package/resources/themes/bootstrap4-dark-blue/theme.css +110 -88
- package/resources/themes/bootstrap4-dark-purple/theme.css +110 -88
- package/resources/themes/bootstrap4-light-blue/theme.css +110 -88
- package/resources/themes/bootstrap4-light-purple/theme.css +110 -88
- package/resources/themes/fluent-light/theme.css +103 -81
- package/resources/themes/lara-dark-blue/theme.css +106 -84
- package/resources/themes/lara-dark-indigo/theme.css +106 -84
- package/resources/themes/lara-dark-purple/theme.css +106 -84
- package/resources/themes/lara-dark-teal/theme.css +106 -84
- package/resources/themes/lara-light-blue/theme.css +109 -87
- package/resources/themes/lara-light-indigo/theme.css +109 -87
- package/resources/themes/lara-light-purple/theme.css +109 -87
- package/resources/themes/lara-light-teal/theme.css +109 -87
- package/resources/themes/luna-amber/theme.css +110 -88
- package/resources/themes/luna-blue/theme.css +110 -88
- package/resources/themes/luna-green/theme.css +110 -88
- package/resources/themes/luna-pink/theme.css +110 -88
- package/resources/themes/md-dark-deeppurple/theme.css +117 -95
- package/resources/themes/md-dark-indigo/theme.css +117 -95
- package/resources/themes/md-light-deeppurple/theme.css +117 -95
- package/resources/themes/md-light-indigo/theme.css +117 -95
- package/resources/themes/mdc-dark-deeppurple/theme.css +117 -95
- package/resources/themes/mdc-dark-indigo/theme.css +117 -95
- package/resources/themes/mdc-light-deeppurple/theme.css +117 -95
- package/resources/themes/mdc-light-indigo/theme.css +117 -95
- package/resources/themes/mira/theme.css +107 -85
- package/resources/themes/nano/theme.css +109 -87
- package/resources/themes/nova/theme.css +110 -88
- package/resources/themes/nova-accent/theme.css +109 -87
- package/resources/themes/nova-alt/theme.css +110 -88
- package/resources/themes/rhea/theme.css +109 -87
- package/resources/themes/saga-blue/theme.css +106 -84
- package/resources/themes/saga-green/theme.css +106 -84
- package/resources/themes/saga-orange/theme.css +106 -84
- package/resources/themes/saga-purple/theme.css +106 -84
- package/resources/themes/soho-dark/theme.css +109 -87
- package/resources/themes/soho-light/theme.css +109 -87
- package/resources/themes/tailwind-light/theme.css +110 -88
- package/resources/themes/vela-blue/theme.css +106 -84
- package/resources/themes/vela-green/theme.css +106 -84
- package/resources/themes/vela-orange/theme.css +106 -84
- package/resources/themes/vela-purple/theme.css +106 -84
- package/resources/themes/viva-dark/theme.css +109 -87
- package/resources/themes/viva-light/theme.css +109 -87
- package/selectbutton/selectbutton.d.ts +15 -3
- package/slider/slider.d.ts +12 -6
- package/togglebutton/togglebutton.d.ts +7 -1
- package/treetable/treetable.d.ts +3 -4
- package/tristatecheckbox/tristatecheckbox.d.ts +8 -4
@@ -1,5 +1,5 @@
|
|
1
1
|
import { CommonModule } from '@angular/common';
|
2
|
-
import { ChangeDetectionStrategy, Component, ContentChild, ContentChildren, EventEmitter, forwardRef, Input, NgModule, Output, ViewChild, ViewEncapsulation } from '@angular/core';
|
2
|
+
import { ChangeDetectionStrategy, Component, computed, ContentChild, ContentChildren, EventEmitter, forwardRef, Input, NgModule, Output, signal, ViewChild, ViewEncapsulation } from '@angular/core';
|
3
3
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
4
4
|
import { Footer, Header, PrimeTemplate, SharedModule, TranslationKeys } from 'primeng/api';
|
5
5
|
import { DomHandler } from 'primeng/dom';
|
@@ -7,7 +7,7 @@ import { OverlayModule } from 'primeng/overlay';
|
|
7
7
|
import { RippleModule } from 'primeng/ripple';
|
8
8
|
import { ScrollerModule } from 'primeng/scroller';
|
9
9
|
import { TooltipModule } from 'primeng/tooltip';
|
10
|
-
import { ObjectUtils } from 'primeng/utils';
|
10
|
+
import { ObjectUtils, UniqueComponentId } from 'primeng/utils';
|
11
11
|
import { CheckIcon } from 'primeng/icons/check';
|
12
12
|
import { SearchIcon } from 'primeng/icons/search';
|
13
13
|
import { TimesCircleIcon } from 'primeng/icons/timescircle';
|
@@ -26,15 +26,19 @@ export const MULTISELECT_VALUE_ACCESSOR = {
|
|
26
26
|
multi: true
|
27
27
|
};
|
28
28
|
class MultiSelectItem {
|
29
|
+
id;
|
29
30
|
option;
|
30
31
|
selected;
|
31
32
|
label;
|
32
33
|
disabled;
|
33
34
|
itemSize;
|
35
|
+
focused;
|
36
|
+
ariaPosInset;
|
37
|
+
ariaSetSize;
|
34
38
|
template;
|
35
39
|
checkIconTemplate;
|
36
40
|
onClick = new EventEmitter();
|
37
|
-
|
41
|
+
onMouseEnter = new EventEmitter();
|
38
42
|
onOptionClick(event) {
|
39
43
|
this.onClick.emit({
|
40
44
|
originalEvent: event,
|
@@ -42,35 +46,42 @@ class MultiSelectItem {
|
|
42
46
|
selected: this.selected
|
43
47
|
});
|
44
48
|
}
|
45
|
-
|
46
|
-
this.
|
49
|
+
onOptionMouseEnter(event) {
|
50
|
+
this.onMouseEnter.emit({
|
47
51
|
originalEvent: event,
|
48
|
-
option: this.option
|
52
|
+
option: this.option,
|
53
|
+
selected: this.selected
|
49
54
|
});
|
50
55
|
}
|
51
56
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: MultiSelectItem, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
52
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: MultiSelectItem, selector: "p-multiSelectItem", inputs: { option: "option", selected: "selected", label: "label", disabled: "disabled", itemSize: "itemSize", template: "template", checkIconTemplate: "checkIconTemplate" }, outputs: { onClick: "onClick",
|
57
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: MultiSelectItem, selector: "p-multiSelectItem", inputs: { id: "id", option: "option", selected: "selected", label: "label", disabled: "disabled", itemSize: "itemSize", focused: "focused", ariaPosInset: "ariaPosInset", ariaSetSize: "ariaSetSize", template: "template", checkIconTemplate: "checkIconTemplate" }, outputs: { onClick: "onClick", onMouseEnter: "onMouseEnter" }, host: { classAttribute: "p-element" }, ngImport: i0, template: `
|
53
58
|
<li
|
59
|
+
pRipple
|
60
|
+
[ngStyle]="{ height: itemSize + 'px' }"
|
54
61
|
class="p-multiselect-item"
|
55
|
-
|
56
|
-
|
62
|
+
[ngClass]="{ 'p-multiselect-item': true, 'p-highlight': selected, 'p-disabled': disabled, 'p-focus': focused }"
|
63
|
+
[id]="id"
|
57
64
|
[attr.aria-label]="label"
|
58
|
-
[attr.
|
59
|
-
[
|
60
|
-
[
|
61
|
-
|
65
|
+
[attr.aria-setsize]="ariaSetSize"
|
66
|
+
[attr.aria-posinset]="ariaPosInset"
|
67
|
+
[attr.aria-selected]="selected"
|
68
|
+
[attr.data-p-focused]="focused"
|
69
|
+
[attr.data-p-highlight]="selected"
|
70
|
+
[attr.data-p-disabled]="disabled"
|
71
|
+
(click)="onOptionClick($event)"
|
72
|
+
(mouseenter)="onOptionMouseEnter($event)"
|
62
73
|
>
|
63
74
|
<div class="p-checkbox p-component">
|
64
|
-
<div class="p-checkbox-box" [ngClass]="{ 'p-highlight': selected }">
|
75
|
+
<div class="p-checkbox-box" [ngClass]="{ 'p-highlight': selected }" [attr.aria-checked]="selected">
|
65
76
|
<ng-container *ngIf="selected">
|
66
|
-
<CheckIcon *ngIf="!checkIconTemplate" [styleClass]="'p-checkbox-icon'" />
|
67
|
-
<span *ngIf="checkIconTemplate" class="p-checkbox-icon">
|
77
|
+
<CheckIcon *ngIf="!checkIconTemplate" [styleClass]="'p-checkbox-icon'" [attr.aria-hidden]="true" />
|
78
|
+
<span *ngIf="checkIconTemplate" class="p-checkbox-icon" [attr.aria-hidden]="true">
|
68
79
|
<ng-template *ngTemplateOutlet="checkIconTemplate"></ng-template>
|
69
80
|
</span>
|
70
81
|
</ng-container>
|
71
82
|
</div>
|
72
83
|
</div>
|
73
|
-
<span *ngIf="!template">{{ label }}</span>
|
84
|
+
<span *ngIf="!template">{{ label ?? 'empty' }}</span>
|
74
85
|
<ng-container *ngTemplateOutlet="template; context: { $implicit: option }"></ng-container>
|
75
86
|
</li>
|
76
87
|
`, isInline: true, dependencies: [{ kind: "directive", type: i0.forwardRef(function () { return i1.NgClass; }), selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgTemplateOutlet; }), selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgStyle; }), selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.Ripple; }), selector: "[pRipple]" }, { kind: "component", type: i0.forwardRef(function () { return CheckIcon; }), selector: "CheckIcon" }], encapsulation: i0.ViewEncapsulation.None });
|
@@ -82,26 +93,32 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
|
|
82
93
|
selector: 'p-multiSelectItem',
|
83
94
|
template: `
|
84
95
|
<li
|
96
|
+
pRipple
|
97
|
+
[ngStyle]="{ height: itemSize + 'px' }"
|
85
98
|
class="p-multiselect-item"
|
86
|
-
|
87
|
-
|
99
|
+
[ngClass]="{ 'p-multiselect-item': true, 'p-highlight': selected, 'p-disabled': disabled, 'p-focus': focused }"
|
100
|
+
[id]="id"
|
88
101
|
[attr.aria-label]="label"
|
89
|
-
[attr.
|
90
|
-
[
|
91
|
-
[
|
92
|
-
|
102
|
+
[attr.aria-setsize]="ariaSetSize"
|
103
|
+
[attr.aria-posinset]="ariaPosInset"
|
104
|
+
[attr.aria-selected]="selected"
|
105
|
+
[attr.data-p-focused]="focused"
|
106
|
+
[attr.data-p-highlight]="selected"
|
107
|
+
[attr.data-p-disabled]="disabled"
|
108
|
+
(click)="onOptionClick($event)"
|
109
|
+
(mouseenter)="onOptionMouseEnter($event)"
|
93
110
|
>
|
94
111
|
<div class="p-checkbox p-component">
|
95
|
-
<div class="p-checkbox-box" [ngClass]="{ 'p-highlight': selected }">
|
112
|
+
<div class="p-checkbox-box" [ngClass]="{ 'p-highlight': selected }" [attr.aria-checked]="selected">
|
96
113
|
<ng-container *ngIf="selected">
|
97
|
-
<CheckIcon *ngIf="!checkIconTemplate" [styleClass]="'p-checkbox-icon'" />
|
98
|
-
<span *ngIf="checkIconTemplate" class="p-checkbox-icon">
|
114
|
+
<CheckIcon *ngIf="!checkIconTemplate" [styleClass]="'p-checkbox-icon'" [attr.aria-hidden]="true" />
|
115
|
+
<span *ngIf="checkIconTemplate" class="p-checkbox-icon" [attr.aria-hidden]="true">
|
99
116
|
<ng-template *ngTemplateOutlet="checkIconTemplate"></ng-template>
|
100
117
|
</span>
|
101
118
|
</ng-container>
|
102
119
|
</div>
|
103
120
|
</div>
|
104
|
-
<span *ngIf="!template">{{ label }}</span>
|
121
|
+
<span *ngIf="!template">{{ label ?? 'empty' }}</span>
|
105
122
|
<ng-container *ngTemplateOutlet="template; context: { $implicit: option }"></ng-container>
|
106
123
|
</li>
|
107
124
|
`,
|
@@ -110,7 +127,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
|
|
110
127
|
class: 'p-element'
|
111
128
|
}
|
112
129
|
}]
|
113
|
-
}], propDecorators: {
|
130
|
+
}], propDecorators: { id: [{
|
131
|
+
type: Input
|
132
|
+
}], option: [{
|
114
133
|
type: Input
|
115
134
|
}], selected: [{
|
116
135
|
type: Input
|
@@ -120,13 +139,19 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
|
|
120
139
|
type: Input
|
121
140
|
}], itemSize: [{
|
122
141
|
type: Input
|
142
|
+
}], focused: [{
|
143
|
+
type: Input
|
144
|
+
}], ariaPosInset: [{
|
145
|
+
type: Input
|
146
|
+
}], ariaSetSize: [{
|
147
|
+
type: Input
|
123
148
|
}], template: [{
|
124
149
|
type: Input
|
125
150
|
}], checkIconTemplate: [{
|
126
151
|
type: Input
|
127
152
|
}], onClick: [{
|
128
153
|
type: Output
|
129
|
-
}],
|
154
|
+
}], onMouseEnter: [{
|
130
155
|
type: Output
|
131
156
|
}] } });
|
132
157
|
/**
|
@@ -141,6 +166,16 @@ class MultiSelect {
|
|
141
166
|
filterService;
|
142
167
|
config;
|
143
168
|
overlayService;
|
169
|
+
/**
|
170
|
+
* Unique identifier of the component
|
171
|
+
* @group Props
|
172
|
+
*/
|
173
|
+
id;
|
174
|
+
/**
|
175
|
+
* Defines a string that labels the input for accessibility.
|
176
|
+
* @group Props
|
177
|
+
*/
|
178
|
+
ariaLabel;
|
144
179
|
/**
|
145
180
|
* Inline style of the element.
|
146
181
|
* @group Props
|
@@ -205,7 +240,7 @@ class MultiSelect {
|
|
205
240
|
* Index of the element in tabbing order.
|
206
241
|
* @group Props
|
207
242
|
*/
|
208
|
-
tabindex;
|
243
|
+
tabindex = 0;
|
209
244
|
/**
|
210
245
|
* Target element to attach the overlay, valid values are "body" or a local ng-template variable of another element (note: use binding with brackets for template variables, e.g. [appendTo]="mydiv" for a div element having #mydiv as variable name).
|
211
246
|
* @group Props
|
@@ -221,11 +256,6 @@ class MultiSelect {
|
|
221
256
|
* @group Props
|
222
257
|
*/
|
223
258
|
name;
|
224
|
-
/**
|
225
|
-
* Label of the input for accessibility.
|
226
|
-
* @group Props
|
227
|
-
*/
|
228
|
-
label;
|
229
259
|
/**
|
230
260
|
* Establishes relationships between the component and label(s) where its value should be one or more element IDs.
|
231
261
|
* @group Props
|
@@ -241,11 +271,16 @@ class MultiSelect {
|
|
241
271
|
* @group Props
|
242
272
|
*/
|
243
273
|
maxSelectedLabels = 3;
|
274
|
+
/**
|
275
|
+
* Decides how many selected item labels to show at most.
|
276
|
+
* @group Props
|
277
|
+
*/
|
278
|
+
selectionLimit;
|
244
279
|
/**
|
245
280
|
* Label to display after exceeding max selected labels e.g. ({0} items selected), defaults "ellipsis" keyword to indicate a text-overflow.
|
246
281
|
* @group Props
|
247
282
|
*/
|
248
|
-
selectedItemsLabel = '
|
283
|
+
selectedItemsLabel = '{0} items selected';
|
249
284
|
/**
|
250
285
|
* Whether to show the checkbox at header to toggle all items at once.
|
251
286
|
* @group Props
|
@@ -290,7 +325,7 @@ class MultiSelect {
|
|
290
325
|
* Name of the label field of an option group.
|
291
326
|
* @group Props
|
292
327
|
*/
|
293
|
-
optionGroupLabel;
|
328
|
+
optionGroupLabel = 'label';
|
294
329
|
/**
|
295
330
|
* Name of the options field of an option group.
|
296
331
|
* @group Props
|
@@ -380,7 +415,7 @@ class MultiSelect {
|
|
380
415
|
* Defines the autocomplete is active.
|
381
416
|
* @group Props
|
382
417
|
*/
|
383
|
-
autocomplete = '
|
418
|
+
autocomplete = 'off';
|
384
419
|
/**
|
385
420
|
* When enabled, a clear icon is displayed to clear the value.
|
386
421
|
* @group Props
|
@@ -441,7 +476,7 @@ class MultiSelect {
|
|
441
476
|
*/
|
442
477
|
set defaultLabel(val) {
|
443
478
|
this._defaultLabel = val;
|
444
|
-
|
479
|
+
console.warn('defaultLabel property is deprecated since 16.6.0, use placeholder instead');
|
445
480
|
}
|
446
481
|
get defaultLabel() {
|
447
482
|
return this._defaultLabel;
|
@@ -452,7 +487,6 @@ class MultiSelect {
|
|
452
487
|
*/
|
453
488
|
set placeholder(val) {
|
454
489
|
this._placeholder = val;
|
455
|
-
this.updateLabel();
|
456
490
|
}
|
457
491
|
get placeholder() {
|
458
492
|
return this._placeholder;
|
@@ -462,22 +496,21 @@ class MultiSelect {
|
|
462
496
|
* @group Props
|
463
497
|
*/
|
464
498
|
get options() {
|
465
|
-
|
499
|
+
const options = this._options();
|
500
|
+
return options;
|
466
501
|
}
|
467
502
|
set options(val) {
|
468
|
-
this._options
|
469
|
-
this.updateLabel();
|
503
|
+
this._options.set(val);
|
470
504
|
}
|
471
505
|
/**
|
472
506
|
* When specified, filter displays with this value.
|
473
507
|
* @group Props
|
474
508
|
*/
|
475
509
|
get filterValue() {
|
476
|
-
return this._filterValue;
|
510
|
+
return this._filterValue();
|
477
511
|
}
|
478
512
|
set filterValue(val) {
|
479
|
-
this._filterValue
|
480
|
-
this.activateFilter();
|
513
|
+
this._filterValue.set(val);
|
481
514
|
}
|
482
515
|
/**
|
483
516
|
* Item size of item to be virtual scrolled.
|
@@ -492,25 +525,25 @@ class MultiSelect {
|
|
492
525
|
console.warn('The itemSize property is deprecated, use virtualScrollItemSize property instead.');
|
493
526
|
}
|
494
527
|
/**
|
495
|
-
*
|
528
|
+
* Fields used when filtering the options, defaults to optionLabel.
|
496
529
|
* @group Props
|
497
530
|
*/
|
498
|
-
|
499
|
-
|
500
|
-
|
501
|
-
|
502
|
-
|
503
|
-
|
504
|
-
|
505
|
-
|
506
|
-
|
507
|
-
|
508
|
-
|
509
|
-
|
510
|
-
|
511
|
-
|
512
|
-
|
513
|
-
|
531
|
+
focusOnHover = false;
|
532
|
+
/**
|
533
|
+
* Fields used when filtering the options, defaults to optionLabel.
|
534
|
+
* @group Props
|
535
|
+
*/
|
536
|
+
filterFields;
|
537
|
+
/**
|
538
|
+
* Determines if the option will be selected on focus.
|
539
|
+
* @group Props
|
540
|
+
*/
|
541
|
+
selectOnFocus = false;
|
542
|
+
/**
|
543
|
+
* Whether to focus on the first visible or selected element when the overlay panel is shown.
|
544
|
+
* @group Props
|
545
|
+
*/
|
546
|
+
autoOptionFocus = true;
|
514
547
|
/**
|
515
548
|
* Callback to invoke when value changes.
|
516
549
|
* @param {MultiSelectChangeEvent} event - Custom change event.
|
@@ -568,6 +601,20 @@ class MultiSelect {
|
|
568
601
|
* @group Emits
|
569
602
|
*/
|
570
603
|
onRemove = new EventEmitter();
|
604
|
+
containerViewChild;
|
605
|
+
overlayViewChild;
|
606
|
+
filterInputChild;
|
607
|
+
focusInputViewChild;
|
608
|
+
itemsViewChild;
|
609
|
+
scroller;
|
610
|
+
lastHiddenFocusableElementOnOverlay;
|
611
|
+
firstHiddenFocusableElementOnOverlay;
|
612
|
+
headerCheckboxViewChild;
|
613
|
+
footerFacet;
|
614
|
+
headerFacet;
|
615
|
+
templates;
|
616
|
+
searchValue;
|
617
|
+
searchTimeout;
|
571
618
|
_autoZIndex;
|
572
619
|
_baseZIndex;
|
573
620
|
_showTransitionOptions;
|
@@ -582,8 +629,6 @@ class MultiSelect {
|
|
582
629
|
onModelTouched = () => { };
|
583
630
|
valuesAsString;
|
584
631
|
focus;
|
585
|
-
filled;
|
586
|
-
_filterValue;
|
587
632
|
filtered;
|
588
633
|
itemTemplate;
|
589
634
|
groupTemplate;
|
@@ -602,10 +647,112 @@ class MultiSelect {
|
|
602
647
|
dropdownIconTemplate;
|
603
648
|
headerCheckboxFocus;
|
604
649
|
filterOptions;
|
605
|
-
_options;
|
606
650
|
maxSelectionLimitReached;
|
607
651
|
preventModelTouched;
|
608
652
|
preventDocumentDefault;
|
653
|
+
focused = false;
|
654
|
+
itemsWrapper;
|
655
|
+
modelValue = signal(null);
|
656
|
+
_filterValue = signal(null);
|
657
|
+
_options = signal(null);
|
658
|
+
startRangeIndex = signal(-1);
|
659
|
+
focusedOptionIndex = signal(-1);
|
660
|
+
get containerClass() {
|
661
|
+
return {
|
662
|
+
'p-multiselect p-component p-inputwrapper': true,
|
663
|
+
'p-disabled': this.disabled,
|
664
|
+
'p-multiselect-clearable': this.showClear && !this.disabled,
|
665
|
+
'p-multiselect-chip': this.display === 'chip',
|
666
|
+
'p-focus': this.focused,
|
667
|
+
'p-inputwrapper-filled': ObjectUtils.isNotEmpty(this.modelValue()),
|
668
|
+
'p-inputwrapper-focus': this.focused || this.overlayVisible
|
669
|
+
};
|
670
|
+
}
|
671
|
+
get inputClass() {
|
672
|
+
return {
|
673
|
+
'p-multiselect-label p-inputtext': true,
|
674
|
+
'p-placeholder': (this.placeholder || this.defaultLabel) && (this.label() === this.placeholder || this.label() === this.defaultLabel),
|
675
|
+
'p-multiselect-label-empty': !this.selectedItemsTemplate && (this.label() === 'p-emptylabel' || this.label().length === 0)
|
676
|
+
};
|
677
|
+
}
|
678
|
+
get panelClass() {
|
679
|
+
return {
|
680
|
+
'p-multiselect-panel p-component': true,
|
681
|
+
'p-input-filled': this.config.inputStyle === 'filled',
|
682
|
+
'p-ripple-disabled': this.config.ripple === false
|
683
|
+
};
|
684
|
+
}
|
685
|
+
get labelClass() {
|
686
|
+
return {
|
687
|
+
'p-multiselect-label': true,
|
688
|
+
'p-placeholder': this.label() === this.placeholder || this.label() === this.defaultLabel,
|
689
|
+
'p-multiselect-label-empty': !this.placeholder && !this.defaultLabel && (!this.modelValue() || this.modelValue().length === 0)
|
690
|
+
};
|
691
|
+
}
|
692
|
+
get emptyMessageLabel() {
|
693
|
+
return this.emptyMessage || this.config.getTranslation(TranslationKeys.EMPTY_MESSAGE);
|
694
|
+
}
|
695
|
+
get emptyFilterMessageLabel() {
|
696
|
+
return this.emptyFilterMessage || this.config.getTranslation(TranslationKeys.EMPTY_FILTER_MESSAGE);
|
697
|
+
}
|
698
|
+
get filled() {
|
699
|
+
if (typeof this.modelValue() === 'string')
|
700
|
+
return !!this.modelValue();
|
701
|
+
return this.modelValue() || this.modelValue() != null || this.modelValue() != undefined;
|
702
|
+
}
|
703
|
+
get isVisibleClearIcon() {
|
704
|
+
return this.modelValue() != null && this.modelValue() !== '' && this.showClear && !this.disabled;
|
705
|
+
}
|
706
|
+
get toggleAllAriaLabel() {
|
707
|
+
return this.config.translation.aria ? this.config.translation.aria[this.allSelected() ? 'selectAll' : 'unselectAll'] : undefined;
|
708
|
+
}
|
709
|
+
get closeAriaLabel() {
|
710
|
+
return this.config.translation.aria ? this.config.translation.aria.close : undefined;
|
711
|
+
}
|
712
|
+
visibleOptions = computed(() => {
|
713
|
+
const options = this.group ? this.flatOptions(this.options) : this.options || [];
|
714
|
+
if (this._filterValue()) {
|
715
|
+
const filteredOptions = this.filterService.filter(options, this.searchFields(), this._filterValue(), this.filterMatchMode, this.filterLocale);
|
716
|
+
if (this.group) {
|
717
|
+
const optionGroups = this.options || [];
|
718
|
+
const filtered = [];
|
719
|
+
optionGroups.forEach((group) => {
|
720
|
+
const groupChildren = this.getOptionGroupChildren(group);
|
721
|
+
const filteredItems = groupChildren.filter((item) => filteredOptions.includes(item));
|
722
|
+
if (filteredItems.length > 0)
|
723
|
+
filtered.push({ ...group, [typeof this.optionGroupChildren === 'string' ? this.optionGroupChildren : 'items']: [...filteredItems] });
|
724
|
+
});
|
725
|
+
return this.flatOptions(filtered);
|
726
|
+
}
|
727
|
+
return filteredOptions;
|
728
|
+
}
|
729
|
+
return options;
|
730
|
+
});
|
731
|
+
label = computed(() => {
|
732
|
+
let label;
|
733
|
+
const modelValue = this.modelValue();
|
734
|
+
if (modelValue && modelValue.length) {
|
735
|
+
if (ObjectUtils.isNotEmpty(this.maxSelectedLabels) && modelValue.length > this.maxSelectedLabels) {
|
736
|
+
return this.getSelectedItemsLabel();
|
737
|
+
}
|
738
|
+
else {
|
739
|
+
label = '';
|
740
|
+
for (let i = 0; i < modelValue.length; i++) {
|
741
|
+
if (i !== 0) {
|
742
|
+
label += ', ';
|
743
|
+
}
|
744
|
+
label += this.getLabelByValue(modelValue[i]);
|
745
|
+
}
|
746
|
+
}
|
747
|
+
}
|
748
|
+
else {
|
749
|
+
label = this.placeholder || this.defaultLabel || '';
|
750
|
+
}
|
751
|
+
return label;
|
752
|
+
});
|
753
|
+
chipSelectedItems = computed(() => {
|
754
|
+
return ObjectUtils.isNotEmpty(this.maxSelectedLabels) && this.modelValue() && this.modelValue().length > this.maxSelectedLabels ? this.modelValue().slice(0, this.maxSelectedLabels) : this.modelValue();
|
755
|
+
});
|
609
756
|
constructor(el, renderer, cd, zone, filterService, config, overlayService) {
|
610
757
|
this.el = el;
|
611
758
|
this.renderer = renderer;
|
@@ -616,7 +763,8 @@ class MultiSelect {
|
|
616
763
|
this.overlayService = overlayService;
|
617
764
|
}
|
618
765
|
ngOnInit() {
|
619
|
-
this.
|
766
|
+
this.id = this.id || UniqueComponentId();
|
767
|
+
this.autoUpdateModel();
|
620
768
|
if (this.filterBy) {
|
621
769
|
this.filterOptions = {
|
622
770
|
filter: (value) => this.onFilterInputChange(value),
|
@@ -693,6 +841,154 @@ class MultiSelect {
|
|
693
841
|
this.filtered = false;
|
694
842
|
}
|
695
843
|
}
|
844
|
+
flatOptions(options) {
|
845
|
+
return (options || []).reduce((result, option, index) => {
|
846
|
+
result.push({ optionGroup: option, group: true, index });
|
847
|
+
const optionGroupChildren = this.getOptionGroupChildren(option);
|
848
|
+
optionGroupChildren && optionGroupChildren.forEach((o) => result.push(o));
|
849
|
+
return result;
|
850
|
+
}, []);
|
851
|
+
}
|
852
|
+
autoUpdateModel() {
|
853
|
+
if (this.selectOnFocus && this.autoOptionFocus && !this.hasSelectedOption()) {
|
854
|
+
this.focusedOptionIndex.set(this.findFirstFocusedOptionIndex());
|
855
|
+
const value = this.getOptionValue(this.visibleOptions()[this.focusedOptionIndex()]);
|
856
|
+
this.onOptionSelect({ originalEvent: null, option: [value] });
|
857
|
+
}
|
858
|
+
}
|
859
|
+
updateModel(value, event) {
|
860
|
+
this.value = value;
|
861
|
+
this.onModelChange(value);
|
862
|
+
this.modelValue.set(value);
|
863
|
+
this.onChange.emit({
|
864
|
+
originalEvent: event,
|
865
|
+
value: value
|
866
|
+
});
|
867
|
+
}
|
868
|
+
onOptionSelect(event, isFocus = false, index = -1) {
|
869
|
+
const { originalEvent, option } = event;
|
870
|
+
if (this.disabled || this.isOptionDisabled(option)) {
|
871
|
+
return;
|
872
|
+
}
|
873
|
+
let selected = this.isSelected(option);
|
874
|
+
let value = null;
|
875
|
+
if (selected) {
|
876
|
+
value = this.modelValue().filter((val) => !ObjectUtils.equals(val, this.getOptionValue(option), this.equalityKey()));
|
877
|
+
}
|
878
|
+
else {
|
879
|
+
value = [...(this.modelValue() || []), this.getOptionValue(option)];
|
880
|
+
}
|
881
|
+
this.updateModel(value, originalEvent);
|
882
|
+
index !== -1 && this.focusedOptionIndex.set(index);
|
883
|
+
isFocus && DomHandler.focus(this.focusInputViewChild?.nativeElement);
|
884
|
+
}
|
885
|
+
onOptionSelectRange(event, start = -1, end = -1) {
|
886
|
+
start === -1 && (start = this.findNearestSelectedOptionIndex(end, true));
|
887
|
+
end === -1 && (end = this.findNearestSelectedOptionIndex(start));
|
888
|
+
if (start !== -1 && end !== -1) {
|
889
|
+
const rangeStart = Math.min(start, end);
|
890
|
+
const rangeEnd = Math.max(start, end);
|
891
|
+
const value = this.visibleOptions()
|
892
|
+
.slice(rangeStart, rangeEnd + 1)
|
893
|
+
.filter((option) => this.isValidOption(option))
|
894
|
+
.map((option) => this.getOptionValue(option));
|
895
|
+
this.updateModel(value, event);
|
896
|
+
}
|
897
|
+
}
|
898
|
+
searchFields() {
|
899
|
+
return this.filterFields || [this.optionLabel];
|
900
|
+
}
|
901
|
+
findNearestSelectedOptionIndex(index, firstCheckUp = false) {
|
902
|
+
let matchedOptionIndex = -1;
|
903
|
+
if (this.hasSelectedOption()) {
|
904
|
+
if (firstCheckUp) {
|
905
|
+
matchedOptionIndex = this.findPrevSelectedOptionIndex(index);
|
906
|
+
matchedOptionIndex = matchedOptionIndex === -1 ? this.findNextSelectedOptionIndex(index) : matchedOptionIndex;
|
907
|
+
}
|
908
|
+
else {
|
909
|
+
matchedOptionIndex = this.findNextSelectedOptionIndex(index);
|
910
|
+
matchedOptionIndex = matchedOptionIndex === -1 ? this.findPrevSelectedOptionIndex(index) : matchedOptionIndex;
|
911
|
+
}
|
912
|
+
}
|
913
|
+
return matchedOptionIndex > -1 ? matchedOptionIndex : index;
|
914
|
+
}
|
915
|
+
findPrevSelectedOptionIndex(index) {
|
916
|
+
const matchedOptionIndex = this.hasSelectedOption() && index > 0 ? ObjectUtils.findLastIndex(this.visibleOptions().slice(0, index), (option) => this.isValidSelectedOption(option)) : -1;
|
917
|
+
return matchedOptionIndex > -1 ? matchedOptionIndex : -1;
|
918
|
+
}
|
919
|
+
findFirstFocusedOptionIndex() {
|
920
|
+
const selectedIndex = this.findFirstSelectedOptionIndex();
|
921
|
+
return selectedIndex < 0 ? this.findFirstOptionIndex() : selectedIndex;
|
922
|
+
}
|
923
|
+
findFirstOptionIndex() {
|
924
|
+
return this.visibleOptions().findIndex((option) => this.isValidOption(option));
|
925
|
+
}
|
926
|
+
findFirstSelectedOptionIndex() {
|
927
|
+
return this.hasSelectedOption() ? this.visibleOptions().findIndex((option) => this.isValidSelectedOption(option)) : -1;
|
928
|
+
}
|
929
|
+
findNextSelectedOptionIndex(index) {
|
930
|
+
const matchedOptionIndex = this.hasSelectedOption() && index < this.visibleOptions().length - 1
|
931
|
+
? this.visibleOptions()
|
932
|
+
.slice(index + 1)
|
933
|
+
.findIndex((option) => this.isValidSelectedOption(option))
|
934
|
+
: -1;
|
935
|
+
return matchedOptionIndex > -1 ? matchedOptionIndex + index + 1 : -1;
|
936
|
+
}
|
937
|
+
equalityKey() {
|
938
|
+
return this.optionValue ? null : this.dataKey;
|
939
|
+
}
|
940
|
+
hasSelectedOption() {
|
941
|
+
return ObjectUtils.isNotEmpty(this.modelValue());
|
942
|
+
}
|
943
|
+
isValidSelectedOption(option) {
|
944
|
+
return this.isValidOption(option) && this.isSelected(option);
|
945
|
+
}
|
946
|
+
isOptionGroup(option) {
|
947
|
+
return (this.group || this.optionGroupLabel) && option.optionGroup && option.group;
|
948
|
+
}
|
949
|
+
isValidOption(option) {
|
950
|
+
return option && !(this.isOptionDisabled(option) || this.isOptionGroup(option));
|
951
|
+
}
|
952
|
+
isOptionDisabled(option) {
|
953
|
+
let disabled = this.optionDisabled ? ObjectUtils.resolveFieldData(option, this.optionDisabled) : option && option.disabled !== undefined ? option.disabled : false;
|
954
|
+
return disabled || (this.maxSelectionLimitReached && !this.isSelected(option));
|
955
|
+
}
|
956
|
+
isSelected(option) {
|
957
|
+
const optionValue = this.getOptionValue(option);
|
958
|
+
return (this.modelValue() || []).some((value) => ObjectUtils.equals(value, optionValue, this.equalityKey()));
|
959
|
+
}
|
960
|
+
isOptionMatched(option) {
|
961
|
+
return this.isValidOption(option) && this.getOptionLabel(option).toLocaleLowerCase(this.filterLocale).startsWith(this.searchValue.toLocaleLowerCase(this.filterLocale));
|
962
|
+
}
|
963
|
+
isEmpty() {
|
964
|
+
return !this._options() || (this._options() && this._options().length === 0);
|
965
|
+
}
|
966
|
+
getOptionIndex(index, scrollerOptions) {
|
967
|
+
return this.virtualScrollerDisabled ? index : scrollerOptions && scrollerOptions.getItemOptions(index)['index'];
|
968
|
+
}
|
969
|
+
getAriaPosInset(index) {
|
970
|
+
return ((this.optionGroupLabel
|
971
|
+
? index -
|
972
|
+
this.visibleOptions()
|
973
|
+
.slice(0, index)
|
974
|
+
.filter((option) => this.isOptionGroup(option)).length
|
975
|
+
: index) + 1);
|
976
|
+
}
|
977
|
+
get ariaSetSize() {
|
978
|
+
return this.visibleOptions().filter((option) => !this.isOptionGroup(option)).length;
|
979
|
+
}
|
980
|
+
getLabelByValue(value) {
|
981
|
+
const options = this.group ? this.flatOptions(this._options()) : this._options() || [];
|
982
|
+
const matchedOption = options.find((option) => !this.isOptionGroup(option) && ObjectUtils.equals(this.getOptionValue(option), value, this.equalityKey()));
|
983
|
+
return matchedOption ? this.getOptionLabel(matchedOption) : null;
|
984
|
+
}
|
985
|
+
getSelectedItemsLabel() {
|
986
|
+
let pattern = /{(.*?)}/;
|
987
|
+
if (pattern.test(this.selectedItemsLabel)) {
|
988
|
+
return this.selectedItemsLabel.replace(this.selectedItemsLabel.match(pattern)[0], this.modelValue().length + '');
|
989
|
+
}
|
990
|
+
return this.selectedItemsLabel;
|
991
|
+
}
|
696
992
|
getOptionLabel(option) {
|
697
993
|
return this.optionLabel ? ObjectUtils.resolveFieldData(option, this.optionLabel) : option && option.label != undefined ? option.label : option;
|
698
994
|
}
|
@@ -705,186 +1001,413 @@ class MultiSelect {
|
|
705
1001
|
getOptionGroupChildren(optionGroup) {
|
706
1002
|
return this.optionGroupChildren ? ObjectUtils.resolveFieldData(optionGroup, this.optionGroupChildren) : optionGroup.items;
|
707
1003
|
}
|
708
|
-
|
709
|
-
|
710
|
-
|
711
|
-
|
712
|
-
writeValue(value) {
|
713
|
-
this.value = value;
|
714
|
-
this.updateLabel();
|
715
|
-
this.updateFilledState();
|
716
|
-
this.checkSelectionLimit();
|
717
|
-
this.cd.markForCheck();
|
718
|
-
}
|
719
|
-
checkSelectionLimit() {
|
720
|
-
if (this.selectionLimit && this.value && this.value.length === this.selectionLimit) {
|
721
|
-
this.maxSelectionLimitReached = true;
|
1004
|
+
onKeyDown(event) {
|
1005
|
+
if (this.disabled) {
|
1006
|
+
event.preventDefault();
|
1007
|
+
return;
|
722
1008
|
}
|
723
|
-
|
724
|
-
|
1009
|
+
const metaKey = event.metaKey || event.ctrlKey;
|
1010
|
+
switch (event.code) {
|
1011
|
+
case 'ArrowDown':
|
1012
|
+
this.onArrowDownKey(event);
|
1013
|
+
break;
|
1014
|
+
case 'ArrowUp':
|
1015
|
+
this.onArrowUpKey(event);
|
1016
|
+
break;
|
1017
|
+
case 'Home':
|
1018
|
+
this.onHomeKey(event);
|
1019
|
+
break;
|
1020
|
+
case 'End':
|
1021
|
+
this.onEndKey(event);
|
1022
|
+
break;
|
1023
|
+
case 'PageDown':
|
1024
|
+
this.onPageDownKey(event);
|
1025
|
+
break;
|
1026
|
+
case 'PageUp':
|
1027
|
+
this.onPageUpKey(event);
|
1028
|
+
break;
|
1029
|
+
case 'Enter':
|
1030
|
+
case 'Space':
|
1031
|
+
this.onEnterKey(event);
|
1032
|
+
break;
|
1033
|
+
case 'Escape':
|
1034
|
+
this.onEscapeKey(event);
|
1035
|
+
break;
|
1036
|
+
case 'Tab':
|
1037
|
+
this.onTabKey(event);
|
1038
|
+
break;
|
1039
|
+
case 'ShiftLeft':
|
1040
|
+
case 'ShiftRight':
|
1041
|
+
this.onShiftKey();
|
1042
|
+
break;
|
1043
|
+
default:
|
1044
|
+
if (event.code === 'KeyA' && metaKey) {
|
1045
|
+
const value = this.visibleOptions()
|
1046
|
+
.filter((option) => this.isValidOption(option))
|
1047
|
+
.map((option) => this.getOptionValue(option));
|
1048
|
+
this.updateModel(value, event);
|
1049
|
+
event.preventDefault();
|
1050
|
+
break;
|
1051
|
+
}
|
1052
|
+
if (!metaKey && ObjectUtils.isPrintableCharacter(event.key)) {
|
1053
|
+
!this.overlayVisible && this.show();
|
1054
|
+
this.searchOptions(event, event.key);
|
1055
|
+
event.preventDefault();
|
1056
|
+
}
|
1057
|
+
break;
|
725
1058
|
}
|
726
1059
|
}
|
727
|
-
|
728
|
-
|
1060
|
+
onFilterKeyDown(event) {
|
1061
|
+
switch (event.code) {
|
1062
|
+
case 'ArrowDown':
|
1063
|
+
this.onArrowDownKey(event);
|
1064
|
+
break;
|
1065
|
+
case 'ArrowUp':
|
1066
|
+
this.onArrowUpKey(event, true);
|
1067
|
+
break;
|
1068
|
+
case 'ArrowLeft':
|
1069
|
+
case 'ArrowRight':
|
1070
|
+
this.onArrowLeftKey(event, true);
|
1071
|
+
break;
|
1072
|
+
case 'Home':
|
1073
|
+
this.onHomeKey(event, true);
|
1074
|
+
break;
|
1075
|
+
case 'End':
|
1076
|
+
this.onEndKey(event, true);
|
1077
|
+
break;
|
1078
|
+
case 'Enter':
|
1079
|
+
this.onEnterKey(event);
|
1080
|
+
break;
|
1081
|
+
case 'Escape':
|
1082
|
+
this.onEscapeKey(event);
|
1083
|
+
break;
|
1084
|
+
case 'Tab':
|
1085
|
+
this.onTabKey(event, true);
|
1086
|
+
break;
|
1087
|
+
default:
|
1088
|
+
break;
|
1089
|
+
}
|
729
1090
|
}
|
730
|
-
|
731
|
-
this.
|
1091
|
+
onArrowLeftKey(event, pressedInInputText = false) {
|
1092
|
+
pressedInInputText && this.focusedOptionIndex.set(-1);
|
732
1093
|
}
|
733
|
-
|
734
|
-
this.
|
1094
|
+
onArrowDownKey(event) {
|
1095
|
+
const optionIndex = this.focusedOptionIndex() !== -1 ? this.findNextOptionIndex(this.focusedOptionIndex()) : this.findFirstFocusedOptionIndex();
|
1096
|
+
if (event.shiftKey) {
|
1097
|
+
this.onOptionSelectRange(event, this.startRangeIndex(), optionIndex);
|
1098
|
+
}
|
1099
|
+
this.changeFocusedOptionIndex(event, optionIndex);
|
1100
|
+
!this.overlayVisible && this.show();
|
1101
|
+
event.preventDefault();
|
735
1102
|
}
|
736
|
-
|
737
|
-
|
738
|
-
|
1103
|
+
onArrowUpKey(event, pressedInInputText = false) {
|
1104
|
+
if (event.altKey && !pressedInInputText) {
|
1105
|
+
if (this.focusedOptionIndex() !== -1) {
|
1106
|
+
this.onOptionSelect(event, this.visibleOptions()[this.focusedOptionIndex()]);
|
1107
|
+
}
|
1108
|
+
this.overlayVisible && this.hide();
|
1109
|
+
event.preventDefault();
|
1110
|
+
}
|
1111
|
+
else {
|
1112
|
+
const optionIndex = this.focusedOptionIndex() !== -1 ? this.findPrevOptionIndex(this.focusedOptionIndex()) : this.findLastFocusedOptionIndex();
|
1113
|
+
if (event.shiftKey) {
|
1114
|
+
this.onOptionSelectRange(event, optionIndex, this.startRangeIndex());
|
1115
|
+
}
|
1116
|
+
this.changeFocusedOptionIndex(event, optionIndex);
|
1117
|
+
!this.overlayVisible && this.show();
|
1118
|
+
event.preventDefault();
|
1119
|
+
}
|
739
1120
|
}
|
740
|
-
|
741
|
-
|
742
|
-
if (
|
743
|
-
|
1121
|
+
onHomeKey(event, pressedInInputText = false) {
|
1122
|
+
const { currentTarget } = event;
|
1123
|
+
if (pressedInInputText) {
|
1124
|
+
const len = currentTarget.value.length;
|
1125
|
+
currentTarget.setSelectionRange(0, event.shiftKey ? len : 0);
|
1126
|
+
this.focusedOptionIndex.set(-1);
|
744
1127
|
}
|
745
|
-
|
746
|
-
|
747
|
-
|
748
|
-
|
749
|
-
|
750
|
-
if (this.selectionLimit) {
|
751
|
-
this.maxSelectionLimitReached = false;
|
1128
|
+
else {
|
1129
|
+
let metaKey = event.metaKey || event.ctrlKey;
|
1130
|
+
let optionIndex = this.findFirstOptionIndex();
|
1131
|
+
if (event.shiftKey && metaKey) {
|
1132
|
+
this.onOptionSelectRange(event, optionIndex, this.startRangeIndex());
|
752
1133
|
}
|
1134
|
+
this.changeFocusedOptionIndex(event, optionIndex);
|
1135
|
+
!this.overlayVisible && this.show();
|
1136
|
+
}
|
1137
|
+
event.preventDefault();
|
1138
|
+
}
|
1139
|
+
onEndKey(event, pressedInInputText = false) {
|
1140
|
+
const { currentTarget } = event;
|
1141
|
+
if (pressedInInputText) {
|
1142
|
+
const len = currentTarget.value.length;
|
1143
|
+
currentTarget.setSelectionRange(event.shiftKey ? 0 : len, len);
|
1144
|
+
this.focusedOptionIndex.set(-1);
|
753
1145
|
}
|
754
1146
|
else {
|
755
|
-
|
756
|
-
|
1147
|
+
let metaKey = event.metaKey || event.ctrlKey;
|
1148
|
+
let optionIndex = this.findLastFocusedOptionIndex();
|
1149
|
+
if (event.shiftKey && metaKey) {
|
1150
|
+
this.onOptionSelectRange(event, this.startRangeIndex(), optionIndex);
|
757
1151
|
}
|
758
|
-
this.
|
1152
|
+
this.changeFocusedOptionIndex(event, optionIndex);
|
1153
|
+
!this.overlayVisible && this.show();
|
759
1154
|
}
|
760
|
-
|
761
|
-
this.onChange.emit({ originalEvent: event.originalEvent, value: this.value, itemValue: optionValue });
|
762
|
-
this.updateLabel();
|
763
|
-
this.updateFilledState();
|
1155
|
+
event.preventDefault();
|
764
1156
|
}
|
765
|
-
|
766
|
-
|
767
|
-
|
768
|
-
|
769
|
-
|
770
|
-
|
771
|
-
|
772
|
-
|
773
|
-
|
774
|
-
|
1157
|
+
onPageDownKey(event) {
|
1158
|
+
this.scrollInView(this.visibleOptions().length - 1);
|
1159
|
+
event.preventDefault();
|
1160
|
+
}
|
1161
|
+
onPageUpKey(event) {
|
1162
|
+
this.scrollInView(0);
|
1163
|
+
event.preventDefault();
|
1164
|
+
}
|
1165
|
+
onEnterKey(event) {
|
1166
|
+
if (!this.overlayVisible) {
|
1167
|
+
this.onArrowDownKey(event);
|
1168
|
+
}
|
1169
|
+
else {
|
1170
|
+
if (this.focusedOptionIndex() !== -1) {
|
1171
|
+
if (event.shiftKey) {
|
1172
|
+
this.onOptionSelectRange(event, this.focusedOptionIndex());
|
1173
|
+
}
|
1174
|
+
else {
|
1175
|
+
this.onOptionSelect({ originalEvent: event, option: this.visibleOptions()[this.focusedOptionIndex()] });
|
775
1176
|
}
|
776
1177
|
}
|
777
1178
|
}
|
778
|
-
|
1179
|
+
event.preventDefault();
|
779
1180
|
}
|
780
|
-
|
781
|
-
|
782
|
-
|
783
|
-
|
1181
|
+
onEscapeKey(event) {
|
1182
|
+
this.overlayVisible && this.hide(true);
|
1183
|
+
event.preventDefault();
|
1184
|
+
}
|
1185
|
+
onDeleteKey(event) {
|
1186
|
+
if (this.showClear) {
|
1187
|
+
this.clear(event);
|
1188
|
+
event.preventDefault();
|
784
1189
|
}
|
785
|
-
|
786
|
-
|
787
|
-
|
788
|
-
|
1190
|
+
}
|
1191
|
+
onTabKey(event, pressedInInputText = false) {
|
1192
|
+
if (!pressedInInputText) {
|
1193
|
+
if (this.overlayVisible && this.hasFocusableElements()) {
|
1194
|
+
DomHandler.focus(event.shiftKey ? this.lastHiddenFocusableElementOnOverlay.nativeElement : this.firstHiddenFocusableElementOnOverlay.nativeElement);
|
1195
|
+
event.preventDefault();
|
1196
|
+
}
|
1197
|
+
else {
|
1198
|
+
if (this.focusedOptionIndex() !== -1) {
|
1199
|
+
this.onOptionSelect({ originalEvent: event, option: this.visibleOptions()[this.focusedOptionIndex()] });
|
1200
|
+
}
|
1201
|
+
this.overlayVisible && this.hide(this.filter);
|
789
1202
|
}
|
790
|
-
return true;
|
791
1203
|
}
|
792
1204
|
}
|
793
|
-
|
794
|
-
|
1205
|
+
onShiftKey() {
|
1206
|
+
this.startRangeIndex.set(this.focusedOptionIndex());
|
1207
|
+
}
|
1208
|
+
onContainerClick(event) {
|
1209
|
+
if (this.disabled || this.readonly || event.target.isSameNode(this.focusInputViewChild?.nativeElement)) {
|
795
1210
|
return;
|
796
1211
|
}
|
797
|
-
|
798
|
-
|
799
|
-
|
800
|
-
|
801
|
-
|
802
|
-
|
1212
|
+
if (event.target.tagName === 'INPUT' || event.target.getAttribute('data-pc-section') === 'clearicon' || event.target.closest('[data-pc-section="clearicon"]')) {
|
1213
|
+
event.preventDefault();
|
1214
|
+
return;
|
1215
|
+
}
|
1216
|
+
else if (!this.overlayViewChild || !this.overlayViewChild.el.nativeElement.contains(event.target)) {
|
1217
|
+
this.overlayVisible ? this.hide(true) : this.show(true);
|
1218
|
+
}
|
1219
|
+
this.focusInputViewChild?.nativeElement.focus({ preventScroll: true });
|
1220
|
+
this.onClick.emit(event);
|
1221
|
+
this.cd.detectChanges();
|
1222
|
+
}
|
1223
|
+
onFirstHiddenFocus(event) {
|
1224
|
+
const focusableEl = event.relatedTarget === this.focusInputViewChild?.nativeElement
|
1225
|
+
? DomHandler.getFirstFocusableElement(this.overlayViewChild?.overlayViewChild?.nativeElement, ':not([data-p-hidden-focusable="true"])')
|
1226
|
+
: this.focusInputViewChild?.nativeElement;
|
1227
|
+
DomHandler.focus(focusableEl);
|
1228
|
+
}
|
1229
|
+
onInputFocus(event) {
|
1230
|
+
this.focused = true;
|
1231
|
+
const focusedOptionIndex = this.focusedOptionIndex() !== -1 ? this.focusedOptionIndex() : this.overlayVisible && this.autoOptionFocus ? this.findFirstFocusedOptionIndex() : -1;
|
1232
|
+
this.focusedOptionIndex.set(focusedOptionIndex);
|
1233
|
+
this.overlayVisible && this.scrollInView(this.focusedOptionIndex());
|
1234
|
+
this.onFocus.emit({ originalEvent: event });
|
1235
|
+
}
|
1236
|
+
onInputBlur(event) {
|
1237
|
+
this.focused = false;
|
1238
|
+
this.onBlur.emit({ originalEvent: event });
|
1239
|
+
if (!this.preventModelTouched) {
|
1240
|
+
this.onModelTouched();
|
1241
|
+
}
|
1242
|
+
this.preventModelTouched = false;
|
1243
|
+
}
|
1244
|
+
onFilterInputChange(event) {
|
1245
|
+
let value = event.target.value?.trim();
|
1246
|
+
this._filterValue.set(value);
|
1247
|
+
this.focusedOptionIndex.set(-1);
|
1248
|
+
this.onFilter.emit({ originalEvent: event, filter: this._filterValue() });
|
1249
|
+
!this.virtualScrollerDisabled && this.scroller.scrollToIndex(0);
|
1250
|
+
}
|
1251
|
+
onLastHiddenFocus(event) {
|
1252
|
+
const focusableEl = event.relatedTarget === this.focusInputViewChild?.nativeElement
|
1253
|
+
? DomHandler.getLastFocusableElement(this.overlayViewChild?.overlayViewChild?.nativeElement, ':not([data-p-hidden-focusable="true"])')
|
1254
|
+
: this.focusInputViewChild?.nativeElement;
|
1255
|
+
DomHandler.focus(focusableEl);
|
1256
|
+
}
|
1257
|
+
onOptionMouseEnter(event, index) {
|
1258
|
+
if (this.focusOnHover) {
|
1259
|
+
this.changeFocusedOptionIndex(event, index);
|
1260
|
+
}
|
1261
|
+
}
|
1262
|
+
onHeaderCheckboxKeyDown(event) {
|
1263
|
+
if (this.disabled) {
|
1264
|
+
event.preventDefault();
|
1265
|
+
return;
|
1266
|
+
}
|
1267
|
+
switch (event.code) {
|
1268
|
+
case 'Space':
|
1269
|
+
this.onToggleAll(event);
|
1270
|
+
break;
|
1271
|
+
case 'Enter':
|
1272
|
+
this.onToggleAll(event);
|
1273
|
+
break;
|
1274
|
+
default:
|
1275
|
+
break;
|
1276
|
+
}
|
1277
|
+
}
|
1278
|
+
onFilterBlur(event) {
|
1279
|
+
this.focusedOptionIndex.set(-1);
|
1280
|
+
}
|
1281
|
+
onHeaderCheckboxFocus() {
|
1282
|
+
this.headerCheckboxFocus = true;
|
1283
|
+
}
|
1284
|
+
onHeaderCheckboxBlur() {
|
1285
|
+
this.headerCheckboxFocus = false;
|
1286
|
+
}
|
1287
|
+
onToggleAll(event) {
|
1288
|
+
if (this.disabled || this.readonly) {
|
1289
|
+
return;
|
1290
|
+
}
|
1291
|
+
DomHandler.focus(this.headerCheckboxViewChild.nativeElement);
|
1292
|
+
const value = this.allSelected()
|
1293
|
+
? []
|
1294
|
+
: this.visibleOptions()
|
1295
|
+
.filter((option) => this.isValidOption(option))
|
1296
|
+
.map((option) => this.getOptionValue(option));
|
1297
|
+
this.updateModel(value, event);
|
803
1298
|
this.onChange.emit({ originalEvent: event, value: this.value });
|
804
|
-
this.
|
805
|
-
this.updateLabel();
|
1299
|
+
this.headerCheckboxFocus = true;
|
806
1300
|
event.preventDefault();
|
807
1301
|
event.stopPropagation();
|
808
1302
|
}
|
809
|
-
|
810
|
-
|
811
|
-
|
812
|
-
|
813
|
-
|
814
|
-
|
815
|
-
|
816
|
-
|
817
|
-
|
818
|
-
|
819
|
-
|
820
|
-
|
821
|
-
|
822
|
-
|
823
|
-
|
824
|
-
if (!optionDisabled || (optionDisabled && this.isSelected(option))) {
|
825
|
-
val.push(this.getOptionValue(option));
|
826
|
-
}
|
827
|
-
});
|
828
|
-
}
|
829
|
-
}
|
830
|
-
});
|
831
|
-
this.value = val;
|
832
|
-
}
|
833
|
-
uncheckAll() {
|
834
|
-
let optionsToRender = this.optionsToRender;
|
835
|
-
let val = [];
|
836
|
-
optionsToRender.forEach((opt) => {
|
837
|
-
if (!this.group) {
|
838
|
-
let optionDisabled = this.isOptionDisabled(opt);
|
839
|
-
if (optionDisabled && this.isSelected(opt)) {
|
840
|
-
val.push(this.getOptionValue(opt));
|
841
|
-
}
|
1303
|
+
changeFocusedOptionIndex(event, index) {
|
1304
|
+
if (this.focusedOptionIndex() !== index) {
|
1305
|
+
this.focusedOptionIndex.set(index);
|
1306
|
+
this.scrollInView();
|
1307
|
+
}
|
1308
|
+
}
|
1309
|
+
get virtualScrollerDisabled() {
|
1310
|
+
return !this.virtualScroll;
|
1311
|
+
}
|
1312
|
+
scrollInView(index = -1) {
|
1313
|
+
const id = index !== -1 ? `${this.id}_${index}` : this.focusedOptionId;
|
1314
|
+
if (this.itemsViewChild && this.itemsViewChild.nativeElement) {
|
1315
|
+
const element = DomHandler.findSingle(this.itemsViewChild.nativeElement, `li[id="${id}"]`);
|
1316
|
+
if (element) {
|
1317
|
+
element.scrollIntoView && element.scrollIntoView({ block: 'nearest', inline: 'nearest' });
|
842
1318
|
}
|
843
|
-
else {
|
844
|
-
|
845
|
-
|
846
|
-
|
847
|
-
if (optionDisabled && this.isSelected(option)) {
|
848
|
-
val.push(this.getOptionValue(option));
|
849
|
-
}
|
850
|
-
});
|
851
|
-
}
|
1319
|
+
else if (!this.virtualScrollerDisabled) {
|
1320
|
+
setTimeout(() => {
|
1321
|
+
this.virtualScroll && this.scroller?.scrollToIndex(index !== -1 ? index : this.focusedOptionIndex());
|
1322
|
+
}, 0);
|
852
1323
|
}
|
853
|
-
}
|
854
|
-
this.value = val;
|
1324
|
+
}
|
855
1325
|
}
|
856
|
-
|
857
|
-
|
858
|
-
|
859
|
-
|
860
|
-
|
1326
|
+
get focusedOptionId() {
|
1327
|
+
return this.focusedOptionIndex() !== -1 ? `${this.id}_${this.focusedOptionIndex()}` : null;
|
1328
|
+
}
|
1329
|
+
checkSelectionLimit() {
|
1330
|
+
if (this.selectionLimit && this.value && this.value.length === this.selectionLimit) {
|
1331
|
+
this.maxSelectionLimitReached = true;
|
861
1332
|
}
|
1333
|
+
else {
|
1334
|
+
this.maxSelectionLimitReached = false;
|
1335
|
+
}
|
1336
|
+
}
|
1337
|
+
writeValue(value) {
|
1338
|
+
this.value = value;
|
1339
|
+
this.modelValue.set(this.value);
|
1340
|
+
this.updateModel(this.value);
|
1341
|
+
this.checkSelectionLimit();
|
1342
|
+
this.cd.markForCheck();
|
1343
|
+
}
|
1344
|
+
registerOnChange(fn) {
|
1345
|
+
this.onModelChange = fn;
|
1346
|
+
}
|
1347
|
+
registerOnTouched(fn) {
|
1348
|
+
this.onModelTouched = fn;
|
1349
|
+
}
|
1350
|
+
setDisabledState(val) {
|
1351
|
+
this.disabled = val;
|
1352
|
+
this.cd.markForCheck();
|
1353
|
+
}
|
1354
|
+
allSelected() {
|
1355
|
+
const allSelected = this.visibleOptions().length > 0 && this.visibleOptions().every((option) => this.isOptionGroup(option) || this.isOptionDisabled(option) || this.isSelected(option));
|
1356
|
+
return ObjectUtils.isNotEmpty(this.visibleOptions()) && allSelected;
|
1357
|
+
}
|
1358
|
+
/**
|
1359
|
+
* Displays the panel.
|
1360
|
+
* @group Method
|
1361
|
+
*/
|
1362
|
+
show(isFocus) {
|
1363
|
+
this.overlayVisible = true;
|
1364
|
+
const focusedOptionIndex = this.focusedOptionIndex() !== -1 ? this.focusedOptionIndex() : this.autoOptionFocus ? this.findFirstFocusedOptionIndex() : -1;
|
1365
|
+
this.focusedOptionIndex.set(focusedOptionIndex);
|
1366
|
+
if (isFocus) {
|
1367
|
+
DomHandler.focus(this.focusInputViewChild?.nativeElement);
|
1368
|
+
}
|
1369
|
+
this.cd.markForCheck();
|
1370
|
+
}
|
1371
|
+
/**
|
1372
|
+
* Hides the panel.
|
1373
|
+
* @group Method
|
1374
|
+
*/
|
1375
|
+
hide(isFocus) {
|
1376
|
+
this.overlayVisible = false;
|
1377
|
+
this.focusedOptionIndex.set(-1);
|
1378
|
+
if (this.filter && this.resetFilterOnHide) {
|
1379
|
+
this.resetFilter();
|
1380
|
+
}
|
1381
|
+
isFocus && DomHandler.focus(this.focusInputViewChild?.nativeElement);
|
1382
|
+
this.onPanelHide.emit();
|
1383
|
+
this.cd.markForCheck();
|
862
1384
|
}
|
863
1385
|
onOverlayAnimationStart(event) {
|
864
1386
|
switch (event.toState) {
|
865
1387
|
case 'visible':
|
1388
|
+
this.itemsWrapper = DomHandler.findSingle(this.overlayViewChild?.overlayViewChild?.nativeElement, this.virtualScroll ? '.p-scroller' : '.p-multiselect-items-wrapper');
|
866
1389
|
this.virtualScroll && this.scroller?.setContentEl(this.itemsViewChild?.nativeElement);
|
867
|
-
if (this.
|
868
|
-
this.
|
869
|
-
|
870
|
-
|
1390
|
+
if (this._options() && this._options().length) {
|
1391
|
+
if (this.virtualScroll) {
|
1392
|
+
const selectedIndex = ObjectUtils.isNotEmpty(this.modelValue()) ? this.focusedOptionIndex() : -1;
|
1393
|
+
if (selectedIndex !== -1) {
|
1394
|
+
this.scroller?.scrollToIndex(0);
|
1395
|
+
}
|
1396
|
+
}
|
1397
|
+
else {
|
1398
|
+
let selectedListItem = DomHandler.findSingle(this.itemsWrapper, '.p-multiselect-item.p-highlight');
|
1399
|
+
if (selectedListItem) {
|
1400
|
+
selectedListItem.scrollIntoView({ block: 'nearest', inline: 'center' });
|
1401
|
+
}
|
871
1402
|
}
|
1403
|
+
this.onPanelShow.emit();
|
872
1404
|
}
|
873
|
-
this.onPanelShow.emit();
|
874
|
-
break;
|
875
1405
|
case 'void':
|
1406
|
+
this.itemsWrapper = null;
|
876
1407
|
this.onModelTouched();
|
877
1408
|
break;
|
878
1409
|
}
|
879
1410
|
}
|
880
|
-
hide() {
|
881
|
-
this.overlayVisible = false;
|
882
|
-
if (this.resetFilterOnHide) {
|
883
|
-
this.resetFilter();
|
884
|
-
}
|
885
|
-
this.onPanelHide.emit();
|
886
|
-
this.cd.markForCheck();
|
887
|
-
}
|
888
1411
|
resetFilter() {
|
889
1412
|
if (this.filterInputChild && this.filterInputChild.nativeElement) {
|
890
1413
|
this.filterInputChild.nativeElement.value = '';
|
@@ -899,80 +1422,15 @@ class MultiSelect {
|
|
899
1422
|
}
|
900
1423
|
clear(event) {
|
901
1424
|
this.value = null;
|
902
|
-
this.updateLabel();
|
903
|
-
this.updateFilledState();
|
904
1425
|
this.checkSelectionLimit();
|
1426
|
+
this.updateModel(null, event);
|
905
1427
|
this.onClear.emit();
|
906
|
-
this.onModelChange(this.value);
|
907
1428
|
event.stopPropagation();
|
908
1429
|
}
|
909
|
-
|
910
|
-
|
911
|
-
|
912
|
-
|
913
|
-
this.onClick.emit(event);
|
914
|
-
if (!this.overlayViewChild?.el?.nativeElement?.contains(event.target) && !DomHandler.hasClass(event.target, 'p-multiselect-token-icon')) {
|
915
|
-
if (this.overlayVisible) {
|
916
|
-
this.hide();
|
917
|
-
}
|
918
|
-
else {
|
919
|
-
this.show();
|
920
|
-
}
|
921
|
-
input.focus();
|
922
|
-
}
|
923
|
-
this.cd.detectChanges();
|
924
|
-
}
|
925
|
-
removeChip(chip, event) {
|
926
|
-
this.value = this.value.filter((val) => !ObjectUtils.equals(val, chip, this.dataKey));
|
927
|
-
this.onModelChange(this.value);
|
928
|
-
this.checkSelectionLimit();
|
929
|
-
this.onChange.emit({ originalEvent: event, value: this.value, itemValue: chip });
|
930
|
-
this.updateLabel();
|
931
|
-
this.updateFilledState();
|
932
|
-
}
|
933
|
-
onInputFocus(event) {
|
934
|
-
this.focus = true;
|
935
|
-
this.onFocus.emit({ originalEvent: event });
|
936
|
-
}
|
937
|
-
onInputBlur(event) {
|
938
|
-
this.focus = false;
|
939
|
-
this.onBlur.emit({ originalEvent: event });
|
940
|
-
if (!this.preventModelTouched) {
|
941
|
-
this.onModelTouched();
|
942
|
-
}
|
943
|
-
this.preventModelTouched = false;
|
944
|
-
}
|
945
|
-
onOptionKeydown(event) {
|
946
|
-
if (this.readonly) {
|
947
|
-
return;
|
948
|
-
}
|
949
|
-
switch (event.originalEvent.which) {
|
950
|
-
//down
|
951
|
-
case 40:
|
952
|
-
var nextItem = this.findNextItem(event.originalEvent.target.parentElement);
|
953
|
-
if (nextItem) {
|
954
|
-
nextItem.focus();
|
955
|
-
}
|
956
|
-
event.originalEvent.preventDefault();
|
957
|
-
break;
|
958
|
-
//up
|
959
|
-
case 38:
|
960
|
-
var prevItem = this.findPrevItem(event.originalEvent.target.parentElement);
|
961
|
-
if (prevItem) {
|
962
|
-
prevItem.focus();
|
963
|
-
}
|
964
|
-
event.originalEvent.preventDefault();
|
965
|
-
break;
|
966
|
-
//enter
|
967
|
-
case 13:
|
968
|
-
this.onOptionClick(event);
|
969
|
-
event.originalEvent.preventDefault();
|
970
|
-
break;
|
971
|
-
case 27:
|
972
|
-
case 9:
|
973
|
-
this.hide();
|
974
|
-
break;
|
975
|
-
}
|
1430
|
+
removeOption(optionValue, event) {
|
1431
|
+
let value = this.modelValue().filter((val) => !ObjectUtils.equals(val, optionValue, this.equalityKey()));
|
1432
|
+
this.updateModel(value, event);
|
1433
|
+
event && event.stopPropagation();
|
976
1434
|
}
|
977
1435
|
findNextItem(item) {
|
978
1436
|
let nextItem = item.nextElementSibling;
|
@@ -988,161 +1446,63 @@ class MultiSelect {
|
|
988
1446
|
else
|
989
1447
|
return null;
|
990
1448
|
}
|
991
|
-
|
992
|
-
|
993
|
-
|
994
|
-
|
995
|
-
|
996
|
-
|
997
|
-
|
998
|
-
|
999
|
-
|
1000
|
-
|
1001
|
-
|
1002
|
-
|
1003
|
-
|
1004
|
-
|
1005
|
-
|
1006
|
-
|
1007
|
-
|
1008
|
-
|
1009
|
-
|
1010
|
-
|
1011
|
-
|
1012
|
-
}
|
1013
|
-
|
1014
|
-
|
1015
|
-
|
1016
|
-
|
1017
|
-
|
1018
|
-
|
1019
|
-
|
1020
|
-
|
1021
|
-
|
1022
|
-
|
1023
|
-
|
1024
|
-
|
1025
|
-
|
1026
|
-
|
1027
|
-
}
|
1028
|
-
else {
|
1029
|
-
let pattern = /{(.*?)}/;
|
1030
|
-
if (pattern.test(this.selectedItemsLabel)) {
|
1031
|
-
this.valuesAsString = this.selectedItemsLabel.replace(this.selectedItemsLabel.match(pattern)[0], this.value.length + '');
|
1032
|
-
}
|
1033
|
-
else {
|
1034
|
-
this.valuesAsString = this.selectedItemsLabel;
|
1035
|
-
}
|
1036
|
-
}
|
1449
|
+
findNextOptionIndex(index) {
|
1450
|
+
const matchedOptionIndex = index < this.visibleOptions().length - 1
|
1451
|
+
? this.visibleOptions()
|
1452
|
+
.slice(index + 1)
|
1453
|
+
.findIndex((option) => this.isValidOption(option))
|
1454
|
+
: -1;
|
1455
|
+
return matchedOptionIndex > -1 ? matchedOptionIndex + index + 1 : index;
|
1456
|
+
}
|
1457
|
+
findPrevOptionIndex(index) {
|
1458
|
+
const matchedOptionIndex = index > 0 ? ObjectUtils.findLastIndex(this.visibleOptions().slice(0, index), (option) => this.isValidOption(option)) : -1;
|
1459
|
+
return matchedOptionIndex > -1 ? matchedOptionIndex : index;
|
1460
|
+
}
|
1461
|
+
findLastSelectedOptionIndex() {
|
1462
|
+
return this.hasSelectedOption() ? ObjectUtils.findLastIndex(this.visibleOptions(), (option) => this.isValidSelectedOption(option)) : -1;
|
1463
|
+
}
|
1464
|
+
findLastFocusedOptionIndex() {
|
1465
|
+
const selectedIndex = this.findLastSelectedOptionIndex();
|
1466
|
+
return selectedIndex < 0 ? this.findLastOptionIndex() : selectedIndex;
|
1467
|
+
}
|
1468
|
+
findLastOptionIndex() {
|
1469
|
+
return ObjectUtils.findLastIndex(this.visibleOptions(), (option) => this.isValidOption(option));
|
1470
|
+
}
|
1471
|
+
searchOptions(event, char) {
|
1472
|
+
this.searchValue = (this.searchValue || '') + char;
|
1473
|
+
let optionIndex = -1;
|
1474
|
+
let matched = false;
|
1475
|
+
if (this.focusedOptionIndex() !== -1) {
|
1476
|
+
optionIndex = this.visibleOptions()
|
1477
|
+
.slice(this.focusedOptionIndex())
|
1478
|
+
.findIndex((option) => this.isOptionMatched(option));
|
1479
|
+
optionIndex =
|
1480
|
+
optionIndex === -1
|
1481
|
+
? this.visibleOptions()
|
1482
|
+
.slice(0, this.focusedOptionIndex())
|
1483
|
+
.findIndex((option) => this.isOptionMatched(option))
|
1484
|
+
: optionIndex + this.focusedOptionIndex();
|
1037
1485
|
}
|
1038
1486
|
else {
|
1039
|
-
|
1487
|
+
optionIndex = this.visibleOptions().findIndex((option) => this.isOptionMatched(option));
|
1040
1488
|
}
|
1041
|
-
|
1042
|
-
|
1043
|
-
if (this.group) {
|
1044
|
-
let label = null;
|
1045
|
-
for (let i = 0; i < this.options.length; i++) {
|
1046
|
-
let subOptions = this.getOptionGroupChildren(this.options[i]);
|
1047
|
-
if (subOptions) {
|
1048
|
-
label = this.searchLabelByValue(val, subOptions);
|
1049
|
-
if (label) {
|
1050
|
-
break;
|
1051
|
-
}
|
1052
|
-
}
|
1053
|
-
}
|
1054
|
-
return label;
|
1489
|
+
if (optionIndex !== -1) {
|
1490
|
+
matched = true;
|
1055
1491
|
}
|
1056
|
-
|
1057
|
-
|
1492
|
+
if (optionIndex === -1 && this.focusedOptionIndex() === -1) {
|
1493
|
+
optionIndex = this.findFirstFocusedOptionIndex();
|
1058
1494
|
}
|
1059
|
-
|
1060
|
-
|
1061
|
-
let label = null;
|
1062
|
-
for (let i = 0; i < options.length; i++) {
|
1063
|
-
let option = options[i];
|
1064
|
-
let optionValue = this.getOptionValue(option);
|
1065
|
-
if ((val == null && optionValue == null) || ObjectUtils.equals(val, optionValue, this.dataKey)) {
|
1066
|
-
label = this.getOptionLabel(option);
|
1067
|
-
break;
|
1068
|
-
}
|
1069
|
-
}
|
1070
|
-
return label;
|
1071
|
-
}
|
1072
|
-
get allChecked() {
|
1073
|
-
let optionsToRender = this.optionsToRender;
|
1074
|
-
if (!optionsToRender || optionsToRender.length === 0) {
|
1075
|
-
return false;
|
1495
|
+
if (optionIndex !== -1) {
|
1496
|
+
this.changeFocusedOptionIndex(event, optionIndex);
|
1076
1497
|
}
|
1077
|
-
|
1078
|
-
|
1079
|
-
let unselectedDisabledItemsLength = 0;
|
1080
|
-
let selectedEnabledItemsLength = 0;
|
1081
|
-
let visibleOptionsLength = this.group ? 0 : this.optionsToRender.length;
|
1082
|
-
for (let option of optionsToRender) {
|
1083
|
-
if (!this.group) {
|
1084
|
-
let disabled = this.isOptionDisabled(option);
|
1085
|
-
let selected = this.isSelected(option);
|
1086
|
-
if (disabled) {
|
1087
|
-
if (selected)
|
1088
|
-
selectedDisabledItemsLength++;
|
1089
|
-
else
|
1090
|
-
unselectedDisabledItemsLength++;
|
1091
|
-
}
|
1092
|
-
else {
|
1093
|
-
if (selected)
|
1094
|
-
selectedEnabledItemsLength++;
|
1095
|
-
else
|
1096
|
-
return false;
|
1097
|
-
}
|
1098
|
-
}
|
1099
|
-
else {
|
1100
|
-
for (let opt of this.getOptionGroupChildren(option)) {
|
1101
|
-
let disabled = this.isOptionDisabled(opt);
|
1102
|
-
let selected = this.isSelected(opt);
|
1103
|
-
if (disabled) {
|
1104
|
-
if (selected)
|
1105
|
-
selectedDisabledItemsLength++;
|
1106
|
-
else
|
1107
|
-
unselectedDisabledItemsLength++;
|
1108
|
-
}
|
1109
|
-
else {
|
1110
|
-
if (selected)
|
1111
|
-
selectedEnabledItemsLength++;
|
1112
|
-
else {
|
1113
|
-
return false;
|
1114
|
-
}
|
1115
|
-
}
|
1116
|
-
visibleOptionsLength++;
|
1117
|
-
}
|
1118
|
-
}
|
1119
|
-
}
|
1120
|
-
return (visibleOptionsLength === selectedDisabledItemsLength ||
|
1121
|
-
visibleOptionsLength === selectedEnabledItemsLength ||
|
1122
|
-
(selectedEnabledItemsLength && visibleOptionsLength === selectedEnabledItemsLength + unselectedDisabledItemsLength + selectedDisabledItemsLength));
|
1498
|
+
if (this.searchTimeout) {
|
1499
|
+
clearTimeout(this.searchTimeout);
|
1123
1500
|
}
|
1124
|
-
|
1125
|
-
|
1126
|
-
|
1127
|
-
|
1128
|
-
|
1129
|
-
return this.emptyMessage || this.config.getTranslation(TranslationKeys.EMPTY_MESSAGE);
|
1130
|
-
}
|
1131
|
-
get emptyFilterMessageLabel() {
|
1132
|
-
return this.emptyFilterMessage || this.config.getTranslation(TranslationKeys.EMPTY_FILTER_MESSAGE);
|
1133
|
-
}
|
1134
|
-
hasFilter() {
|
1135
|
-
return this._filterValue && this._filterValue.trim().length > 0;
|
1136
|
-
}
|
1137
|
-
isEmpty() {
|
1138
|
-
return !this.optionsToRender || (this.optionsToRender && this.optionsToRender.length === 0);
|
1139
|
-
}
|
1140
|
-
onFilterInputChange(event) {
|
1141
|
-
this._filterValue = event.target.value;
|
1142
|
-
this.activateFilter();
|
1143
|
-
this.filtered = true;
|
1144
|
-
this.onFilter.emit({ originalEvent: event, filter: this._filterValue });
|
1145
|
-
this.cd.detectChanges();
|
1501
|
+
this.searchTimeout = setTimeout(() => {
|
1502
|
+
this.searchValue = '';
|
1503
|
+
this.searchTimeout = null;
|
1504
|
+
}, 500);
|
1505
|
+
return matched;
|
1146
1506
|
}
|
1147
1507
|
activateFilter() {
|
1148
1508
|
if (this.hasFilter() && this._options) {
|
@@ -1165,75 +1525,69 @@ class MultiSelect {
|
|
1165
1525
|
this._filteredOptions = null;
|
1166
1526
|
}
|
1167
1527
|
}
|
1168
|
-
|
1169
|
-
this.
|
1528
|
+
hasFocusableElements() {
|
1529
|
+
return DomHandler.getFocusableElements(this.overlayViewChild.overlayViewChild.nativeElement, ':not([data-p-hidden-focusable="true"])').length > 0;
|
1170
1530
|
}
|
1171
|
-
|
1172
|
-
this.
|
1531
|
+
hasFilter() {
|
1532
|
+
return this._filterValue() && this._filterValue().trim().length > 0;
|
1173
1533
|
}
|
1174
1534
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: MultiSelect, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }, { token: i3.FilterService }, { token: i3.PrimeNGConfig }, { token: i3.OverlayService }], target: i0.ɵɵFactoryTarget.Component });
|
1175
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: MultiSelect, selector: "p-multiSelect", inputs: { style: "style", styleClass: "styleClass", panelStyle: "panelStyle", panelStyleClass: "panelStyleClass", inputId: "inputId", disabled: "disabled", readonly: "readonly", group: "group", filter: "filter", filterPlaceHolder: "filterPlaceHolder", filterLocale: "filterLocale", overlayVisible: "overlayVisible", tabindex: "tabindex", appendTo: "appendTo", dataKey: "dataKey", name: "name",
|
1176
|
-
<div
|
1177
|
-
|
1178
|
-
[ngClass]="{ 'p-multiselect p-component': true, 'p-multiselect-open': overlayVisible, 'p-multiselect-chip': display === 'chip', 'p-focus': focus, 'p-disabled': disabled }"
|
1179
|
-
[ngStyle]="style"
|
1180
|
-
[class]="styleClass"
|
1181
|
-
(click)="onMouseclick($event, in)"
|
1182
|
-
>
|
1183
|
-
<div class="p-hidden-accessible">
|
1535
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: MultiSelect, selector: "p-multiSelect", inputs: { id: "id", ariaLabel: "ariaLabel", style: "style", styleClass: "styleClass", panelStyle: "panelStyle", panelStyleClass: "panelStyleClass", inputId: "inputId", disabled: "disabled", readonly: "readonly", group: "group", filter: "filter", filterPlaceHolder: "filterPlaceHolder", filterLocale: "filterLocale", overlayVisible: "overlayVisible", tabindex: "tabindex", appendTo: "appendTo", dataKey: "dataKey", name: "name", ariaLabelledBy: "ariaLabelledBy", displaySelectedLabel: "displaySelectedLabel", maxSelectedLabels: "maxSelectedLabels", selectionLimit: "selectionLimit", selectedItemsLabel: "selectedItemsLabel", showToggleAll: "showToggleAll", emptyFilterMessage: "emptyFilterMessage", emptyMessage: "emptyMessage", resetFilterOnHide: "resetFilterOnHide", dropdownIcon: "dropdownIcon", optionLabel: "optionLabel", optionValue: "optionValue", optionDisabled: "optionDisabled", optionGroupLabel: "optionGroupLabel", optionGroupChildren: "optionGroupChildren", showHeader: "showHeader", filterBy: "filterBy", scrollHeight: "scrollHeight", lazy: "lazy", virtualScroll: "virtualScroll", virtualScrollItemSize: "virtualScrollItemSize", virtualScrollOptions: "virtualScrollOptions", overlayOptions: "overlayOptions", ariaFilterLabel: "ariaFilterLabel", filterMatchMode: "filterMatchMode", tooltip: "tooltip", tooltipPosition: "tooltipPosition", tooltipPositionStyle: "tooltipPositionStyle", tooltipStyleClass: "tooltipStyleClass", autofocusFilter: "autofocusFilter", display: "display", autocomplete: "autocomplete", showClear: "showClear", autoZIndex: "autoZIndex", baseZIndex: "baseZIndex", showTransitionOptions: "showTransitionOptions", hideTransitionOptions: "hideTransitionOptions", defaultLabel: "defaultLabel", placeholder: "placeholder", options: "options", filterValue: "filterValue", itemSize: "itemSize", focusOnHover: "focusOnHover", filterFields: "filterFields", selectOnFocus: "selectOnFocus", autoOptionFocus: "autoOptionFocus" }, outputs: { onChange: "onChange", onFilter: "onFilter", onFocus: "onFocus", onBlur: "onBlur", onClick: "onClick", onClear: "onClear", onPanelShow: "onPanelShow", onPanelHide: "onPanelHide", onLazyLoad: "onLazyLoad", onRemove: "onRemove" }, host: { properties: { "class.p-inputwrapper-filled": "filled", "class.p-inputwrapper-focus": "focused || overlayVisible" }, classAttribute: "p-element p-inputwrapper" }, providers: [MULTISELECT_VALUE_ACCESSOR], queries: [{ propertyName: "footerFacet", first: true, predicate: Footer, descendants: true }, { propertyName: "headerFacet", first: true, predicate: Header, descendants: true }, { propertyName: "templates", predicate: PrimeTemplate }], viewQueries: [{ propertyName: "containerViewChild", first: true, predicate: ["container"], descendants: true }, { propertyName: "overlayViewChild", first: true, predicate: ["overlay"], descendants: true }, { propertyName: "filterInputChild", first: true, predicate: ["filterInput"], descendants: true }, { propertyName: "focusInputViewChild", first: true, predicate: ["focusInput"], descendants: true }, { propertyName: "itemsViewChild", first: true, predicate: ["items"], descendants: true }, { propertyName: "scroller", first: true, predicate: ["scroller"], descendants: true }, { propertyName: "lastHiddenFocusableElementOnOverlay", first: true, predicate: ["lastHiddenFocusableEl"], descendants: true }, { propertyName: "firstHiddenFocusableElementOnOverlay", first: true, predicate: ["firstHiddenFocusableEl"], descendants: true }, { propertyName: "headerCheckboxViewChild", first: true, predicate: ["headerCheckbox"], descendants: true }], ngImport: i0, template: `
|
1536
|
+
<div #container [attr.id]="id" [ngClass]="containerClass" [ngStyle]="style" [class]="styleClass" (click)="onContainerClick($event)">
|
1537
|
+
<div class="p-hidden-accessible" [attr.data-p-hidden-accessible]="true">
|
1184
1538
|
<input
|
1185
|
-
#
|
1186
|
-
|
1187
|
-
[
|
1188
|
-
|
1539
|
+
#focusInput
|
1540
|
+
[pTooltip]="tooltip"
|
1541
|
+
[tooltipPosition]="tooltipPosition"
|
1542
|
+
[positionStyle]="tooltipPositionStyle"
|
1543
|
+
[tooltipStyleClass]="tooltipStyleClass"
|
1544
|
+
[attr.aria-disabled]="disabled"
|
1189
1545
|
[attr.id]="inputId"
|
1190
|
-
|
1546
|
+
role="combobox"
|
1547
|
+
[attr.aria-label]="ariaLabel"
|
1548
|
+
[attr.aria-labelledby]="ariaLabelledBy"
|
1549
|
+
[attr.aria-haspopup]="'listbox'"
|
1550
|
+
[attr.aria-expanded]="overlayVisible"
|
1551
|
+
[attr.aria-controls]="id + '_list'"
|
1552
|
+
[attr.tabindex]="!disabled ? tabindex : -1"
|
1553
|
+
[attr.aria-activedescendant]="focused ? focusedOptionId : undefined"
|
1191
1554
|
(focus)="onInputFocus($event)"
|
1192
1555
|
(blur)="onInputBlur($event)"
|
1193
|
-
|
1194
|
-
[attr.tabindex]="tabindex"
|
1195
|
-
(keydown)="onKeydown($event)"
|
1196
|
-
aria-haspopup="listbox"
|
1197
|
-
[attr.aria-expanded]="overlayVisible"
|
1198
|
-
[attr.aria-labelledby]="ariaLabelledBy"
|
1199
|
-
role="listbox"
|
1556
|
+
(keydown)="onKeyDown($event)"
|
1200
1557
|
/>
|
1201
1558
|
</div>
|
1202
1559
|
<div class="p-multiselect-label-container" [pTooltip]="tooltip" [tooltipPosition]="tooltipPosition" [positionStyle]="tooltipPositionStyle" [tooltipStyleClass]="tooltipStyleClass">
|
1203
|
-
<div
|
1204
|
-
class="p-multiselect-label"
|
1205
|
-
[ngClass]="{ 'p-placeholder': valuesAsString === (defaultLabel || placeholder), 'p-multiselect-label-empty': (valuesAsString == null || valuesAsString.length === 0) && (placeholder == null || placeholder.length === 0) }"
|
1206
|
-
>
|
1560
|
+
<div [ngClass]="labelClass">
|
1207
1561
|
<ng-container *ngIf="!selectedItemsTemplate">
|
1208
|
-
<ng-container *ngIf="display === 'comma'">{{
|
1562
|
+
<ng-container *ngIf="display === 'comma'">{{ label() || 'empty' }}</ng-container>
|
1209
1563
|
<ng-container *ngIf="display === 'chip'">
|
1210
|
-
<div #token *ngFor="let item of
|
1211
|
-
<span class="p-multiselect-token-label">{{
|
1564
|
+
<div #token *ngFor="let item of chipSelectedItems(); let i = index" class="p-multiselect-token">
|
1565
|
+
<span class="p-multiselect-token-label">{{ getLabelByValue(item) }}</span>
|
1212
1566
|
<ng-container *ngIf="!disabled">
|
1213
|
-
<TimesCircleIcon *ngIf="!removeTokenIconTemplate" [styleClass]="'p-multiselect-token-icon'" (click)="
|
1214
|
-
<span *ngIf="removeTokenIconTemplate" class="p-multiselect-token-icon" (click)="
|
1567
|
+
<TimesCircleIcon *ngIf="!removeTokenIconTemplate" [styleClass]="'p-multiselect-token-icon'" (click)="removeOption(item, event)" [attr.data-pc-section]="'clearicon'" [attr.aria-hidden]="true" />
|
1568
|
+
<span *ngIf="removeTokenIconTemplate" class="p-multiselect-token-icon" (click)="removeOption(item, event)" [attr.data-pc-section]="'clearicon'" [attr.aria-hidden]="true">
|
1215
1569
|
<ng-container *ngTemplateOutlet="removeTokenIconTemplate"></ng-container>
|
1216
1570
|
</span>
|
1217
1571
|
</ng-container>
|
1218
1572
|
</div>
|
1219
|
-
<ng-container *ngIf="!
|
1573
|
+
<ng-container *ngIf="!modelValue() || modelValue().length === 0">{{ placeholder || defaultLabel || 'empty' }}</ng-container>
|
1220
1574
|
</ng-container>
|
1221
1575
|
</ng-container>
|
1222
|
-
<ng-container *ngTemplateOutlet="selectedItemsTemplate; context: { $implicit:
|
1576
|
+
<ng-container *ngTemplateOutlet="selectedItemsTemplate; context: { $implicit: modelValue(), removeChip: removeOption.bind(this) }"></ng-container>
|
1223
1577
|
</div>
|
1224
|
-
<ng-container *ngIf="
|
1225
|
-
<TimesIcon *ngIf="!clearIconTemplate" [styleClass]="'p-multiselect-clear-icon'" (click)="clear($event)" />
|
1226
|
-
<span *ngIf="clearIconTemplate" class="p-multiselect-clear-icon" (click)="clear($event)">
|
1578
|
+
<ng-container *ngIf="modelValue() != null && filled && !disabled && showClear">
|
1579
|
+
<TimesIcon *ngIf="!clearIconTemplate" [styleClass]="'p-multiselect-clear-icon'" (click)="clear($event)" [attr.data-pc-section]="'clearicon'" [attr.aria-hidden]="true" />
|
1580
|
+
<span *ngIf="clearIconTemplate" class="p-multiselect-clear-icon" (click)="clear($event)" [attr.data-pc-section]="'clearicon'" [attr.aria-hidden]="true">
|
1227
1581
|
<ng-template *ngTemplateOutlet="clearIconTemplate"></ng-template>
|
1228
1582
|
</span>
|
1229
1583
|
</ng-container>
|
1230
1584
|
</div>
|
1231
|
-
<div
|
1585
|
+
<div class="p-multiselect-trigger">
|
1232
1586
|
<ng-container *ngIf="!dropdownIconTemplate">
|
1233
|
-
<span *ngIf="dropdownIcon" class="p-multiselect-trigger-icon" [ngClass]="dropdownIcon"></span>
|
1234
|
-
<ChevronDownIcon *ngIf="!dropdownIcon" [styleClass]="'p-multiselect-trigger-icon'" />
|
1587
|
+
<span *ngIf="dropdownIcon" class="p-multiselect-trigger-icon" [ngClass]="dropdownIcon" [attr.data-pc-section]="'triggericon'" [attr.aria-hidden]="true"></span>
|
1588
|
+
<ChevronDownIcon *ngIf="!dropdownIcon" [styleClass]="'p-multiselect-trigger-icon'" [attr.data-pc-section]="'triggericon'" [attr.aria-hidden]="true" />
|
1235
1589
|
</ng-container>
|
1236
|
-
<span *ngIf="dropdownIconTemplate" class="p-multiselect-trigger-icon">
|
1590
|
+
<span *ngIf="dropdownIconTemplate" class="p-multiselect-trigger-icon" [attr.data-pc-section]="'triggericon'" [attr.aria-hidden]="true">
|
1237
1591
|
<ng-template *ngTemplateOutlet="dropdownIconTemplate"></ng-template>
|
1238
1592
|
</span>
|
1239
1593
|
</div>
|
@@ -1251,7 +1605,18 @@ class MultiSelect {
|
|
1251
1605
|
(onHide)="hide()"
|
1252
1606
|
>
|
1253
1607
|
<ng-template pTemplate="content">
|
1254
|
-
<div [ngClass]="
|
1608
|
+
<div [ngClass]="'p-multiselect-panel p-component'" [ngStyle]="panelStyle" [class]="panelStyleClass">
|
1609
|
+
<span
|
1610
|
+
#firstHiddenFocusableEl
|
1611
|
+
role="presentation"
|
1612
|
+
[attr.aria-hidden]="'true'"
|
1613
|
+
class="p-hidden-accessible p-hidden-focusable"
|
1614
|
+
[attr.tabindex]="0"
|
1615
|
+
(focus)="onFirstHiddenFocus($event)"
|
1616
|
+
[attr.data-p-hidden-accessible]="true"
|
1617
|
+
[attr.data-p-hidden-focusable]="true"
|
1618
|
+
>
|
1619
|
+
</span>
|
1255
1620
|
<div class="p-multiselect-header" *ngIf="showHeader">
|
1256
1621
|
<ng-content select="p-header"></ng-content>
|
1257
1622
|
<ng-container *ngTemplateOutlet="headerTemplate"></ng-container>
|
@@ -1259,28 +1624,29 @@ class MultiSelect {
|
|
1259
1624
|
<ng-container *ngTemplateOutlet="filterTemplate; context: { options: filterOptions }"></ng-container>
|
1260
1625
|
</ng-container>
|
1261
1626
|
<ng-template #builtInFilterElement>
|
1262
|
-
<div
|
1263
|
-
|
1627
|
+
<div
|
1628
|
+
class="p-checkbox p-component"
|
1629
|
+
*ngIf="showToggleAll && !selectionLimit"
|
1630
|
+
[ngClass]="{ 'p-checkbox-disabled': disabled || toggleAllDisabled }"
|
1631
|
+
(click)="onToggleAll($event)"
|
1632
|
+
(keydown)="onHeaderCheckboxKeyDown($event)"
|
1633
|
+
>
|
1634
|
+
<div class="p-hidden-accessible" [attr.data-p-hidden-accessible]="true">
|
1264
1635
|
<input
|
1636
|
+
#headerCheckbox
|
1265
1637
|
type="checkbox"
|
1266
|
-
readonly="readonly"
|
1267
|
-
[checked]="
|
1638
|
+
[readonly]="readonly"
|
1639
|
+
[attr.checked]="allSelected()"
|
1268
1640
|
(focus)="onHeaderCheckboxFocus()"
|
1269
1641
|
(blur)="onHeaderCheckboxBlur()"
|
1270
|
-
(keydown.space)="toggleAll($event)"
|
1271
1642
|
[disabled]="disabled || toggleAllDisabled"
|
1643
|
+
[attr.aria-label]="toggleAllAriaLabel"
|
1272
1644
|
/>
|
1273
1645
|
</div>
|
1274
|
-
<div
|
1275
|
-
|
1276
|
-
|
1277
|
-
|
1278
|
-
[ngClass]="{ 'p-highlight': allChecked, 'p-focus': headerCheckboxFocus, 'p-disabled': disabled || toggleAllDisabled }"
|
1279
|
-
(click)="toggleAll($event)"
|
1280
|
-
>
|
1281
|
-
<ng-container *ngIf="allChecked">
|
1282
|
-
<CheckIcon [styleClass]="'p-checkbox-icon'" *ngIf="!checkIconTemplate" />
|
1283
|
-
<span *ngIf="checkIconTemplate" class="p-checkbox-icon">
|
1646
|
+
<div class="p-checkbox-box" role="checkbox" [attr.aria-checked]="allSelected()" [ngClass]="{ 'p-highlight': allSelected(), 'p-focus': headerCheckboxFocus, 'p-disabled': disabled || toggleAllDisabled }">
|
1647
|
+
<ng-container *ngIf="allSelected()">
|
1648
|
+
<CheckIcon [styleClass]="'p-checkbox-icon'" *ngIf="!checkIconTemplate" [attr.aria-hidden]="true" />
|
1649
|
+
<span *ngIf="checkIconTemplate" class="p-checkbox-icon" [attr.aria-hidden]="true">
|
1284
1650
|
<ng-template *ngTemplateOutlet="checkIconTemplate"></ng-template>
|
1285
1651
|
</span>
|
1286
1652
|
</ng-container>
|
@@ -1291,9 +1657,14 @@ class MultiSelect {
|
|
1291
1657
|
#filterInput
|
1292
1658
|
type="text"
|
1293
1659
|
[attr.autocomplete]="autocomplete"
|
1294
|
-
|
1295
|
-
|
1660
|
+
[attr.placeholder]="filterPlaceHolder"
|
1661
|
+
role="searchbox"
|
1662
|
+
[attr.aria-owns]="id + '_list'"
|
1663
|
+
[attr.aria-activedescendant]="focusedOptionId"
|
1664
|
+
[value]="_filterValue() || ''"
|
1296
1665
|
(input)="onFilterInputChange($event)"
|
1666
|
+
(keydown)="onFilterKeyDown($event)"
|
1667
|
+
(blur)="onFilterBlur($event)"
|
1297
1668
|
class="p-multiselect-filter p-inputtext p-component"
|
1298
1669
|
[disabled]="disabled"
|
1299
1670
|
[attr.placeholder]="filterPlaceHolder"
|
@@ -1317,7 +1688,7 @@ class MultiSelect {
|
|
1317
1688
|
<p-scroller
|
1318
1689
|
*ngIf="virtualScroll"
|
1319
1690
|
#scroller
|
1320
|
-
[items]="
|
1691
|
+
[items]="visibleOptions()"
|
1321
1692
|
[style]="{ height: scrollHeight }"
|
1322
1693
|
[itemSize]="virtualScrollItemSize || _itemSize"
|
1323
1694
|
[autoSize]="true"
|
@@ -1336,38 +1707,37 @@ class MultiSelect {
|
|
1336
1707
|
</ng-container>
|
1337
1708
|
</p-scroller>
|
1338
1709
|
<ng-container *ngIf="!virtualScroll">
|
1339
|
-
<ng-container *ngTemplateOutlet="buildInItems; context: { $implicit:
|
1710
|
+
<ng-container *ngTemplateOutlet="buildInItems; context: { $implicit: visibleOptions(), options: {} }"></ng-container>
|
1340
1711
|
</ng-container>
|
1341
1712
|
|
1342
1713
|
<ng-template #buildInItems let-items let-scrollerOptions="options">
|
1343
1714
|
<ul #items class="p-multiselect-items p-component" [ngClass]="scrollerOptions.contentStyleClass" [style]="scrollerOptions.contentStyle" role="listbox" aria-multiselectable="true">
|
1344
|
-
<ng-
|
1345
|
-
<ng-
|
1346
|
-
<li class="p-multiselect-item-group" [ngStyle]="{ height: scrollerOptions.itemSize + 'px' }">
|
1347
|
-
<span *ngIf="!groupTemplate">{{ getOptionGroupLabel(
|
1348
|
-
<ng-container *ngTemplateOutlet="groupTemplate; context: { $implicit:
|
1715
|
+
<ng-template ngFor let-option [ngForOf]="items" let-i="index">
|
1716
|
+
<ng-container *ngIf="option.group">
|
1717
|
+
<li [attr.id]="id + '_' + getOptionIndex(i, scrollerOptions)" class="p-multiselect-item-group" [ngStyle]="{ height: scrollerOptions.itemSize + 'px' }" role="option">
|
1718
|
+
<span *ngIf="!groupTemplate">{{ getOptionGroupLabel(option.optionGroup) }}</span>
|
1719
|
+
<ng-container *ngTemplateOutlet="groupTemplate; context: { $implicit: option.optionGroup }"></ng-container>
|
1349
1720
|
</li>
|
1350
|
-
|
1351
|
-
|
1352
|
-
</ng-container>
|
1353
|
-
<ng-container *ngIf="!group">
|
1354
|
-
<ng-container *ngTemplateOutlet="itemslist; context: { $implicit: items }"></ng-container>
|
1355
|
-
</ng-container>
|
1356
|
-
<ng-template #itemslist let-optionsToDisplay let-selectedOption="selectedOption">
|
1357
|
-
<ng-template ngFor let-option let-i="index" [ngForOf]="optionsToDisplay">
|
1721
|
+
</ng-container>
|
1722
|
+
<ng-container *ngIf="!option.group">
|
1358
1723
|
<p-multiSelectItem
|
1724
|
+
[id]="id + '_' + getOptionIndex(i, scrollerOptions)"
|
1359
1725
|
[option]="option"
|
1360
1726
|
[selected]="isSelected(option)"
|
1361
1727
|
[label]="getOptionLabel(option)"
|
1362
1728
|
[disabled]="isOptionDisabled(option)"
|
1363
|
-
(onClick)="onOptionClick($event)"
|
1364
|
-
(onKeydown)="onOptionKeydown($event)"
|
1365
1729
|
[template]="itemTemplate"
|
1366
1730
|
[checkIconTemplate]="checkIconTemplate"
|
1367
1731
|
[itemSize]="scrollerOptions.itemSize"
|
1732
|
+
[focused]="focusedOptionIndex() === getOptionIndex(i, scrollerOptions)"
|
1733
|
+
[ariaPosInset]="getAriaPosInset(getOptionIndex(i, scrollerOptions))"
|
1734
|
+
[ariaSetSize]="ariaSetSize"
|
1735
|
+
(onClick)="onOptionSelect($event, false, getOptionIndex(i, scrollerOptions))"
|
1736
|
+
(onMouseEnter)="onOptionMouseEnter($event, getOptionIndex(i, scrollerOptions))"
|
1368
1737
|
></p-multiSelectItem>
|
1369
|
-
</ng-
|
1738
|
+
</ng-container>
|
1370
1739
|
</ng-template>
|
1740
|
+
|
1371
1741
|
<li *ngIf="hasFilter() && isEmpty()" class="p-multiselect-empty-message" [ngStyle]="{ height: scrollerOptions.itemSize + 'px' }">
|
1372
1742
|
<ng-container *ngIf="!emptyFilterTemplate && !emptyTemplate; else emptyFilter">
|
1373
1743
|
{{ emptyFilterMessageLabel }}
|
@@ -1387,77 +1757,82 @@ class MultiSelect {
|
|
1387
1757
|
<ng-content select="p-footer"></ng-content>
|
1388
1758
|
<ng-container *ngTemplateOutlet="footerTemplate"></ng-container>
|
1389
1759
|
</div>
|
1760
|
+
|
1761
|
+
<span
|
1762
|
+
#lastHiddenFocusableEl
|
1763
|
+
role="presentation"
|
1764
|
+
[attr.aria-hidden]="true"
|
1765
|
+
class="p-hidden-accessible p-hidden-focusable"
|
1766
|
+
[attr.tabindex]="0"
|
1767
|
+
(focus)="onLastHiddenFocus($event)"
|
1768
|
+
[attr.data-p-hidden-accessible]="true"
|
1769
|
+
[attr.data-p-hidden-focusable]="true"
|
1770
|
+
></span>
|
1390
1771
|
</div>
|
1391
1772
|
</ng-template>
|
1392
1773
|
</p-overlay>
|
1393
1774
|
</div>
|
1394
|
-
`, isInline: true, styles: ["@layer primeng{.p-multiselect{display:inline-flex;cursor:pointer;position:relative;-webkit-user-select:none;user-select:none}.p-multiselect-trigger{display:flex;align-items:center;justify-content:center;flex-shrink:0}.p-multiselect-label-container{overflow:hidden;flex:1 1 auto;cursor:pointer;display:flex}.p-multiselect-label{display:block;white-space:nowrap;cursor:pointer;overflow:hidden;text-overflow:ellipsis}.p-multiselect-label-empty{overflow:hidden;visibility:hidden}.p-multiselect-token{cursor:default;display:inline-flex;align-items:center;flex:0 0 auto}.p-multiselect-token-icon{cursor:pointer}.p-multiselect-token-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100px}.p-multiselect-items-wrapper{overflow:auto}.p-multiselect-items{margin:0;padding:0;list-style-type:none}.p-multiselect-item{cursor:pointer;display:flex;align-items:center;font-weight:400;white-space:nowrap;position:relative;overflow:hidden}.p-multiselect-header{display:flex;align-items:center;justify-content:space-between}.p-multiselect-filter-container{position:relative;flex:1 1 auto}.p-multiselect-filter-icon{position:absolute;top:50%;margin-top:-.5rem}.p-multiselect-filter-container .p-inputtext{width:100%}.p-multiselect-close{display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;position:relative}.p-fluid .p-multiselect{display:flex}.p-multiselect-clear-icon{position:absolute;top:50%;margin-top:-.5rem;cursor:pointer}.p-multiselect-clearable{position:relative}}\n"], dependencies: [{ kind: "directive", type: i0.forwardRef(function () { return i1.NgClass; }), selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgForOf; }), selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgTemplateOutlet; }), selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgStyle; }), selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i0.forwardRef(function () { return i4.Overlay; }), selector: "p-overlay", inputs: ["visible", "mode", "style", "styleClass", "contentStyle", "contentStyleClass", "target", "appendTo", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "listener", "responsive", "options"], outputs: ["visibleChange", "onBeforeShow", "onShow", "onBeforeHide", "onHide", "onAnimationStart", "onAnimationDone"] }, { kind: "directive", type: i0.forwardRef(function () { return i3.PrimeTemplate; }), selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "directive", type: i0.forwardRef(function () { return i5.Tooltip; }), selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.Ripple; }), selector: "[pRipple]" }, { kind: "component", type: i0.forwardRef(function () { return i6.Scroller; }), selector: "p-scroller", inputs: ["id", "style", "styleClass", "tabindex", "items", "itemSize", "scrollHeight", "scrollWidth", "orientation", "step", "delay", "resizeDelay", "appendOnly", "inline", "lazy", "disabled", "loaderDisabled", "columns", "showSpacer", "showLoader", "numToleratedItems", "loading", "autoSize", "trackBy", "options"], outputs: ["onLazyLoad", "onScroll", "onScrollIndexChange"] }, { kind: "component", type: i0.forwardRef(function () { return CheckIcon; }), selector: "CheckIcon" }, { kind: "component", type: i0.forwardRef(function () { return SearchIcon; }), selector: "SearchIcon" }, { kind: "component", type: i0.forwardRef(function () { return TimesCircleIcon; }), selector: "TimesCircleIcon" }, { kind: "component", type: i0.forwardRef(function () { return TimesIcon; }), selector: "TimesIcon" }, { kind: "component", type: i0.forwardRef(function () { return ChevronDownIcon; }), selector: "ChevronDownIcon" }, { kind: "component", type: i0.forwardRef(function () { return MultiSelectItem; }), selector: "p-multiSelectItem", inputs: ["option", "selected", "label", "disabled", "itemSize", "template", "checkIconTemplate"], outputs: ["onClick", "
|
1775
|
+
`, isInline: true, styles: ["@layer primeng{.p-multiselect{display:inline-flex;cursor:pointer;position:relative;-webkit-user-select:none;user-select:none}.p-multiselect-trigger{display:flex;align-items:center;justify-content:center;flex-shrink:0}.p-multiselect-label-container{overflow:hidden;flex:1 1 auto;cursor:pointer;display:flex}.p-multiselect-label{display:block;white-space:nowrap;cursor:pointer;overflow:hidden;text-overflow:ellipsis}.p-multiselect-label-empty{overflow:hidden;visibility:hidden}.p-multiselect-token{cursor:default;display:inline-flex;align-items:center;flex:0 0 auto}.p-multiselect-token-icon{cursor:pointer}.p-multiselect-token-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100px}.p-multiselect-items-wrapper{overflow:auto}.p-multiselect-items{margin:0;padding:0;list-style-type:none}.p-multiselect-item{cursor:pointer;display:flex;align-items:center;font-weight:400;white-space:nowrap;position:relative;overflow:hidden}.p-multiselect-header{display:flex;align-items:center;justify-content:space-between}.p-multiselect-filter-container{position:relative;flex:1 1 auto}.p-multiselect-filter-icon{position:absolute;top:50%;margin-top:-.5rem}.p-multiselect-filter-container .p-inputtext{width:100%}.p-multiselect-close{display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;position:relative}.p-fluid .p-multiselect{display:flex}.p-multiselect-clear-icon{position:absolute;top:50%;margin-top:-.5rem;cursor:pointer}.p-multiselect-clearable{position:relative}}\n"], dependencies: [{ kind: "directive", type: i0.forwardRef(function () { return i1.NgClass; }), selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgForOf; }), selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgTemplateOutlet; }), selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgStyle; }), selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i0.forwardRef(function () { return i4.Overlay; }), selector: "p-overlay", inputs: ["visible", "mode", "style", "styleClass", "contentStyle", "contentStyleClass", "target", "appendTo", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "listener", "responsive", "options"], outputs: ["visibleChange", "onBeforeShow", "onShow", "onBeforeHide", "onHide", "onAnimationStart", "onAnimationDone"] }, { kind: "directive", type: i0.forwardRef(function () { return i3.PrimeTemplate; }), selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "directive", type: i0.forwardRef(function () { return i5.Tooltip; }), selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.Ripple; }), selector: "[pRipple]" }, { kind: "component", type: i0.forwardRef(function () { return i6.Scroller; }), selector: "p-scroller", inputs: ["id", "style", "styleClass", "tabindex", "items", "itemSize", "scrollHeight", "scrollWidth", "orientation", "step", "delay", "resizeDelay", "appendOnly", "inline", "lazy", "disabled", "loaderDisabled", "columns", "showSpacer", "showLoader", "numToleratedItems", "loading", "autoSize", "trackBy", "options"], outputs: ["onLazyLoad", "onScroll", "onScrollIndexChange"] }, { kind: "component", type: i0.forwardRef(function () { return CheckIcon; }), selector: "CheckIcon" }, { kind: "component", type: i0.forwardRef(function () { return SearchIcon; }), selector: "SearchIcon" }, { kind: "component", type: i0.forwardRef(function () { return TimesCircleIcon; }), selector: "TimesCircleIcon" }, { kind: "component", type: i0.forwardRef(function () { return TimesIcon; }), selector: "TimesIcon" }, { kind: "component", type: i0.forwardRef(function () { return ChevronDownIcon; }), selector: "ChevronDownIcon" }, { kind: "component", type: i0.forwardRef(function () { return MultiSelectItem; }), selector: "p-multiSelectItem", inputs: ["id", "option", "selected", "label", "disabled", "itemSize", "focused", "ariaPosInset", "ariaSetSize", "template", "checkIconTemplate"], outputs: ["onClick", "onMouseEnter"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
1395
1776
|
}
|
1396
1777
|
export { MultiSelect };
|
1397
1778
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: MultiSelect, decorators: [{
|
1398
1779
|
type: Component,
|
1399
1780
|
args: [{ selector: 'p-multiSelect', template: `
|
1400
|
-
<div
|
1401
|
-
|
1402
|
-
[ngClass]="{ 'p-multiselect p-component': true, 'p-multiselect-open': overlayVisible, 'p-multiselect-chip': display === 'chip', 'p-focus': focus, 'p-disabled': disabled }"
|
1403
|
-
[ngStyle]="style"
|
1404
|
-
[class]="styleClass"
|
1405
|
-
(click)="onMouseclick($event, in)"
|
1406
|
-
>
|
1407
|
-
<div class="p-hidden-accessible">
|
1781
|
+
<div #container [attr.id]="id" [ngClass]="containerClass" [ngStyle]="style" [class]="styleClass" (click)="onContainerClick($event)">
|
1782
|
+
<div class="p-hidden-accessible" [attr.data-p-hidden-accessible]="true">
|
1408
1783
|
<input
|
1409
|
-
#
|
1410
|
-
|
1411
|
-
[
|
1412
|
-
|
1784
|
+
#focusInput
|
1785
|
+
[pTooltip]="tooltip"
|
1786
|
+
[tooltipPosition]="tooltipPosition"
|
1787
|
+
[positionStyle]="tooltipPositionStyle"
|
1788
|
+
[tooltipStyleClass]="tooltipStyleClass"
|
1789
|
+
[attr.aria-disabled]="disabled"
|
1413
1790
|
[attr.id]="inputId"
|
1414
|
-
|
1791
|
+
role="combobox"
|
1792
|
+
[attr.aria-label]="ariaLabel"
|
1793
|
+
[attr.aria-labelledby]="ariaLabelledBy"
|
1794
|
+
[attr.aria-haspopup]="'listbox'"
|
1795
|
+
[attr.aria-expanded]="overlayVisible"
|
1796
|
+
[attr.aria-controls]="id + '_list'"
|
1797
|
+
[attr.tabindex]="!disabled ? tabindex : -1"
|
1798
|
+
[attr.aria-activedescendant]="focused ? focusedOptionId : undefined"
|
1415
1799
|
(focus)="onInputFocus($event)"
|
1416
1800
|
(blur)="onInputBlur($event)"
|
1417
|
-
|
1418
|
-
[attr.tabindex]="tabindex"
|
1419
|
-
(keydown)="onKeydown($event)"
|
1420
|
-
aria-haspopup="listbox"
|
1421
|
-
[attr.aria-expanded]="overlayVisible"
|
1422
|
-
[attr.aria-labelledby]="ariaLabelledBy"
|
1423
|
-
role="listbox"
|
1801
|
+
(keydown)="onKeyDown($event)"
|
1424
1802
|
/>
|
1425
1803
|
</div>
|
1426
1804
|
<div class="p-multiselect-label-container" [pTooltip]="tooltip" [tooltipPosition]="tooltipPosition" [positionStyle]="tooltipPositionStyle" [tooltipStyleClass]="tooltipStyleClass">
|
1427
|
-
<div
|
1428
|
-
class="p-multiselect-label"
|
1429
|
-
[ngClass]="{ 'p-placeholder': valuesAsString === (defaultLabel || placeholder), 'p-multiselect-label-empty': (valuesAsString == null || valuesAsString.length === 0) && (placeholder == null || placeholder.length === 0) }"
|
1430
|
-
>
|
1805
|
+
<div [ngClass]="labelClass">
|
1431
1806
|
<ng-container *ngIf="!selectedItemsTemplate">
|
1432
|
-
<ng-container *ngIf="display === 'comma'">{{
|
1807
|
+
<ng-container *ngIf="display === 'comma'">{{ label() || 'empty' }}</ng-container>
|
1433
1808
|
<ng-container *ngIf="display === 'chip'">
|
1434
|
-
<div #token *ngFor="let item of
|
1435
|
-
<span class="p-multiselect-token-label">{{
|
1809
|
+
<div #token *ngFor="let item of chipSelectedItems(); let i = index" class="p-multiselect-token">
|
1810
|
+
<span class="p-multiselect-token-label">{{ getLabelByValue(item) }}</span>
|
1436
1811
|
<ng-container *ngIf="!disabled">
|
1437
|
-
<TimesCircleIcon *ngIf="!removeTokenIconTemplate" [styleClass]="'p-multiselect-token-icon'" (click)="
|
1438
|
-
<span *ngIf="removeTokenIconTemplate" class="p-multiselect-token-icon" (click)="
|
1812
|
+
<TimesCircleIcon *ngIf="!removeTokenIconTemplate" [styleClass]="'p-multiselect-token-icon'" (click)="removeOption(item, event)" [attr.data-pc-section]="'clearicon'" [attr.aria-hidden]="true" />
|
1813
|
+
<span *ngIf="removeTokenIconTemplate" class="p-multiselect-token-icon" (click)="removeOption(item, event)" [attr.data-pc-section]="'clearicon'" [attr.aria-hidden]="true">
|
1439
1814
|
<ng-container *ngTemplateOutlet="removeTokenIconTemplate"></ng-container>
|
1440
1815
|
</span>
|
1441
1816
|
</ng-container>
|
1442
1817
|
</div>
|
1443
|
-
<ng-container *ngIf="!
|
1818
|
+
<ng-container *ngIf="!modelValue() || modelValue().length === 0">{{ placeholder || defaultLabel || 'empty' }}</ng-container>
|
1444
1819
|
</ng-container>
|
1445
1820
|
</ng-container>
|
1446
|
-
<ng-container *ngTemplateOutlet="selectedItemsTemplate; context: { $implicit:
|
1821
|
+
<ng-container *ngTemplateOutlet="selectedItemsTemplate; context: { $implicit: modelValue(), removeChip: removeOption.bind(this) }"></ng-container>
|
1447
1822
|
</div>
|
1448
|
-
<ng-container *ngIf="
|
1449
|
-
<TimesIcon *ngIf="!clearIconTemplate" [styleClass]="'p-multiselect-clear-icon'" (click)="clear($event)" />
|
1450
|
-
<span *ngIf="clearIconTemplate" class="p-multiselect-clear-icon" (click)="clear($event)">
|
1823
|
+
<ng-container *ngIf="modelValue() != null && filled && !disabled && showClear">
|
1824
|
+
<TimesIcon *ngIf="!clearIconTemplate" [styleClass]="'p-multiselect-clear-icon'" (click)="clear($event)" [attr.data-pc-section]="'clearicon'" [attr.aria-hidden]="true" />
|
1825
|
+
<span *ngIf="clearIconTemplate" class="p-multiselect-clear-icon" (click)="clear($event)" [attr.data-pc-section]="'clearicon'" [attr.aria-hidden]="true">
|
1451
1826
|
<ng-template *ngTemplateOutlet="clearIconTemplate"></ng-template>
|
1452
1827
|
</span>
|
1453
1828
|
</ng-container>
|
1454
1829
|
</div>
|
1455
|
-
<div
|
1830
|
+
<div class="p-multiselect-trigger">
|
1456
1831
|
<ng-container *ngIf="!dropdownIconTemplate">
|
1457
|
-
<span *ngIf="dropdownIcon" class="p-multiselect-trigger-icon" [ngClass]="dropdownIcon"></span>
|
1458
|
-
<ChevronDownIcon *ngIf="!dropdownIcon" [styleClass]="'p-multiselect-trigger-icon'" />
|
1832
|
+
<span *ngIf="dropdownIcon" class="p-multiselect-trigger-icon" [ngClass]="dropdownIcon" [attr.data-pc-section]="'triggericon'" [attr.aria-hidden]="true"></span>
|
1833
|
+
<ChevronDownIcon *ngIf="!dropdownIcon" [styleClass]="'p-multiselect-trigger-icon'" [attr.data-pc-section]="'triggericon'" [attr.aria-hidden]="true" />
|
1459
1834
|
</ng-container>
|
1460
|
-
<span *ngIf="dropdownIconTemplate" class="p-multiselect-trigger-icon">
|
1835
|
+
<span *ngIf="dropdownIconTemplate" class="p-multiselect-trigger-icon" [attr.data-pc-section]="'triggericon'" [attr.aria-hidden]="true">
|
1461
1836
|
<ng-template *ngTemplateOutlet="dropdownIconTemplate"></ng-template>
|
1462
1837
|
</span>
|
1463
1838
|
</div>
|
@@ -1475,7 +1850,18 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
|
|
1475
1850
|
(onHide)="hide()"
|
1476
1851
|
>
|
1477
1852
|
<ng-template pTemplate="content">
|
1478
|
-
<div [ngClass]="
|
1853
|
+
<div [ngClass]="'p-multiselect-panel p-component'" [ngStyle]="panelStyle" [class]="panelStyleClass">
|
1854
|
+
<span
|
1855
|
+
#firstHiddenFocusableEl
|
1856
|
+
role="presentation"
|
1857
|
+
[attr.aria-hidden]="'true'"
|
1858
|
+
class="p-hidden-accessible p-hidden-focusable"
|
1859
|
+
[attr.tabindex]="0"
|
1860
|
+
(focus)="onFirstHiddenFocus($event)"
|
1861
|
+
[attr.data-p-hidden-accessible]="true"
|
1862
|
+
[attr.data-p-hidden-focusable]="true"
|
1863
|
+
>
|
1864
|
+
</span>
|
1479
1865
|
<div class="p-multiselect-header" *ngIf="showHeader">
|
1480
1866
|
<ng-content select="p-header"></ng-content>
|
1481
1867
|
<ng-container *ngTemplateOutlet="headerTemplate"></ng-container>
|
@@ -1483,28 +1869,29 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
|
|
1483
1869
|
<ng-container *ngTemplateOutlet="filterTemplate; context: { options: filterOptions }"></ng-container>
|
1484
1870
|
</ng-container>
|
1485
1871
|
<ng-template #builtInFilterElement>
|
1486
|
-
<div
|
1487
|
-
|
1872
|
+
<div
|
1873
|
+
class="p-checkbox p-component"
|
1874
|
+
*ngIf="showToggleAll && !selectionLimit"
|
1875
|
+
[ngClass]="{ 'p-checkbox-disabled': disabled || toggleAllDisabled }"
|
1876
|
+
(click)="onToggleAll($event)"
|
1877
|
+
(keydown)="onHeaderCheckboxKeyDown($event)"
|
1878
|
+
>
|
1879
|
+
<div class="p-hidden-accessible" [attr.data-p-hidden-accessible]="true">
|
1488
1880
|
<input
|
1881
|
+
#headerCheckbox
|
1489
1882
|
type="checkbox"
|
1490
|
-
readonly="readonly"
|
1491
|
-
[checked]="
|
1883
|
+
[readonly]="readonly"
|
1884
|
+
[attr.checked]="allSelected()"
|
1492
1885
|
(focus)="onHeaderCheckboxFocus()"
|
1493
1886
|
(blur)="onHeaderCheckboxBlur()"
|
1494
|
-
(keydown.space)="toggleAll($event)"
|
1495
1887
|
[disabled]="disabled || toggleAllDisabled"
|
1888
|
+
[attr.aria-label]="toggleAllAriaLabel"
|
1496
1889
|
/>
|
1497
1890
|
</div>
|
1498
|
-
<div
|
1499
|
-
|
1500
|
-
|
1501
|
-
|
1502
|
-
[ngClass]="{ 'p-highlight': allChecked, 'p-focus': headerCheckboxFocus, 'p-disabled': disabled || toggleAllDisabled }"
|
1503
|
-
(click)="toggleAll($event)"
|
1504
|
-
>
|
1505
|
-
<ng-container *ngIf="allChecked">
|
1506
|
-
<CheckIcon [styleClass]="'p-checkbox-icon'" *ngIf="!checkIconTemplate" />
|
1507
|
-
<span *ngIf="checkIconTemplate" class="p-checkbox-icon">
|
1891
|
+
<div class="p-checkbox-box" role="checkbox" [attr.aria-checked]="allSelected()" [ngClass]="{ 'p-highlight': allSelected(), 'p-focus': headerCheckboxFocus, 'p-disabled': disabled || toggleAllDisabled }">
|
1892
|
+
<ng-container *ngIf="allSelected()">
|
1893
|
+
<CheckIcon [styleClass]="'p-checkbox-icon'" *ngIf="!checkIconTemplate" [attr.aria-hidden]="true" />
|
1894
|
+
<span *ngIf="checkIconTemplate" class="p-checkbox-icon" [attr.aria-hidden]="true">
|
1508
1895
|
<ng-template *ngTemplateOutlet="checkIconTemplate"></ng-template>
|
1509
1896
|
</span>
|
1510
1897
|
</ng-container>
|
@@ -1515,9 +1902,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
|
|
1515
1902
|
#filterInput
|
1516
1903
|
type="text"
|
1517
1904
|
[attr.autocomplete]="autocomplete"
|
1518
|
-
|
1519
|
-
|
1905
|
+
[attr.placeholder]="filterPlaceHolder"
|
1906
|
+
role="searchbox"
|
1907
|
+
[attr.aria-owns]="id + '_list'"
|
1908
|
+
[attr.aria-activedescendant]="focusedOptionId"
|
1909
|
+
[value]="_filterValue() || ''"
|
1520
1910
|
(input)="onFilterInputChange($event)"
|
1911
|
+
(keydown)="onFilterKeyDown($event)"
|
1912
|
+
(blur)="onFilterBlur($event)"
|
1521
1913
|
class="p-multiselect-filter p-inputtext p-component"
|
1522
1914
|
[disabled]="disabled"
|
1523
1915
|
[attr.placeholder]="filterPlaceHolder"
|
@@ -1541,7 +1933,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
|
|
1541
1933
|
<p-scroller
|
1542
1934
|
*ngIf="virtualScroll"
|
1543
1935
|
#scroller
|
1544
|
-
[items]="
|
1936
|
+
[items]="visibleOptions()"
|
1545
1937
|
[style]="{ height: scrollHeight }"
|
1546
1938
|
[itemSize]="virtualScrollItemSize || _itemSize"
|
1547
1939
|
[autoSize]="true"
|
@@ -1560,38 +1952,37 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
|
|
1560
1952
|
</ng-container>
|
1561
1953
|
</p-scroller>
|
1562
1954
|
<ng-container *ngIf="!virtualScroll">
|
1563
|
-
<ng-container *ngTemplateOutlet="buildInItems; context: { $implicit:
|
1955
|
+
<ng-container *ngTemplateOutlet="buildInItems; context: { $implicit: visibleOptions(), options: {} }"></ng-container>
|
1564
1956
|
</ng-container>
|
1565
1957
|
|
1566
1958
|
<ng-template #buildInItems let-items let-scrollerOptions="options">
|
1567
1959
|
<ul #items class="p-multiselect-items p-component" [ngClass]="scrollerOptions.contentStyleClass" [style]="scrollerOptions.contentStyle" role="listbox" aria-multiselectable="true">
|
1568
|
-
<ng-
|
1569
|
-
<ng-
|
1570
|
-
<li class="p-multiselect-item-group" [ngStyle]="{ height: scrollerOptions.itemSize + 'px' }">
|
1571
|
-
<span *ngIf="!groupTemplate">{{ getOptionGroupLabel(
|
1572
|
-
<ng-container *ngTemplateOutlet="groupTemplate; context: { $implicit:
|
1960
|
+
<ng-template ngFor let-option [ngForOf]="items" let-i="index">
|
1961
|
+
<ng-container *ngIf="option.group">
|
1962
|
+
<li [attr.id]="id + '_' + getOptionIndex(i, scrollerOptions)" class="p-multiselect-item-group" [ngStyle]="{ height: scrollerOptions.itemSize + 'px' }" role="option">
|
1963
|
+
<span *ngIf="!groupTemplate">{{ getOptionGroupLabel(option.optionGroup) }}</span>
|
1964
|
+
<ng-container *ngTemplateOutlet="groupTemplate; context: { $implicit: option.optionGroup }"></ng-container>
|
1573
1965
|
</li>
|
1574
|
-
|
1575
|
-
|
1576
|
-
</ng-container>
|
1577
|
-
<ng-container *ngIf="!group">
|
1578
|
-
<ng-container *ngTemplateOutlet="itemslist; context: { $implicit: items }"></ng-container>
|
1579
|
-
</ng-container>
|
1580
|
-
<ng-template #itemslist let-optionsToDisplay let-selectedOption="selectedOption">
|
1581
|
-
<ng-template ngFor let-option let-i="index" [ngForOf]="optionsToDisplay">
|
1966
|
+
</ng-container>
|
1967
|
+
<ng-container *ngIf="!option.group">
|
1582
1968
|
<p-multiSelectItem
|
1969
|
+
[id]="id + '_' + getOptionIndex(i, scrollerOptions)"
|
1583
1970
|
[option]="option"
|
1584
1971
|
[selected]="isSelected(option)"
|
1585
1972
|
[label]="getOptionLabel(option)"
|
1586
1973
|
[disabled]="isOptionDisabled(option)"
|
1587
|
-
(onClick)="onOptionClick($event)"
|
1588
|
-
(onKeydown)="onOptionKeydown($event)"
|
1589
1974
|
[template]="itemTemplate"
|
1590
1975
|
[checkIconTemplate]="checkIconTemplate"
|
1591
1976
|
[itemSize]="scrollerOptions.itemSize"
|
1977
|
+
[focused]="focusedOptionIndex() === getOptionIndex(i, scrollerOptions)"
|
1978
|
+
[ariaPosInset]="getAriaPosInset(getOptionIndex(i, scrollerOptions))"
|
1979
|
+
[ariaSetSize]="ariaSetSize"
|
1980
|
+
(onClick)="onOptionSelect($event, false, getOptionIndex(i, scrollerOptions))"
|
1981
|
+
(onMouseEnter)="onOptionMouseEnter($event, getOptionIndex(i, scrollerOptions))"
|
1592
1982
|
></p-multiSelectItem>
|
1593
|
-
</ng-
|
1983
|
+
</ng-container>
|
1594
1984
|
</ng-template>
|
1985
|
+
|
1595
1986
|
<li *ngIf="hasFilter() && isEmpty()" class="p-multiselect-empty-message" [ngStyle]="{ height: scrollerOptions.itemSize + 'px' }">
|
1596
1987
|
<ng-container *ngIf="!emptyFilterTemplate && !emptyTemplate; else emptyFilter">
|
1597
1988
|
{{ emptyFilterMessageLabel }}
|
@@ -1611,6 +2002,17 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
|
|
1611
2002
|
<ng-content select="p-footer"></ng-content>
|
1612
2003
|
<ng-container *ngTemplateOutlet="footerTemplate"></ng-container>
|
1613
2004
|
</div>
|
2005
|
+
|
2006
|
+
<span
|
2007
|
+
#lastHiddenFocusableEl
|
2008
|
+
role="presentation"
|
2009
|
+
[attr.aria-hidden]="true"
|
2010
|
+
class="p-hidden-accessible p-hidden-focusable"
|
2011
|
+
[attr.tabindex]="0"
|
2012
|
+
(focus)="onLastHiddenFocus($event)"
|
2013
|
+
[attr.data-p-hidden-accessible]="true"
|
2014
|
+
[attr.data-p-hidden-focusable]="true"
|
2015
|
+
></span>
|
1614
2016
|
</div>
|
1615
2017
|
</ng-template>
|
1616
2018
|
</p-overlay>
|
@@ -1618,10 +2020,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
|
|
1618
2020
|
`, host: {
|
1619
2021
|
class: 'p-element p-inputwrapper',
|
1620
2022
|
'[class.p-inputwrapper-filled]': 'filled',
|
1621
|
-
'[class.p-inputwrapper-focus]': '
|
1622
|
-
'[class.p-multiselect-clearable]': 'showClear && !disabled'
|
2023
|
+
'[class.p-inputwrapper-focus]': 'focused || overlayVisible'
|
1623
2024
|
}, providers: [MULTISELECT_VALUE_ACCESSOR], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, styles: ["@layer primeng{.p-multiselect{display:inline-flex;cursor:pointer;position:relative;-webkit-user-select:none;user-select:none}.p-multiselect-trigger{display:flex;align-items:center;justify-content:center;flex-shrink:0}.p-multiselect-label-container{overflow:hidden;flex:1 1 auto;cursor:pointer;display:flex}.p-multiselect-label{display:block;white-space:nowrap;cursor:pointer;overflow:hidden;text-overflow:ellipsis}.p-multiselect-label-empty{overflow:hidden;visibility:hidden}.p-multiselect-token{cursor:default;display:inline-flex;align-items:center;flex:0 0 auto}.p-multiselect-token-icon{cursor:pointer}.p-multiselect-token-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100px}.p-multiselect-items-wrapper{overflow:auto}.p-multiselect-items{margin:0;padding:0;list-style-type:none}.p-multiselect-item{cursor:pointer;display:flex;align-items:center;font-weight:400;white-space:nowrap;position:relative;overflow:hidden}.p-multiselect-header{display:flex;align-items:center;justify-content:space-between}.p-multiselect-filter-container{position:relative;flex:1 1 auto}.p-multiselect-filter-icon{position:absolute;top:50%;margin-top:-.5rem}.p-multiselect-filter-container .p-inputtext{width:100%}.p-multiselect-close{display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;position:relative}.p-fluid .p-multiselect{display:flex}.p-multiselect-clear-icon{position:absolute;top:50%;margin-top:-.5rem;cursor:pointer}.p-multiselect-clearable{position:relative}}\n"] }]
|
1624
|
-
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }, { type: i0.NgZone }, { type: i3.FilterService }, { type: i3.PrimeNGConfig }, { type: i3.OverlayService }]; }, propDecorators: {
|
2025
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }, { type: i0.NgZone }, { type: i3.FilterService }, { type: i3.PrimeNGConfig }, { type: i3.OverlayService }]; }, propDecorators: { id: [{
|
2026
|
+
type: Input
|
2027
|
+
}], ariaLabel: [{
|
2028
|
+
type: Input
|
2029
|
+
}], style: [{
|
1625
2030
|
type: Input
|
1626
2031
|
}], styleClass: [{
|
1627
2032
|
type: Input
|
@@ -1653,14 +2058,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
|
|
1653
2058
|
type: Input
|
1654
2059
|
}], name: [{
|
1655
2060
|
type: Input
|
1656
|
-
}], label: [{
|
1657
|
-
type: Input
|
1658
2061
|
}], ariaLabelledBy: [{
|
1659
2062
|
type: Input
|
1660
2063
|
}], displaySelectedLabel: [{
|
1661
2064
|
type: Input
|
1662
2065
|
}], maxSelectedLabels: [{
|
1663
2066
|
type: Input
|
2067
|
+
}], selectionLimit: [{
|
2068
|
+
type: Input
|
1664
2069
|
}], selectedItemsLabel: [{
|
1665
2070
|
type: Input
|
1666
2071
|
}], showToggleAll: [{
|
@@ -1737,8 +2142,34 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
|
|
1737
2142
|
type: Input
|
1738
2143
|
}], itemSize: [{
|
1739
2144
|
type: Input
|
1740
|
-
}],
|
2145
|
+
}], focusOnHover: [{
|
2146
|
+
type: Input
|
2147
|
+
}], filterFields: [{
|
2148
|
+
type: Input
|
2149
|
+
}], selectOnFocus: [{
|
2150
|
+
type: Input
|
2151
|
+
}], autoOptionFocus: [{
|
1741
2152
|
type: Input
|
2153
|
+
}], onChange: [{
|
2154
|
+
type: Output
|
2155
|
+
}], onFilter: [{
|
2156
|
+
type: Output
|
2157
|
+
}], onFocus: [{
|
2158
|
+
type: Output
|
2159
|
+
}], onBlur: [{
|
2160
|
+
type: Output
|
2161
|
+
}], onClick: [{
|
2162
|
+
type: Output
|
2163
|
+
}], onClear: [{
|
2164
|
+
type: Output
|
2165
|
+
}], onPanelShow: [{
|
2166
|
+
type: Output
|
2167
|
+
}], onPanelHide: [{
|
2168
|
+
type: Output
|
2169
|
+
}], onLazyLoad: [{
|
2170
|
+
type: Output
|
2171
|
+
}], onRemove: [{
|
2172
|
+
type: Output
|
1742
2173
|
}], containerViewChild: [{
|
1743
2174
|
type: ViewChild,
|
1744
2175
|
args: ['container']
|
@@ -1748,15 +2179,24 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
|
|
1748
2179
|
}], filterInputChild: [{
|
1749
2180
|
type: ViewChild,
|
1750
2181
|
args: ['filterInput']
|
1751
|
-
}],
|
2182
|
+
}], focusInputViewChild: [{
|
1752
2183
|
type: ViewChild,
|
1753
|
-
args: ['
|
2184
|
+
args: ['focusInput']
|
1754
2185
|
}], itemsViewChild: [{
|
1755
2186
|
type: ViewChild,
|
1756
2187
|
args: ['items']
|
1757
2188
|
}], scroller: [{
|
1758
2189
|
type: ViewChild,
|
1759
2190
|
args: ['scroller']
|
2191
|
+
}], lastHiddenFocusableElementOnOverlay: [{
|
2192
|
+
type: ViewChild,
|
2193
|
+
args: ['lastHiddenFocusableEl']
|
2194
|
+
}], firstHiddenFocusableElementOnOverlay: [{
|
2195
|
+
type: ViewChild,
|
2196
|
+
args: ['firstHiddenFocusableEl']
|
2197
|
+
}], headerCheckboxViewChild: [{
|
2198
|
+
type: ViewChild,
|
2199
|
+
args: ['headerCheckbox']
|
1760
2200
|
}], footerFacet: [{
|
1761
2201
|
type: ContentChild,
|
1762
2202
|
args: [Footer]
|
@@ -1766,26 +2206,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
|
|
1766
2206
|
}], templates: [{
|
1767
2207
|
type: ContentChildren,
|
1768
2208
|
args: [PrimeTemplate]
|
1769
|
-
}], onChange: [{
|
1770
|
-
type: Output
|
1771
|
-
}], onFilter: [{
|
1772
|
-
type: Output
|
1773
|
-
}], onFocus: [{
|
1774
|
-
type: Output
|
1775
|
-
}], onBlur: [{
|
1776
|
-
type: Output
|
1777
|
-
}], onClick: [{
|
1778
|
-
type: Output
|
1779
|
-
}], onClear: [{
|
1780
|
-
type: Output
|
1781
|
-
}], onPanelShow: [{
|
1782
|
-
type: Output
|
1783
|
-
}], onPanelHide: [{
|
1784
|
-
type: Output
|
1785
|
-
}], onLazyLoad: [{
|
1786
|
-
type: Output
|
1787
|
-
}], onRemove: [{
|
1788
|
-
type: Output
|
1789
2209
|
}] } });
|
1790
2210
|
class MultiSelectModule {
|
1791
2211
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: MultiSelectModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
@@ -1801,4 +2221,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
|
|
1801
2221
|
declarations: [MultiSelect, MultiSelectItem]
|
1802
2222
|
}]
|
1803
2223
|
}] });
|
1804
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multiselect.js","sourceRoot":"","sources":["../../../src/app/components/multiselect/multiselect.ts"],"names":[],"mappings":"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","sourcesContent":["import { AnimationEvent } from '@angular/animations';\nimport { CommonModule } from '@angular/common';\nimport {\n    AfterContentInit,\n    AfterViewChecked,\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    Input,\n    NgModule,\n    NgZone,\n    OnInit,\n    Output,\n    QueryList,\n    Renderer2,\n    TemplateRef,\n    ViewChild,\n    ViewEncapsulation\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { FilterService, Footer, Header, OverlayOptions, OverlayService, PrimeNGConfig, PrimeTemplate, SharedModule, TranslationKeys } from 'primeng/api';\nimport { DomHandler } from 'primeng/dom';\nimport { Overlay, OverlayModule } from 'primeng/overlay';\nimport { RippleModule } from 'primeng/ripple';\nimport { Scroller, ScrollerModule } from 'primeng/scroller';\nimport { ScrollerOptions } from 'primeng/api';\nimport { TooltipModule } from 'primeng/tooltip';\nimport { ObjectUtils } from 'primeng/utils';\nimport { CheckIcon } from 'primeng/icons/check';\nimport { SearchIcon } from 'primeng/icons/search';\nimport { TimesCircleIcon } from 'primeng/icons/timescircle';\nimport { TimesIcon } from 'primeng/icons/times';\nimport { ChevronDownIcon } from 'primeng/icons/chevrondown';\nimport { Nullable } from 'primeng/ts-helpers';\nimport { MultiSelectRemoveEvent, MultiSelectFilterOptions, MultiSelectFilterEvent, MultiSelectBlurEvent, MultiSelectChangeEvent, MultiSelectFocusEvent, MultiSelectLazyLoadEvent } from './multiselect.interface';\n\nexport const MULTISELECT_VALUE_ACCESSOR: any = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => MultiSelect),\n    multi: true\n};\n\n@Component({\n    selector: 'p-multiSelectItem',\n    template: `\n        <li\n            class=\"p-multiselect-item\"\n            (click)=\"onOptionClick($event)\"\n            (keydown)=\"onOptionKeydown($event)\"\n            [attr.aria-label]=\"label\"\n            [attr.tabindex]=\"disabled ? null : '0'\"\n            [ngStyle]=\"{ height: itemSize + 'px' }\"\n            [ngClass]=\"{ 'p-highlight': selected, 'p-disabled': disabled }\"\n            pRipple\n        >\n            <div class=\"p-checkbox p-component\">\n                <div class=\"p-checkbox-box\" [ngClass]=\"{ 'p-highlight': selected }\">\n                    <ng-container *ngIf=\"selected\">\n                        <CheckIcon *ngIf=\"!checkIconTemplate\" [styleClass]=\"'p-checkbox-icon'\" />\n                        <span *ngIf=\"checkIconTemplate\" class=\"p-checkbox-icon\">\n                            <ng-template *ngTemplateOutlet=\"checkIconTemplate\"></ng-template>\n                        </span>\n                    </ng-container>\n                </div>\n            </div>\n            <span *ngIf=\"!template\">{{ label }}</span>\n            <ng-container *ngTemplateOutlet=\"template; context: { $implicit: option }\"></ng-container>\n        </li>\n    `,\n    encapsulation: ViewEncapsulation.None,\n    host: {\n        class: 'p-element'\n    }\n})\nexport class MultiSelectItem {\n    @Input() option: any;\n\n    @Input() selected: boolean | undefined;\n\n    @Input() label: string | undefined;\n\n    @Input() disabled: boolean | undefined;\n\n    @Input() itemSize: number | undefined;\n\n    @Input() template: TemplateRef<any> | undefined;\n\n    @Input() checkIconTemplate: TemplateRef<any> | undefined;\n\n    @Output() onClick: EventEmitter<any> = new EventEmitter();\n\n    @Output() onKeydown: EventEmitter<any> = new EventEmitter();\n\n    onOptionClick(event: Event) {\n        this.onClick.emit({\n            originalEvent: event,\n            option: this.option,\n            selected: this.selected\n        });\n    }\n\n    onOptionKeydown(event: Event) {\n        this.onKeydown.emit({\n            originalEvent: event,\n            option: this.option\n        });\n    }\n}\n/**\n * MultiSelect is used to select multiple items from a collection.\n * @group Components\n */\n@Component({\n    selector: 'p-multiSelect',\n    template: `\n        <div\n            #container\n            [ngClass]=\"{ 'p-multiselect p-component': true, 'p-multiselect-open': overlayVisible, 'p-multiselect-chip': display === 'chip', 'p-focus': focus, 'p-disabled': disabled }\"\n            [ngStyle]=\"style\"\n            [class]=\"styleClass\"\n            (click)=\"onMouseclick($event, in)\"\n        >\n            <div class=\"p-hidden-accessible\">\n                <input\n                    #in\n                    type=\"text\"\n                    [attr.label]=\"label\"\n                    readonly=\"readonly\"\n                    [attr.id]=\"inputId\"\n                    [attr.name]=\"name\"\n                    (focus)=\"onInputFocus($event)\"\n                    (blur)=\"onInputBlur($event)\"\n                    [disabled]=\"disabled\"\n                    [attr.tabindex]=\"tabindex\"\n                    (keydown)=\"onKeydown($event)\"\n                    aria-haspopup=\"listbox\"\n                    [attr.aria-expanded]=\"overlayVisible\"\n                    [attr.aria-labelledby]=\"ariaLabelledBy\"\n                    role=\"listbox\"\n                />\n            </div>\n            <div class=\"p-multiselect-label-container\" [pTooltip]=\"tooltip\" [tooltipPosition]=\"tooltipPosition\" [positionStyle]=\"tooltipPositionStyle\" [tooltipStyleClass]=\"tooltipStyleClass\">\n                <div\n                    class=\"p-multiselect-label\"\n                    [ngClass]=\"{ 'p-placeholder': valuesAsString === (defaultLabel || placeholder), 'p-multiselect-label-empty': (valuesAsString == null || valuesAsString.length === 0) && (placeholder == null || placeholder.length === 0) }\"\n                >\n                    <ng-container *ngIf=\"!selectedItemsTemplate\">\n                        <ng-container *ngIf=\"display === 'comma'\">{{ valuesAsString || 'empty' }}</ng-container>\n                        <ng-container *ngIf=\"display === 'chip'\">\n                            <div #token *ngFor=\"let item of value; let i = index\" class=\"p-multiselect-token\">\n                                <span class=\"p-multiselect-token-label\">{{ findLabelByValue(item) }}</span>\n                                <ng-container *ngIf=\"!disabled\">\n                                    <TimesCircleIcon *ngIf=\"!removeTokenIconTemplate\" [styleClass]=\"'p-multiselect-token-icon'\" (click)=\"removeChip(item, event)\" />\n                                    <span *ngIf=\"removeTokenIconTemplate\" class=\"p-multiselect-token-icon\" (click)=\"removeChip(item, event)\">\n                                        <ng-container *ngTemplateOutlet=\"removeTokenIconTemplate\"></ng-container>\n                                    </span>\n                                </ng-container>\n                            </div>\n                            <ng-container *ngIf=\"!value || value.length === 0\">{{ placeholder || defaultLabel || 'empty' }}</ng-container>\n                        </ng-container>\n                    </ng-container>\n                    <ng-container *ngTemplateOutlet=\"selectedItemsTemplate; context: { $implicit: value, removeChip: removeChip.bind(this) }\"></ng-container>\n                </div>\n                <ng-container *ngIf=\"value != null && filled && !disabled && showClear\">\n                    <TimesIcon *ngIf=\"!clearIconTemplate\" [styleClass]=\"'p-multiselect-clear-icon'\" (click)=\"clear($event)\" />\n                    <span *ngIf=\"clearIconTemplate\" class=\"p-multiselect-clear-icon\" (click)=\"clear($event)\">\n                        <ng-template *ngTemplateOutlet=\"clearIconTemplate\"></ng-template>\n                    </span>\n                </ng-container>\n            </div>\n            <div [ngClass]=\"{ 'p-multiselect-trigger': true }\">\n                <ng-container *ngIf=\"!dropdownIconTemplate\">\n                    <span *ngIf=\"dropdownIcon\" class=\"p-multiselect-trigger-icon\" [ngClass]=\"dropdownIcon\"></span>\n                    <ChevronDownIcon *ngIf=\"!dropdownIcon\" [styleClass]=\"'p-multiselect-trigger-icon'\" />\n                </ng-container>\n                <span *ngIf=\"dropdownIconTemplate\" class=\"p-multiselect-trigger-icon\">\n                    <ng-template *ngTemplateOutlet=\"dropdownIconTemplate\"></ng-template>\n                </span>\n            </div>\n            <p-overlay\n                #overlay\n                [(visible)]=\"overlayVisible\"\n                [options]=\"overlayOptions\"\n                [target]=\"'@parent'\"\n                [appendTo]=\"appendTo\"\n                [autoZIndex]=\"autoZIndex\"\n                [baseZIndex]=\"baseZIndex\"\n                [showTransitionOptions]=\"showTransitionOptions\"\n                [hideTransitionOptions]=\"hideTransitionOptions\"\n                (onAnimationStart)=\"onOverlayAnimationStart($event)\"\n                (onHide)=\"hide()\"\n            >\n                <ng-template pTemplate=\"content\">\n                    <div [ngClass]=\"['p-multiselect-panel p-component']\" [ngStyle]=\"panelStyle\" [class]=\"panelStyleClass\" (keydown)=\"onKeydown($event)\">\n                        <div class=\"p-multiselect-header\" *ngIf=\"showHeader\">\n                            <ng-content select=\"p-header\"></ng-content>\n                            <ng-container *ngTemplateOutlet=\"headerTemplate\"></ng-container>\n                            <ng-container *ngIf=\"filterTemplate; else builtInFilterElement\">\n                                <ng-container *ngTemplateOutlet=\"filterTemplate; context: { options: filterOptions }\"></ng-container>\n                            </ng-container>\n                            <ng-template #builtInFilterElement>\n                                <div class=\"p-checkbox p-component\" *ngIf=\"showToggleAll && !selectionLimit\" [ngClass]=\"{ 'p-checkbox-disabled': disabled || toggleAllDisabled }\">\n                                    <div class=\"p-hidden-accessible\">\n                                        <input\n                                            type=\"checkbox\"\n                                            readonly=\"readonly\"\n                                            [checked]=\"allChecked\"\n                                            (focus)=\"onHeaderCheckboxFocus()\"\n                                            (blur)=\"onHeaderCheckboxBlur()\"\n                                            (keydown.space)=\"toggleAll($event)\"\n                                            [disabled]=\"disabled || toggleAllDisabled\"\n                                        />\n                                    </div>\n                                    <div\n                                        class=\"p-checkbox-box\"\n                                        role=\"checkbox\"\n                                        [attr.aria-checked]=\"allChecked\"\n                                        [ngClass]=\"{ 'p-highlight': allChecked, 'p-focus': headerCheckboxFocus, 'p-disabled': disabled || toggleAllDisabled }\"\n                                        (click)=\"toggleAll($event)\"\n                                    >\n                                        <ng-container *ngIf=\"allChecked\">\n                                            <CheckIcon [styleClass]=\"'p-checkbox-icon'\" *ngIf=\"!checkIconTemplate\" />\n                                            <span *ngIf=\"checkIconTemplate\" class=\"p-checkbox-icon\">\n                                                <ng-template *ngTemplateOutlet=\"checkIconTemplate\"></ng-template>\n                                            </span>\n                                        </ng-container>\n                                    </div>\n                                </div>\n                                <div class=\"p-multiselect-filter-container\" *ngIf=\"filter\">\n                                    <input\n                                        #filterInput\n                                        type=\"text\"\n                                        [attr.autocomplete]=\"autocomplete\"\n                                        role=\"textbox\"\n                                        [value]=\"filterValue || ''\"\n                                        (input)=\"onFilterInputChange($event)\"\n                                        class=\"p-multiselect-filter p-inputtext p-component\"\n                                        [disabled]=\"disabled\"\n                                        [attr.placeholder]=\"filterPlaceHolder\"\n                                        [attr.aria-label]=\"ariaFilterLabel\"\n                                    />\n                                    <SearchIcon [styleClass]=\"'p-multiselect-filter-icon'\" *ngIf=\"!filterIconTemplate\" />\n                                    <span *ngIf=\"filterIconTemplate\" class=\"p-multiselect-filter-icon\">\n                                        <ng-template *ngTemplateOutlet=\"filterIconTemplate\"></ng-template>\n                                    </span>\n                                </div>\n\n                                <button class=\"p-multiselect-close p-link p-button-icon-only\" type=\"button\" (click)=\"close($event)\" pRipple>\n                                    <TimesIcon [styleClass]=\"'p-multiselect-close-icon'\" *ngIf=\"!closeIconTemplate\" />\n                                    <span *ngIf=\"closeIconTemplate\" class=\"p-multiselect-close-icon\">\n                                        <ng-template *ngTemplateOutlet=\"closeIconTemplate\"></ng-template>\n                                    </span>\n                                </button>\n                            </ng-template>\n                        </div>\n                        <div class=\"p-multiselect-items-wrapper\" [style.max-height]=\"virtualScroll ? 'auto' : scrollHeight || 'auto'\">\n                            <p-scroller\n                                *ngIf=\"virtualScroll\"\n                                #scroller\n                                [items]=\"optionsToRender\"\n                                [style]=\"{ height: scrollHeight }\"\n                                [itemSize]=\"virtualScrollItemSize || _itemSize\"\n                                [autoSize]=\"true\"\n                                [tabindex]=\"-1\"\n                                [lazy]=\"lazy\"\n                                (onLazyLoad)=\"onLazyLoad.emit($event)\"\n                                [options]=\"virtualScrollOptions\"\n                            >\n                                <ng-template pTemplate=\"content\" let-items let-scrollerOptions=\"options\">\n                                    <ng-container *ngTemplateOutlet=\"buildInItems; context: { $implicit: items, options: scrollerOptions }\"></ng-container>\n                                </ng-template>\n                                <ng-container *ngIf=\"loaderTemplate\">\n                                    <ng-template pTemplate=\"loader\" let-scrollerOptions=\"options\">\n                                        <ng-container *ngTemplateOutlet=\"loaderTemplate; context: { options: scrollerOptions }\"></ng-container>\n                                    </ng-template>\n                                </ng-container>\n                            </p-scroller>\n                            <ng-container *ngIf=\"!virtualScroll\">\n                                <ng-container *ngTemplateOutlet=\"buildInItems; context: { $implicit: optionsToRender, options: {} }\"></ng-container>\n                            </ng-container>\n\n                            <ng-template #buildInItems let-items let-scrollerOptions=\"options\">\n                                <ul #items class=\"p-multiselect-items p-component\" [ngClass]=\"scrollerOptions.contentStyleClass\" [style]=\"scrollerOptions.contentStyle\" role=\"listbox\" aria-multiselectable=\"true\">\n                                    <ng-container *ngIf=\"group\">\n                                        <ng-template ngFor let-optgroup [ngForOf]=\"items\">\n                                            <li class=\"p-multiselect-item-group\" [ngStyle]=\"{ height: scrollerOptions.itemSize + 'px' }\">\n                                                <span *ngIf=\"!groupTemplate\">{{ getOptionGroupLabel(optgroup) || 'empty' }}</span>\n                                                <ng-container *ngTemplateOutlet=\"groupTemplate; context: { $implicit: optgroup }\"></ng-container>\n                                            </li>\n                                            <ng-container *ngTemplateOutlet=\"itemslist; context: { $implicit: getOptionGroupChildren(optgroup) }\"></ng-container>\n                                        </ng-template>\n                                    </ng-container>\n                                    <ng-container *ngIf=\"!group\">\n                                        <ng-container *ngTemplateOutlet=\"itemslist; context: { $implicit: items }\"></ng-container>\n                                    </ng-container>\n                                    <ng-template #itemslist let-optionsToDisplay let-selectedOption=\"selectedOption\">\n                                        <ng-template ngFor let-option let-i=\"index\" [ngForOf]=\"optionsToDisplay\">\n                                            <p-multiSelectItem\n                                                [option]=\"option\"\n                                                [selected]=\"isSelected(option)\"\n                                                [label]=\"getOptionLabel(option)\"\n                                                [disabled]=\"isOptionDisabled(option)\"\n                                                (onClick)=\"onOptionClick($event)\"\n                                                (onKeydown)=\"onOptionKeydown($event)\"\n                                                [template]=\"itemTemplate\"\n                                                [checkIconTemplate]=\"checkIconTemplate\"\n                                                [itemSize]=\"scrollerOptions.itemSize\"\n                                            ></p-multiSelectItem>\n                                        </ng-template>\n                                    </ng-template>\n                                    <li *ngIf=\"hasFilter() && isEmpty()\" class=\"p-multiselect-empty-message\" [ngStyle]=\"{ height: scrollerOptions.itemSize + 'px' }\">\n                                        <ng-container *ngIf=\"!emptyFilterTemplate && !emptyTemplate; else emptyFilter\">\n                                            {{ emptyFilterMessageLabel }}\n                                        </ng-container>\n                                        <ng-container #emptyFilter *ngTemplateOutlet=\"emptyFilterTemplate || emptyTemplate\"></ng-container>\n                                    </li>\n                                    <li *ngIf=\"!hasFilter() && isEmpty()\" class=\"p-multiselect-empty-message\" [ngStyle]=\"{ height: scrollerOptions.itemSize + 'px' }\">\n                                        <ng-container *ngIf=\"!emptyTemplate; else empty\">\n                                            {{ emptyMessageLabel }}\n                                        </ng-container>\n                                        <ng-container #empty *ngTemplateOutlet=\"emptyTemplate\"></ng-container>\n                                    </li>\n                                </ul>\n                            </ng-template>\n                        </div>\n                        <div class=\"p-multiselect-footer\" *ngIf=\"footerFacet || footerTemplate\">\n                            <ng-content select=\"p-footer\"></ng-content>\n                            <ng-container *ngTemplateOutlet=\"footerTemplate\"></ng-container>\n                        </div>\n                    </div>\n                </ng-template>\n            </p-overlay>\n        </div>\n    `,\n    host: {\n        class: 'p-element p-inputwrapper',\n        '[class.p-inputwrapper-filled]': 'filled',\n        '[class.p-inputwrapper-focus]': 'focus || overlayVisible',\n        '[class.p-multiselect-clearable]': 'showClear && !disabled'\n    },\n    providers: [MULTISELECT_VALUE_ACCESSOR],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    styleUrls: ['./multiselect.css']\n})\nexport class MultiSelect implements OnInit, AfterViewInit, AfterContentInit, AfterViewChecked, ControlValueAccessor {\n    /**\n     * Inline style of the element.\n     * @group Props\n     */\n    @Input() style: { [klass: string]: any } | null | undefined;\n    /**\n     * Style class of the element.\n     * @group Props\n     */\n    @Input() styleClass: string | undefined;\n    /**\n     * Inline style of the overlay panel.\n     * @group Props\n     */\n    @Input() panelStyle: any;\n    /**\n     * Style class of the overlay panel element.\n     * @group Props\n     */\n    @Input() panelStyleClass: string | undefined;\n    /**\n     * Identifier of the focus input to match a label defined for the component.\n     * @group Props\n     */\n    @Input() inputId: string | undefined;\n    /**\n     * When present, it specifies that the element should be disabled.\n     * @group Props\n     */\n    @Input() disabled: boolean | undefined;\n    /**\n     * When present, it specifies that the component cannot be edited.\n     * @group Props\n     */\n    @Input() readonly: boolean | undefined;\n    /**\n     * Whether to display options as grouped when nested options are provided.\n     * @group Props\n     */\n    @Input() group: boolean | undefined;\n    /**\n     * When specified, displays an input field to filter the items on keyup.\n     * @group Props\n     */\n    @Input() filter: boolean = true;\n    /**\n     * Defines placeholder of the filter input.\n     * @group Props\n     */\n    @Input() filterPlaceHolder: string | undefined;\n    /**\n     * Locale to use in filtering. The default locale is the host environment's current locale.\n     * @group Props\n     */\n    @Input() filterLocale: string | undefined;\n    /**\n     * Specifies the visibility of the options panel.\n     * @group Props\n     */\n    @Input() overlayVisible: boolean | undefined;\n    /**\n     * Index of the element in tabbing order.\n     * @group Props\n     */\n    @Input() tabindex: number | undefined;\n    /**\n     * Target element to attach the overlay, valid values are \"body\" or a local ng-template variable of another element (note: use binding with brackets for template variables, e.g. [appendTo]=\"mydiv\" for a div element having #mydiv as variable name).\n     * @group Props\n     */\n    @Input() appendTo: HTMLElement | ElementRef | TemplateRef<any> | string | null | undefined | any;\n    /**\n     * A property to uniquely identify a value in options.\n     * @group Props\n     */\n    @Input() dataKey: string | undefined;\n    /**\n     * Name of the input element.\n     * @group Props\n     */\n    @Input() name: string | undefined;\n    /**\n     * Label of the input for accessibility.\n     * @group Props\n     */\n    @Input() label: string | undefined;\n    /**\n     * Establishes relationships between the component and label(s) where its value should be one or more element IDs.\n     * @group Props\n     */\n    @Input() ariaLabelledBy: string | undefined;\n    /**\n     * Whether to show labels of selected item labels or use default label.\n     * @group Props\n     */\n    @Input() displaySelectedLabel: boolean = true;\n    /**\n     * Decides how many selected item labels to show at most.\n     * @group Props\n     */\n    @Input() maxSelectedLabels: number = 3;\n    /**\n     * Label to display after exceeding max selected labels e.g. ({0} items selected), defaults \"ellipsis\" keyword to indicate a text-overflow.\n     * @group Props\n     */\n    @Input() selectedItemsLabel: string = 'ellipsis';\n    /**\n     * Whether to show the checkbox at header to toggle all items at once.\n     * @group Props\n     */\n    @Input() showToggleAll: boolean = true;\n    /**\n     * Text to display when filtering does not return any results.\n     * @group Props\n     */\n    @Input() emptyFilterMessage: string = '';\n    /**\n     * Text to display when there is no data. Defaults to global value in i18n translation configuration.\n     * @group Props\n     */\n    @Input() emptyMessage: string = '';\n    /**\n     * Clears the filter value when hiding the dropdown.\n     * @group Props\n     */\n    @Input() resetFilterOnHide: boolean = false;\n    /**\n     * Icon class of the dropdown icon.\n     * @group Props\n     */\n    @Input() dropdownIcon: string | undefined;\n    /**\n     * Name of the label field of an option.\n     * @group Props\n     */\n    @Input() optionLabel: string | undefined;\n    /**\n     * Name of the value field of an option.\n     * @group Props\n     */\n    @Input() optionValue: string | undefined;\n    /**\n     * Name of the disabled field of an option.\n     * @group Props\n     */\n    @Input() optionDisabled: string | undefined;\n    /**\n     * Name of the label field of an option group.\n     * @group Props\n     */\n    @Input() optionGroupLabel: string | undefined;\n    /**\n     * Name of the options field of an option group.\n     * @group Props\n     */\n    @Input() optionGroupChildren: string = 'items';\n    /**\n     * Whether to show the header.\n     * @group Props\n     */\n    @Input() showHeader: boolean = true;\n    /**\n     * When filtering is enabled, filterBy decides which field or fields (comma separated) to search against.\n     * @group Props\n     */\n    @Input() filterBy: string | undefined;\n    /**\n     * Height of the viewport in pixels, a scrollbar is defined if height of list exceeds this value.\n     * @group Props\n     */\n    @Input() scrollHeight: string = '200px';\n    /**\n     * Defines if data is loaded and interacted with in lazy manner.\n     * @group Props\n     */\n    @Input() lazy: boolean = false;\n    /**\n     * Whether the data should be loaded on demand during scroll.\n     * @group Props\n     */\n    @Input() virtualScroll: boolean | undefined;\n    /**\n     * Height of an item in the list for VirtualScrolling.\n     * @group Props\n     */\n    @Input() virtualScrollItemSize: number | undefined;\n    /**\n     * Whether to use the scroller feature. The properties of scroller component can be used like an object in it.\n     * @group Props\n     */\n    @Input() virtualScrollOptions: ScrollerOptions | undefined;\n    /**\n     * Whether to use overlay API feature. The properties of overlay API can be used like an object in it.\n     * @group Props\n     */\n    @Input() overlayOptions: OverlayOptions | undefined;\n    /**\n     * Defines a string that labels the filter input.\n     * @group Props\n     */\n    @Input() ariaFilterLabel: string | undefined;\n    /**\n     * Defines how the items are filtered.\n     * @group Props\n     */\n    @Input() filterMatchMode: 'contains' | 'startsWith' | 'endsWith' | 'equals' | 'notEquals' | 'in' | 'lt' | 'lte' | 'gt' | 'gte' = 'contains';\n    /**\n     * Advisory information to display in a tooltip on hover.\n     * @group Props\n     */\n    @Input() tooltip: string = '';\n    /**\n     * Position of the tooltip.\n     * @group Props\n     */\n    @Input() tooltipPosition: 'top' | 'left' | 'right' | 'bottom' = 'right';\n    /**\n     * Type of CSS position.\n     * @group Props\n     */\n    @Input() tooltipPositionStyle: string = 'absolute';\n    /**\n     * Style class of the tooltip.\n     * @group Props\n     */\n    @Input() tooltipStyleClass: string | undefined;\n    /**\n     * Applies focus to the filter element when the overlay is shown.\n     * @group Props\n     */\n    @Input() autofocusFilter: boolean = true;\n    /**\n     * Defines how the selected items are displayed.\n     * @group Props\n     */\n    @Input() display: string | 'comma' | 'chip' = 'comma';\n    /**\n     * Defines the autocomplete is active.\n     * @group Props\n     */\n    @Input() autocomplete: string = 'on';\n    /**\n     * When enabled, a clear icon is displayed to clear the value.\n     * @group Props\n     */\n    @Input() showClear: boolean = false;\n    /**\n     * @deprecated since v14.2.0, use overlayOptions property instead.\n     * Whether to automatically manage layering.\n     * @group Props\n     */\n    @Input() get autoZIndex(): boolean | undefined {\n        return this._autoZIndex;\n    }\n    set autoZIndex(val: boolean | undefined) {\n        this._autoZIndex = val;\n        console.warn('The autoZIndex property is deprecated since v14.2.0, use overlayOptions property instead.');\n    }\n    /**\n     * @deprecated since v14.2.0, use overlayOptions property instead.\n     * Base zIndex value to use in layering.\n     * @group Props\n     */\n    @Input() get baseZIndex(): number | undefined {\n        return this._baseZIndex;\n    }\n    set baseZIndex(val: number | undefined) {\n        this._baseZIndex = val;\n        console.warn('The baseZIndex property is deprecated since v14.2.0, use overlayOptions property instead.');\n    }\n    /**\n     * Transition options of the show animation.\n     * @group Props\n     * @deprecated since v14.2.0, use overlayOptions property instead.\n     */\n    @Input() get showTransitionOptions(): string | undefined {\n        return this._showTransitionOptions;\n    }\n    set showTransitionOptions(val: string | undefined) {\n        this._showTransitionOptions = val;\n        console.warn('The showTransitionOptions property is deprecated since v14.2.0, use overlayOptions property instead.');\n    }\n    /**\n     * Transition options of the hide animation.\n     * @group Props\n     * @deprecated since v14.2.0, use overlayOptions property instead.\n     */\n    @Input() get hideTransitionOptions(): string | undefined {\n        return this._hideTransitionOptions;\n    }\n    set hideTransitionOptions(val: string | undefined) {\n        this._hideTransitionOptions = val;\n        console.warn('The hideTransitionOptions property is deprecated since v14.2.0, use overlayOptions property instead.');\n    }\n    /**\n     * Label to display when there are no selections.\n     * @group Props\n     * @deprecated Use placeholder instead.\n     */\n    @Input() set defaultLabel(val: string | undefined) {\n        this._defaultLabel = val;\n        this.updateLabel();\n    }\n    get defaultLabel(): string | undefined {\n        return this._defaultLabel;\n    }\n    /**\n     * Label to display when there are no selections.\n     * @group Props\n     */\n    @Input() set placeholder(val: string | undefined) {\n        this._placeholder = val;\n        this.updateLabel();\n    }\n    get placeholder(): string | undefined {\n        return this._placeholder;\n    }\n    /**\n     * An array of objects to display as the available options.\n     * @group Props\n     */\n    @Input() get options(): any[] | undefined {\n        return this._options;\n    }\n    set options(val: any[] | undefined) {\n        this._options = val;\n        this.updateLabel();\n    }\n    /**\n     * When specified, filter displays with this value.\n     * @group Props\n     */\n    @Input() get filterValue(): string | undefined | null {\n        return this._filterValue;\n    }\n    set filterValue(val: string | undefined | null) {\n        this._filterValue = val;\n        this.activateFilter();\n    }\n    /**\n     * Item size of item to be virtual scrolled.\n     * @group Props\n     * @deprecated use virtualScrollItemSize property instead.\n     */\n    @Input() get itemSize(): number | undefined {\n        return this._itemSize;\n    }\n    set itemSize(val: number | undefined) {\n        this._itemSize = val;\n        console.warn('The itemSize property is deprecated, use virtualScrollItemSize property instead.');\n    }\n    /**\n     * Number of maximum options that can be selected.\n     * @group Props\n     */\n    @Input() get selectionLimit(): number | undefined {\n        return this._selectionLimit;\n    }\n    set selectionLimit(val: number | undefined) {\n        this._selectionLimit = val;\n        this.checkSelectionLimit();\n    }\n\n    @ViewChild('container') containerViewChild: Nullable<ElementRef>;\n\n    @ViewChild('overlay') overlayViewChild: Nullable<Overlay>;\n\n    @ViewChild('filterInput') filterInputChild: Nullable<ElementRef>;\n\n    @ViewChild('in') accessibleViewChild: Nullable<ElementRef>;\n\n    @ViewChild('items') itemsViewChild: Nullable<ElementRef>;\n\n    @ViewChild('scroller') scroller: Nullable<Scroller>;\n\n    @ContentChild(Footer) footerFacet: any;\n\n    @ContentChild(Header) headerFacet: any;\n\n    @ContentChildren(PrimeTemplate) templates: Nullable<QueryList<PrimeTemplate>>;\n\n    /**\n     * Callback to invoke when value changes.\n     * @param {MultiSelectChangeEvent} event - Custom change event.\n     * @group Emits\n     */\n    @Output() onChange: EventEmitter<MultiSelectChangeEvent> = new EventEmitter<MultiSelectChangeEvent>();\n    /**\n     * Callback to invoke when data is filtered.\n     * @param {MultiSelectFilterEvent} event - Custom filter event.\n     * @group Emits\n     */\n    @Output() onFilter: EventEmitter<MultiSelectFilterEvent> = new EventEmitter<MultiSelectFilterEvent>();\n    /**\n     * Callback to invoke when multiselect receives focus.\n     * @param {MultiSelectFocusEvent} event - Custom focus event.\n     * @group Emits\n     */\n    @Output() onFocus: EventEmitter<MultiSelectFocusEvent> = new EventEmitter<MultiSelectFocusEvent>();\n    /**\n     * Callback to invoke when multiselect loses focus.\n     * @param {MultiSelectBlurEvent} event - Custom blur event.\n     * @group Emits\n     */\n    @Output() onBlur: EventEmitter<MultiSelectBlurEvent> = new EventEmitter<MultiSelectBlurEvent>();\n    /**\n     * Callback to invoke when component is clicked.\n     * @param {Event} event - Browser event.\n     * @group Emits\n     */\n    @Output() onClick: EventEmitter<Event> = new EventEmitter<Event>();\n    /**\n     * Callback to invoke when input field is cleared.\n     * @group Emits\n     */\n    @Output() onClear: EventEmitter<void> = new EventEmitter<void>();\n    /**\n     * Callback to invoke when overlay panel becomes visible.\n     * @group Emits\n     */\n    @Output() onPanelShow: EventEmitter<void> = new EventEmitter<void>();\n    /**\n     * Callback to invoke when overlay panel becomes hidden.\n     * @group Emits\n     */\n    @Output() onPanelHide: EventEmitter<void> = new EventEmitter<void>();\n    /**\n     * Callback to invoke in lazy mode to load new data.\n     * @param {MultiSelectLazyLoadEvent} event - Lazy load event.\n     * @group Emits\n     */\n    @Output() onLazyLoad: EventEmitter<MultiSelectLazyLoadEvent> = new EventEmitter<MultiSelectLazyLoadEvent>();\n    /**\n     * Callback to invoke in lazy mode to load new data.\n     * @param {MultiSelectRemoveEvent} event - Remove event.\n     * @group Emits\n     */\n    @Output() onRemove: EventEmitter<MultiSelectRemoveEvent> = new EventEmitter<MultiSelectRemoveEvent>();\n\n    _autoZIndex: boolean | undefined;\n\n    _baseZIndex: number | undefined;\n\n    _showTransitionOptions: string | undefined;\n\n    _hideTransitionOptions: string | undefined;\n\n    _defaultLabel: string | undefined;\n\n    _placeholder: string | undefined;\n\n    _itemSize: number | undefined;\n\n    _selectionLimit: number | undefined;\n\n    public value: any[] | undefined | null;\n\n    public _filteredOptions: any[] | undefined | null;\n\n    public onModelChange: Function = () => {};\n\n    public onModelTouched: Function = () => {};\n\n    public valuesAsString: string | undefined;\n\n    public focus: boolean | undefined;\n\n    filled: boolean | undefined | null;\n\n    public _filterValue: string | undefined | null;\n\n    public filtered: boolean | undefined;\n\n    public itemTemplate: TemplateRef<any> | undefined;\n\n    public groupTemplate: TemplateRef<any> | undefined;\n\n    public loaderTemplate: TemplateRef<any> | undefined;\n\n    public headerTemplate: TemplateRef<any> | undefined;\n\n    public filterTemplate: TemplateRef<any> | undefined;\n\n    public footerTemplate: TemplateRef<any> | undefined;\n\n    public emptyFilterTemplate: TemplateRef<any> | undefined;\n\n    public emptyTemplate: TemplateRef<any> | undefined;\n\n    public selectedItemsTemplate: TemplateRef<any> | undefined;\n\n    checkIconTemplate: TemplateRef<any> | undefined;\n\n    filterIconTemplate: TemplateRef<any> | undefined;\n\n    removeTokenIconTemplate: TemplateRef<any> | undefined;\n\n    closeIconTemplate: TemplateRef<any> | undefined;\n\n    clearIconTemplate: TemplateRef<any> | undefined;\n\n    dropdownIconTemplate: TemplateRef<any> | undefined;\n\n    public headerCheckboxFocus: boolean | undefined;\n\n    filterOptions: MultiSelectFilterOptions | undefined;\n\n    _options: any[] | undefined;\n\n    maxSelectionLimitReached: boolean | undefined;\n\n    preventModelTouched: boolean | undefined;\n\n    preventDocumentDefault: boolean | undefined;\n\n    constructor(public el: ElementRef, public renderer: Renderer2, public cd: ChangeDetectorRef, public zone: NgZone, public filterService: FilterService, public config: PrimeNGConfig, public overlayService: OverlayService) {}\n\n    ngOnInit() {\n        this.updateLabel();\n\n        if (this.filterBy) {\n            this.filterOptions = {\n                filter: (value) => this.onFilterInputChange(value),\n                reset: () => this.resetFilter()\n            };\n        }\n    }\n\n    ngAfterContentInit() {\n        (this.templates as QueryList<PrimeTemplate>).forEach((item) => {\n            switch (item.getType()) {\n                case 'item':\n                    this.itemTemplate = item.template;\n                    break;\n\n                case 'group':\n                    this.groupTemplate = item.template;\n                    break;\n\n                case 'selectedItems':\n                    this.selectedItemsTemplate = item.template;\n                    break;\n\n                case 'header':\n                    this.headerTemplate = item.template;\n                    break;\n\n                case 'filter':\n                    this.filterTemplate = item.template;\n                    break;\n\n                case 'emptyfilter':\n                    this.emptyFilterTemplate = item.template;\n                    break;\n\n                case 'empty':\n                    this.emptyTemplate = item.template;\n                    break;\n\n                case 'footer':\n                    this.footerTemplate = item.template;\n                    break;\n\n                case 'loader':\n                    this.loaderTemplate = item.template;\n                    break;\n\n                case 'checkicon':\n                    this.checkIconTemplate = item.template;\n                    break;\n\n                case 'filtericon':\n                    this.filterIconTemplate = item.template;\n                    break;\n\n                case 'removetokenicon':\n                    this.removeTokenIconTemplate = item.template;\n                    break;\n\n                case 'closeicon':\n                    this.closeIconTemplate = item.template;\n                    break;\n\n                case 'clearicon':\n                    this.clearIconTemplate = item.template;\n                    break;\n\n                case 'dropdownicon':\n                    this.dropdownIconTemplate = item.template;\n                    break;\n\n                default:\n                    this.itemTemplate = item.template;\n                    break;\n            }\n        });\n    }\n\n    ngAfterViewInit() {\n        if (this.overlayVisible) {\n            this.show();\n        }\n    }\n\n    ngAfterViewChecked() {\n        if (this.filtered) {\n            this.zone.runOutsideAngular(() => {\n                setTimeout(() => {\n                    this.overlayViewChild?.alignOverlay();\n                }, 1);\n            });\n            this.filtered = false;\n        }\n    }\n\n    getOptionLabel(option: any) {\n        return this.optionLabel ? ObjectUtils.resolveFieldData(option, this.optionLabel) : option && option.label != undefined ? option.label : option;\n    }\n\n    getOptionValue(option: any) {\n        return this.optionValue ? ObjectUtils.resolveFieldData(option, this.optionValue) : !this.optionLabel && option && option.value !== undefined ? option.value : option;\n    }\n\n    getOptionGroupLabel(optionGroup: any) {\n        return this.optionGroupLabel ? ObjectUtils.resolveFieldData(optionGroup, this.optionGroupLabel) : optionGroup && optionGroup.label != undefined ? optionGroup.label : optionGroup;\n    }\n\n    getOptionGroupChildren(optionGroup: any) {\n        return this.optionGroupChildren ? ObjectUtils.resolveFieldData(optionGroup, this.optionGroupChildren) : optionGroup.items;\n    }\n\n    isOptionDisabled(option: any) {\n        let disabled = this.optionDisabled ? ObjectUtils.resolveFieldData(option, this.optionDisabled) : option && option.disabled !== undefined ? option.disabled : false;\n        return disabled || (this.maxSelectionLimitReached && !this.isSelected(option));\n    }\n\n    writeValue(value: any): void {\n        this.value = value;\n        this.updateLabel();\n        this.updateFilledState();\n        this.checkSelectionLimit();\n\n        this.cd.markForCheck();\n    }\n\n    checkSelectionLimit() {\n        if (this.selectionLimit && this.value && this.value.length === this.selectionLimit) {\n            this.maxSelectionLimitReached = true;\n        } else {\n            this.maxSelectionLimitReached = false;\n        }\n    }\n\n    updateFilledState() {\n        this.filled = this.value && this.value.length > 0;\n    }\n\n    registerOnChange(fn: Function): void {\n        this.onModelChange = fn;\n    }\n\n    registerOnTouched(fn: Function): void {\n        this.onModelTouched = fn;\n    }\n\n    setDisabledState(val: boolean): void {\n        this.disabled = val;\n        this.cd.markForCheck();\n    }\n\n    onOptionClick(event: { originalEvent: Event; option: any }) {\n        let option = event.option;\n        if (this.isOptionDisabled(option)) {\n            return;\n        }\n\n        let optionValue = this.getOptionValue(option);\n        let selectionIndex = this.findSelectionIndex(optionValue);\n        if (selectionIndex != -1) {\n            this.value = (this.value as any[]).filter((val, i) => i != selectionIndex);\n            this.onRemove.emit({ newValue: this.value, removed: optionValue });\n\n            if (this.selectionLimit) {\n                this.maxSelectionLimitReached = false;\n            }\n        } else {\n            if (!this.selectionLimit || !this.value || this.value.length < this.selectionLimit) {\n                this.value = [...(this.value || []), optionValue];\n            }\n\n            this.checkSelectionLimit();\n        }\n\n        this.onModelChange(this.value);\n        this.onChange.emit({ originalEvent: event.originalEvent, value: this.value, itemValue: optionValue });\n        this.updateLabel();\n        this.updateFilledState();\n    }\n\n    isSelected(option: any) {\n        return this.findSelectionIndex(this.getOptionValue(option)) != -1;\n    }\n\n    findSelectionIndex(val: any): number {\n        let index = -1;\n\n        if (this.value) {\n            for (let i = 0; i < this.value.length; i++) {\n                if (ObjectUtils.equals(this.value[i], val, this.dataKey)) {\n                    index = i;\n                    break;\n                }\n            }\n        }\n\n        return index;\n    }\n\n    get toggleAllDisabled(): boolean {\n        let optionsToRender = this.optionsToRender;\n        if (!optionsToRender || optionsToRender.length === 0) {\n            return true;\n        } else {\n            for (let option of optionsToRender) {\n                if (!this.isOptionDisabled(option)) return false;\n            }\n\n            return true;\n        }\n    }\n\n    toggleAll(event: Event) {\n        if (this.disabled || this.toggleAllDisabled || this.readonly) {\n            return;\n        }\n\n        let allChecked = this.allChecked;\n\n        if (allChecked) this.uncheckAll();\n        else this.checkAll();\n\n        this.onModelChange(this.value);\n        this.onChange.emit({ originalEvent: event, value: this.value });\n        this.updateFilledState();\n        this.updateLabel();\n        event.preventDefault();\n        event.stopPropagation();\n    }\n\n    checkAll() {\n        let optionsToRender = this.optionsToRender;\n        let val: any[] = [];\n\n        optionsToRender.forEach((opt) => {\n            if (!this.group) {\n                let optionDisabled = this.isOptionDisabled(opt);\n                if (!optionDisabled || (optionDisabled && this.isSelected(opt))) {\n                    val.push(this.getOptionValue(opt));\n                }\n            } else {\n                let subOptions = this.getOptionGroupChildren(opt);\n\n                if (subOptions) {\n                    subOptions.forEach((option: any) => {\n                        let optionDisabled = this.isOptionDisabled(option);\n                        if (!optionDisabled || (optionDisabled && this.isSelected(option))) {\n                            val.push(this.getOptionValue(option));\n                        }\n                    });\n                }\n            }\n        });\n\n        this.value = val;\n    }\n\n    uncheckAll() {\n        let optionsToRender = this.optionsToRender;\n        let val: any[] = [];\n\n        optionsToRender.forEach((opt) => {\n            if (!this.group) {\n                let optionDisabled = this.isOptionDisabled(opt);\n                if (optionDisabled && this.isSelected(opt)) {\n                    val.push(this.getOptionValue(opt));\n                }\n            } else {\n                if (opt.items) {\n                    opt.items.forEach((option: any) => {\n                        let optionDisabled = this.isOptionDisabled(option);\n                        if (optionDisabled && this.isSelected(option)) {\n                            val.push(this.getOptionValue(option));\n                        }\n                    });\n                }\n            }\n        });\n\n        this.value = val;\n    }\n\n    show() {\n        if (!this.overlayVisible) {\n            this.overlayVisible = true;\n            this.preventDocumentDefault = true;\n            this.cd.markForCheck();\n        }\n    }\n\n    onOverlayAnimationStart(event: AnimationEvent) {\n        switch (event.toState) {\n            case 'visible':\n                this.virtualScroll && this.scroller?.setContentEl(this.itemsViewChild?.nativeElement);\n\n                if (this.filterInputChild && this.filterInputChild.nativeElement) {\n                    this.preventModelTouched = true;\n\n                    if (this.autofocusFilter) {\n                        this.filterInputChild.nativeElement.focus();\n                    }\n                }\n\n                this.onPanelShow.emit();\n                break;\n\n            case 'void':\n                this.onModelTouched();\n                break;\n        }\n    }\n\n    hide() {\n        this.overlayVisible = false;\n        if (this.resetFilterOnHide) {\n            this.resetFilter();\n        }\n        this.onPanelHide.emit();\n        this.cd.markForCheck();\n    }\n\n    resetFilter() {\n        if (this.filterInputChild && this.filterInputChild.nativeElement) {\n            this.filterInputChild.nativeElement.value = '';\n        }\n\n        this._filterValue = null;\n        this._filteredOptions = null;\n    }\n\n    close(event: Event) {\n        this.hide();\n        event.preventDefault();\n        event.stopPropagation();\n    }\n\n    clear(event: Event) {\n        this.value = null;\n        this.updateLabel();\n        this.updateFilledState();\n        this.checkSelectionLimit();\n        this.onClear.emit();\n        this.onModelChange(this.value);\n        event.stopPropagation();\n    }\n\n    onMouseclick(event: MouseEvent, input: HTMLInputElement) {\n        if (this.disabled || this.readonly || (<Node>event.target).isSameNode(this.accessibleViewChild?.nativeElement)) {\n            return;\n        }\n\n        this.onClick.emit(event);\n\n        if (!this.overlayViewChild?.el?.nativeElement?.contains(event.target) && !DomHandler.hasClass(event.target, 'p-multiselect-token-icon')) {\n            if (this.overlayVisible) {\n                this.hide();\n            } else {\n                this.show();\n            }\n\n            input.focus();\n        }\n        this.cd.detectChanges();\n    }\n\n    removeChip(chip: MultiSelectItem, event: MouseEvent) {\n        this.value = (<any[]>this.value).filter((val) => !ObjectUtils.equals(val, chip, this.dataKey));\n        this.onModelChange(this.value);\n        this.checkSelectionLimit();\n        this.onChange.emit({ originalEvent: event, value: this.value, itemValue: chip });\n        this.updateLabel();\n        this.updateFilledState();\n    }\n\n    onInputFocus(event: Event) {\n        this.focus = true;\n        this.onFocus.emit({ originalEvent: event });\n    }\n\n    onInputBlur(event: Event) {\n        this.focus = false;\n        this.onBlur.emit({ originalEvent: event });\n\n        if (!this.preventModelTouched) {\n            this.onModelTouched();\n        }\n        this.preventModelTouched = false;\n    }\n\n    onOptionKeydown(event: { originalEvent: Event; option: any }) {\n        if (this.readonly) {\n            return;\n        }\n\n        switch ((<KeyboardEvent>event.originalEvent).which) {\n            //down\n            case 40:\n                var nextItem = this.findNextItem((event.originalEvent.target as any).parentElement);\n                if (nextItem) {\n                    nextItem.focus();\n                }\n\n                event.originalEvent.preventDefault();\n                break;\n\n            //up\n            case 38:\n                var prevItem = this.findPrevItem((event.originalEvent.target as any).parentElement);\n                if (prevItem) {\n                    prevItem.focus();\n                }\n\n                event.originalEvent.preventDefault();\n                break;\n\n            //enter\n            case 13:\n                this.onOptionClick(event);\n                event.originalEvent.preventDefault();\n                break;\n\n            case 27:\n            case 9:\n                this.hide();\n                break;\n        }\n    }\n\n    findNextItem(item: any): HTMLElement | null {\n        let nextItem = item.nextElementSibling;\n\n        if (nextItem) return DomHandler.hasClass(nextItem.children[0], 'p-disabled') || DomHandler.isHidden(nextItem.children[0]) || DomHandler.hasClass(nextItem, 'p-multiselect-item-group') ? this.findNextItem(nextItem) : nextItem.children[0];\n        else return null;\n    }\n\n    findPrevItem(item: any): HTMLElement | null {\n        let prevItem = item.previousElementSibling;\n\n        if (prevItem) return DomHandler.hasClass(prevItem.children[0], 'p-disabled') || DomHandler.isHidden(prevItem.children[0]) || DomHandler.hasClass(prevItem, 'p-multiselect-item-group') ? this.findPrevItem(prevItem) : prevItem.children[0];\n        else return null;\n    }\n\n    onKeydown(event: KeyboardEvent) {\n        switch (event.which) {\n            //down\n            case 40:\n                if (!this.overlayVisible && event.altKey) {\n                    this.show();\n                    event.preventDefault();\n                }\n                break;\n\n            //space\n            case 32:\n                if (!this.overlayVisible) {\n                    this.show();\n                    event.preventDefault();\n                }\n                break;\n\n            //escape\n            case 27:\n                this.hide();\n                break;\n        }\n    }\n\n    updateLabel() {\n        if (this.value && this.options && this.value.length && this.displaySelectedLabel) {\n            let label = '';\n            for (let i = 0; i < this.value.length; i++) {\n                let itemLabel = this.findLabelByValue(this.value[i]);\n                if (itemLabel) {\n                    if (label.length > 0) {\n                        label = label + ', ';\n                    }\n                    label = label + itemLabel;\n                }\n            }\n\n            if (this.value.length <= this.maxSelectedLabels || this.selectedItemsLabel === 'ellipsis') {\n                this.valuesAsString = label;\n            } else {\n                let pattern = /{(.*?)}/;\n                if (pattern.test(this.selectedItemsLabel)) {\n                    this.valuesAsString = this.selectedItemsLabel.replace((this.selectedItemsLabel as any).match(pattern)[0], this.value.length + '');\n                } else {\n                    this.valuesAsString = this.selectedItemsLabel;\n                }\n            }\n        } else {\n            this.valuesAsString = this.placeholder || this.defaultLabel;\n        }\n    }\n\n    findLabelByValue(val: any): string {\n        if (this.group) {\n            let label = null;\n\n            for (let i = 0; i < (this.options as any[]).length; i++) {\n                let subOptions = this.getOptionGroupChildren((this.options as any[])[i]);\n                if (subOptions) {\n                    label = this.searchLabelByValue(val, subOptions);\n\n                    if (label) {\n                        break;\n                    }\n                }\n            }\n\n            return label as string;\n        } else {\n            return this.searchLabelByValue(val, this.options as any[]);\n        }\n    }\n\n    searchLabelByValue(val: any, options: any[]): string {\n        let label = null;\n\n        for (let i = 0; i < options.length; i++) {\n            let option = options[i];\n            let optionValue = this.getOptionValue(option);\n\n            if ((val == null && optionValue == null) || ObjectUtils.equals(val, optionValue, this.dataKey)) {\n                label = this.getOptionLabel(option);\n                break;\n            }\n        }\n\n        return label;\n    }\n\n    get allChecked(): boolean {\n        let optionsToRender = this.optionsToRender;\n        if (!optionsToRender || optionsToRender.length === 0) {\n            return false;\n        } else {\n            let selectedDisabledItemsLength = 0;\n            let unselectedDisabledItemsLength = 0;\n            let selectedEnabledItemsLength = 0;\n            let visibleOptionsLength = this.group ? 0 : this.optionsToRender.length;\n\n            for (let option of optionsToRender) {\n                if (!this.group) {\n                    let disabled = this.isOptionDisabled(option);\n                    let selected = this.isSelected(option);\n\n                    if (disabled) {\n                        if (selected) selectedDisabledItemsLength++;\n                        else unselectedDisabledItemsLength++;\n                    } else {\n                        if (selected) selectedEnabledItemsLength++;\n                        else return false;\n                    }\n                } else {\n                    for (let opt of this.getOptionGroupChildren(option)) {\n                        let disabled = this.isOptionDisabled(opt);\n                        let selected = this.isSelected(opt);\n\n                        if (disabled) {\n                            if (selected) selectedDisabledItemsLength++;\n                            else unselectedDisabledItemsLength++;\n                        } else {\n                            if (selected) selectedEnabledItemsLength++;\n                            else {\n                                return false;\n                            }\n                        }\n\n                        visibleOptionsLength++;\n                    }\n                }\n            }\n\n            return (visibleOptionsLength === selectedDisabledItemsLength ||\n                visibleOptionsLength === selectedEnabledItemsLength ||\n                (selectedEnabledItemsLength && visibleOptionsLength === selectedEnabledItemsLength + unselectedDisabledItemsLength + selectedDisabledItemsLength)) as boolean;\n        }\n    }\n\n    get optionsToRender(): any[] {\n        return (this._filteredOptions || this.options) as any[];\n    }\n\n    get emptyMessageLabel(): string {\n        return this.emptyMessage || this.config.getTranslation(TranslationKeys.EMPTY_MESSAGE);\n    }\n\n    get emptyFilterMessageLabel(): string {\n        return this.emptyFilterMessage || this.config.getTranslation(TranslationKeys.EMPTY_FILTER_MESSAGE);\n    }\n\n    hasFilter() {\n        return this._filterValue && this._filterValue.trim().length > 0;\n    }\n\n    isEmpty() {\n        return !this.optionsToRender || (this.optionsToRender && this.optionsToRender.length === 0);\n    }\n\n    onFilterInputChange(event: KeyboardEvent) {\n        this._filterValue = (<HTMLInputElement>event.target).value;\n        this.activateFilter();\n        this.filtered = true;\n        this.onFilter.emit({ originalEvent: event, filter: this._filterValue });\n        this.cd.detectChanges();\n    }\n\n    activateFilter() {\n        if (this.hasFilter() && this._options) {\n            let searchFields: string[] = (this.filterBy || this.optionLabel || 'label').split(',');\n\n            if (this.group) {\n                let filteredGroups = [];\n                for (let optgroup of this.options as any[]) {\n                    let filteredSubOptions = this.filterService.filter(this.getOptionGroupChildren(optgroup), searchFields, this.filterValue, this.filterMatchMode, this.filterLocale);\n                    if (filteredSubOptions && filteredSubOptions.length) {\n                        filteredGroups.push({ ...optgroup, ...{ [this.optionGroupChildren]: filteredSubOptions } });\n                    }\n                }\n\n                this._filteredOptions = filteredGroups;\n            } else {\n                this._filteredOptions = this.filterService.filter(this.options as any[], searchFields, this._filterValue, this.filterMatchMode, this.filterLocale);\n            }\n        } else {\n            this._filteredOptions = null;\n        }\n    }\n\n    onHeaderCheckboxFocus() {\n        this.headerCheckboxFocus = true;\n    }\n\n    onHeaderCheckboxBlur() {\n        this.headerCheckboxFocus = false;\n    }\n}\n\n@NgModule({\n    imports: [CommonModule, OverlayModule, SharedModule, TooltipModule, RippleModule, ScrollerModule, CheckIcon, SearchIcon, TimesCircleIcon, TimesIcon, ChevronDownIcon, CheckIcon],\n    exports: [MultiSelect, OverlayModule, SharedModule, ScrollerModule],\n    declarations: [MultiSelect, MultiSelectItem]\n})\nexport class MultiSelectModule {}\n"]}
|
2224
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multiselect.js","sourceRoot":"","sources":["../../../src/app/components/multiselect/multiselect.ts"],"names":[],"mappings":"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","sourcesContent":["import { AnimationEvent } from '@angular/animations';\nimport { CommonModule } from '@angular/common';\nimport {\n    AfterContentInit,\n    AfterViewChecked,\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    computed,\n    ContentChild,\n    ContentChildren,\n    effect,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    Input,\n    NgModule,\n    NgZone,\n    OnInit,\n    Output,\n    QueryList,\n    Renderer2,\n    signal,\n    TemplateRef,\n    ViewChild,\n    ViewEncapsulation\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { FilterService, Footer, Header, OverlayOptions, OverlayService, PrimeNGConfig, PrimeTemplate, SharedModule, TranslationKeys } from 'primeng/api';\nimport { DomHandler } from 'primeng/dom';\nimport { Overlay, OverlayModule } from 'primeng/overlay';\nimport { RippleModule } from 'primeng/ripple';\nimport { Scroller, ScrollerModule } from 'primeng/scroller';\nimport { ScrollerOptions } from 'primeng/api';\nimport { TooltipModule } from 'primeng/tooltip';\nimport { ObjectUtils, UniqueComponentId } from 'primeng/utils';\nimport { CheckIcon } from 'primeng/icons/check';\nimport { SearchIcon } from 'primeng/icons/search';\nimport { TimesCircleIcon } from 'primeng/icons/timescircle';\nimport { TimesIcon } from 'primeng/icons/times';\nimport { ChevronDownIcon } from 'primeng/icons/chevrondown';\nimport { Nullable } from 'primeng/ts-helpers';\nimport { MultiSelectRemoveEvent, MultiSelectFilterOptions, MultiSelectFilterEvent, MultiSelectBlurEvent, MultiSelectChangeEvent, MultiSelectFocusEvent, MultiSelectLazyLoadEvent } from './multiselect.interface';\n\nexport const MULTISELECT_VALUE_ACCESSOR: any = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => MultiSelect),\n    multi: true\n};\n\n@Component({\n    selector: 'p-multiSelectItem',\n    template: `\n        <li\n            pRipple\n            [ngStyle]=\"{ height: itemSize + 'px' }\"\n            class=\"p-multiselect-item\"\n            [ngClass]=\"{ 'p-multiselect-item': true, 'p-highlight': selected, 'p-disabled': disabled, 'p-focus': focused }\"\n            [id]=\"id\"\n            [attr.aria-label]=\"label\"\n            [attr.aria-setsize]=\"ariaSetSize\"\n            [attr.aria-posinset]=\"ariaPosInset\"\n            [attr.aria-selected]=\"selected\"\n            [attr.data-p-focused]=\"focused\"\n            [attr.data-p-highlight]=\"selected\"\n            [attr.data-p-disabled]=\"disabled\"\n            (click)=\"onOptionClick($event)\"\n            (mouseenter)=\"onOptionMouseEnter($event)\"\n        >\n            <div class=\"p-checkbox p-component\">\n                <div class=\"p-checkbox-box\" [ngClass]=\"{ 'p-highlight': selected }\" [attr.aria-checked]=\"selected\">\n                    <ng-container *ngIf=\"selected\">\n                        <CheckIcon *ngIf=\"!checkIconTemplate\" [styleClass]=\"'p-checkbox-icon'\" [attr.aria-hidden]=\"true\" />\n                        <span *ngIf=\"checkIconTemplate\" class=\"p-checkbox-icon\" [attr.aria-hidden]=\"true\">\n                            <ng-template *ngTemplateOutlet=\"checkIconTemplate\"></ng-template>\n                        </span>\n                    </ng-container>\n                </div>\n            </div>\n            <span *ngIf=\"!template\">{{ label ?? 'empty' }}</span>\n            <ng-container *ngTemplateOutlet=\"template; context: { $implicit: option }\"></ng-container>\n        </li>\n    `,\n    encapsulation: ViewEncapsulation.None,\n    host: {\n        class: 'p-element'\n    }\n})\nexport class MultiSelectItem {\n    @Input() id: string | undefined;\n\n    @Input() option: any;\n\n    @Input() selected: boolean | undefined;\n\n    @Input() label: string | undefined;\n\n    @Input() disabled: boolean | undefined;\n\n    @Input() itemSize: number | undefined;\n\n    @Input() focused: boolean | undefined;\n\n    @Input() ariaPosInset: string | undefined;\n\n    @Input() ariaSetSize: string | undefined;\n\n    @Input() template: TemplateRef<any> | undefined;\n\n    @Input() checkIconTemplate: TemplateRef<any> | undefined;\n\n    @Output() onClick: EventEmitter<any> = new EventEmitter();\n\n    @Output() onMouseEnter: EventEmitter<any> = new EventEmitter();\n\n    onOptionClick(event: Event) {\n        this.onClick.emit({\n            originalEvent: event,\n            option: this.option,\n            selected: this.selected\n        });\n    }\n\n    onOptionMouseEnter(event: Event) {\n        this.onMouseEnter.emit({\n            originalEvent: event,\n            option: this.option,\n            selected: this.selected\n        });\n    }\n}\n/**\n * MultiSelect is used to select multiple items from a collection.\n * @group Components\n */\n@Component({\n    selector: 'p-multiSelect',\n    template: `\n        <div #container [attr.id]=\"id\" [ngClass]=\"containerClass\" [ngStyle]=\"style\" [class]=\"styleClass\" (click)=\"onContainerClick($event)\">\n            <div class=\"p-hidden-accessible\" [attr.data-p-hidden-accessible]=\"true\">\n                <input\n                    #focusInput\n                    [pTooltip]=\"tooltip\"\n                    [tooltipPosition]=\"tooltipPosition\"\n                    [positionStyle]=\"tooltipPositionStyle\"\n                    [tooltipStyleClass]=\"tooltipStyleClass\"\n                    [attr.aria-disabled]=\"disabled\"\n                    [attr.id]=\"inputId\"\n                    role=\"combobox\"\n                    [attr.aria-label]=\"ariaLabel\"\n                    [attr.aria-labelledby]=\"ariaLabelledBy\"\n                    [attr.aria-haspopup]=\"'listbox'\"\n                    [attr.aria-expanded]=\"overlayVisible\"\n                    [attr.aria-controls]=\"id + '_list'\"\n                    [attr.tabindex]=\"!disabled ? tabindex : -1\"\n                    [attr.aria-activedescendant]=\"focused ? focusedOptionId : undefined\"\n                    (focus)=\"onInputFocus($event)\"\n                    (blur)=\"onInputBlur($event)\"\n                    (keydown)=\"onKeyDown($event)\"\n                />\n            </div>\n            <div class=\"p-multiselect-label-container\" [pTooltip]=\"tooltip\" [tooltipPosition]=\"tooltipPosition\" [positionStyle]=\"tooltipPositionStyle\" [tooltipStyleClass]=\"tooltipStyleClass\">\n                <div [ngClass]=\"labelClass\">\n                    <ng-container *ngIf=\"!selectedItemsTemplate\">\n                        <ng-container *ngIf=\"display === 'comma'\">{{ label() || 'empty' }}</ng-container>\n                        <ng-container *ngIf=\"display === 'chip'\">\n                            <div #token *ngFor=\"let item of chipSelectedItems(); let i = index\" class=\"p-multiselect-token\">\n                                <span class=\"p-multiselect-token-label\">{{ getLabelByValue(item) }}</span>\n                                <ng-container *ngIf=\"!disabled\">\n                                    <TimesCircleIcon *ngIf=\"!removeTokenIconTemplate\" [styleClass]=\"'p-multiselect-token-icon'\" (click)=\"removeOption(item, event)\" [attr.data-pc-section]=\"'clearicon'\" [attr.aria-hidden]=\"true\" />\n                                    <span *ngIf=\"removeTokenIconTemplate\" class=\"p-multiselect-token-icon\" (click)=\"removeOption(item, event)\" [attr.data-pc-section]=\"'clearicon'\" [attr.aria-hidden]=\"true\">\n                                        <ng-container *ngTemplateOutlet=\"removeTokenIconTemplate\"></ng-container>\n                                    </span>\n                                </ng-container>\n                            </div>\n                            <ng-container *ngIf=\"!modelValue() || modelValue().length === 0\">{{ placeholder || defaultLabel || 'empty' }}</ng-container>\n                        </ng-container>\n                    </ng-container>\n                    <ng-container *ngTemplateOutlet=\"selectedItemsTemplate; context: { $implicit: modelValue(), removeChip: removeOption.bind(this) }\"></ng-container>\n                </div>\n                <ng-container *ngIf=\"modelValue() != null && filled && !disabled && showClear\">\n                    <TimesIcon *ngIf=\"!clearIconTemplate\" [styleClass]=\"'p-multiselect-clear-icon'\" (click)=\"clear($event)\" [attr.data-pc-section]=\"'clearicon'\" [attr.aria-hidden]=\"true\" />\n                    <span *ngIf=\"clearIconTemplate\" class=\"p-multiselect-clear-icon\" (click)=\"clear($event)\" [attr.data-pc-section]=\"'clearicon'\" [attr.aria-hidden]=\"true\">\n                        <ng-template *ngTemplateOutlet=\"clearIconTemplate\"></ng-template>\n                    </span>\n                </ng-container>\n            </div>\n            <div class=\"p-multiselect-trigger\">\n                <ng-container *ngIf=\"!dropdownIconTemplate\">\n                    <span *ngIf=\"dropdownIcon\" class=\"p-multiselect-trigger-icon\" [ngClass]=\"dropdownIcon\" [attr.data-pc-section]=\"'triggericon'\" [attr.aria-hidden]=\"true\"></span>\n                    <ChevronDownIcon *ngIf=\"!dropdownIcon\" [styleClass]=\"'p-multiselect-trigger-icon'\" [attr.data-pc-section]=\"'triggericon'\" [attr.aria-hidden]=\"true\" />\n                </ng-container>\n                <span *ngIf=\"dropdownIconTemplate\" class=\"p-multiselect-trigger-icon\" [attr.data-pc-section]=\"'triggericon'\" [attr.aria-hidden]=\"true\">\n                    <ng-template *ngTemplateOutlet=\"dropdownIconTemplate\"></ng-template>\n                </span>\n            </div>\n            <p-overlay\n                #overlay\n                [(visible)]=\"overlayVisible\"\n                [options]=\"overlayOptions\"\n                [target]=\"'@parent'\"\n                [appendTo]=\"appendTo\"\n                [autoZIndex]=\"autoZIndex\"\n                [baseZIndex]=\"baseZIndex\"\n                [showTransitionOptions]=\"showTransitionOptions\"\n                [hideTransitionOptions]=\"hideTransitionOptions\"\n                (onAnimationStart)=\"onOverlayAnimationStart($event)\"\n                (onHide)=\"hide()\"\n            >\n                <ng-template pTemplate=\"content\">\n                    <div [ngClass]=\"'p-multiselect-panel p-component'\" [ngStyle]=\"panelStyle\" [class]=\"panelStyleClass\">\n                        <span\n                            #firstHiddenFocusableEl\n                            role=\"presentation\"\n                            [attr.aria-hidden]=\"'true'\"\n                            class=\"p-hidden-accessible p-hidden-focusable\"\n                            [attr.tabindex]=\"0\"\n                            (focus)=\"onFirstHiddenFocus($event)\"\n                            [attr.data-p-hidden-accessible]=\"true\"\n                            [attr.data-p-hidden-focusable]=\"true\"\n                        >\n                        </span>\n                        <div class=\"p-multiselect-header\" *ngIf=\"showHeader\">\n                            <ng-content select=\"p-header\"></ng-content>\n                            <ng-container *ngTemplateOutlet=\"headerTemplate\"></ng-container>\n                            <ng-container *ngIf=\"filterTemplate; else builtInFilterElement\">\n                                <ng-container *ngTemplateOutlet=\"filterTemplate; context: { options: filterOptions }\"></ng-container>\n                            </ng-container>\n                            <ng-template #builtInFilterElement>\n                                <div\n                                    class=\"p-checkbox p-component\"\n                                    *ngIf=\"showToggleAll && !selectionLimit\"\n                                    [ngClass]=\"{ 'p-checkbox-disabled': disabled || toggleAllDisabled }\"\n                                    (click)=\"onToggleAll($event)\"\n                                    (keydown)=\"onHeaderCheckboxKeyDown($event)\"\n                                >\n                                    <div class=\"p-hidden-accessible\" [attr.data-p-hidden-accessible]=\"true\">\n                                        <input\n                                            #headerCheckbox\n                                            type=\"checkbox\"\n                                            [readonly]=\"readonly\"\n                                            [attr.checked]=\"allSelected()\"\n                                            (focus)=\"onHeaderCheckboxFocus()\"\n                                            (blur)=\"onHeaderCheckboxBlur()\"\n                                            [disabled]=\"disabled || toggleAllDisabled\"\n                                            [attr.aria-label]=\"toggleAllAriaLabel\"\n                                        />\n                                    </div>\n                                    <div class=\"p-checkbox-box\" role=\"checkbox\" [attr.aria-checked]=\"allSelected()\" [ngClass]=\"{ 'p-highlight': allSelected(), 'p-focus': headerCheckboxFocus, 'p-disabled': disabled || toggleAllDisabled }\">\n                                        <ng-container *ngIf=\"allSelected()\">\n                                            <CheckIcon [styleClass]=\"'p-checkbox-icon'\" *ngIf=\"!checkIconTemplate\" [attr.aria-hidden]=\"true\" />\n                                            <span *ngIf=\"checkIconTemplate\" class=\"p-checkbox-icon\" [attr.aria-hidden]=\"true\">\n                                                <ng-template *ngTemplateOutlet=\"checkIconTemplate\"></ng-template>\n                                            </span>\n                                        </ng-container>\n                                    </div>\n                                </div>\n                                <div class=\"p-multiselect-filter-container\" *ngIf=\"filter\">\n                                    <input\n                                        #filterInput\n                                        type=\"text\"\n                                        [attr.autocomplete]=\"autocomplete\"\n                                        [attr.placeholder]=\"filterPlaceHolder\"\n                                        role=\"searchbox\"\n                                        [attr.aria-owns]=\"id + '_list'\"\n                                        [attr.aria-activedescendant]=\"focusedOptionId\"\n                                        [value]=\"_filterValue() || ''\"\n                                        (input)=\"onFilterInputChange($event)\"\n                                        (keydown)=\"onFilterKeyDown($event)\"\n                                        (blur)=\"onFilterBlur($event)\"\n                                        class=\"p-multiselect-filter p-inputtext p-component\"\n                                        [disabled]=\"disabled\"\n                                        [attr.placeholder]=\"filterPlaceHolder\"\n                                        [attr.aria-label]=\"ariaFilterLabel\"\n                                    />\n                                    <SearchIcon [styleClass]=\"'p-multiselect-filter-icon'\" *ngIf=\"!filterIconTemplate\" />\n                                    <span *ngIf=\"filterIconTemplate\" class=\"p-multiselect-filter-icon\">\n                                        <ng-template *ngTemplateOutlet=\"filterIconTemplate\"></ng-template>\n                                    </span>\n                                </div>\n\n                                <button class=\"p-multiselect-close p-link p-button-icon-only\" type=\"button\" (click)=\"close($event)\" pRipple>\n                                    <TimesIcon [styleClass]=\"'p-multiselect-close-icon'\" *ngIf=\"!closeIconTemplate\" />\n                                    <span *ngIf=\"closeIconTemplate\" class=\"p-multiselect-close-icon\">\n                                        <ng-template *ngTemplateOutlet=\"closeIconTemplate\"></ng-template>\n                                    </span>\n                                </button>\n                            </ng-template>\n                        </div>\n                        <div class=\"p-multiselect-items-wrapper\" [style.max-height]=\"virtualScroll ? 'auto' : scrollHeight || 'auto'\">\n                            <p-scroller\n                                *ngIf=\"virtualScroll\"\n                                #scroller\n                                [items]=\"visibleOptions()\"\n                                [style]=\"{ height: scrollHeight }\"\n                                [itemSize]=\"virtualScrollItemSize || _itemSize\"\n                                [autoSize]=\"true\"\n                                [tabindex]=\"-1\"\n                                [lazy]=\"lazy\"\n                                (onLazyLoad)=\"onLazyLoad.emit($event)\"\n                                [options]=\"virtualScrollOptions\"\n                            >\n                                <ng-template pTemplate=\"content\" let-items let-scrollerOptions=\"options\">\n                                    <ng-container *ngTemplateOutlet=\"buildInItems; context: { $implicit: items, options: scrollerOptions }\"></ng-container>\n                                </ng-template>\n                                <ng-container *ngIf=\"loaderTemplate\">\n                                    <ng-template pTemplate=\"loader\" let-scrollerOptions=\"options\">\n                                        <ng-container *ngTemplateOutlet=\"loaderTemplate; context: { options: scrollerOptions }\"></ng-container>\n                                    </ng-template>\n                                </ng-container>\n                            </p-scroller>\n                            <ng-container *ngIf=\"!virtualScroll\">\n                                <ng-container *ngTemplateOutlet=\"buildInItems; context: { $implicit: visibleOptions(), options: {} }\"></ng-container>\n                            </ng-container>\n\n                            <ng-template #buildInItems let-items let-scrollerOptions=\"options\">\n                                <ul #items class=\"p-multiselect-items p-component\" [ngClass]=\"scrollerOptions.contentStyleClass\" [style]=\"scrollerOptions.contentStyle\" role=\"listbox\" aria-multiselectable=\"true\">\n                                    <ng-template ngFor let-option [ngForOf]=\"items\" let-i=\"index\">\n                                        <ng-container *ngIf=\"option.group\">\n                                            <li [attr.id]=\"id + '_' + getOptionIndex(i, scrollerOptions)\" class=\"p-multiselect-item-group\" [ngStyle]=\"{ height: scrollerOptions.itemSize + 'px' }\" role=\"option\">\n                                                <span *ngIf=\"!groupTemplate\">{{ getOptionGroupLabel(option.optionGroup) }}</span>\n                                                <ng-container *ngTemplateOutlet=\"groupTemplate; context: { $implicit: option.optionGroup }\"></ng-container>\n                                            </li>\n                                        </ng-container>\n                                        <ng-container *ngIf=\"!option.group\">\n                                            <p-multiSelectItem\n                                                [id]=\"id + '_' + getOptionIndex(i, scrollerOptions)\"\n                                                [option]=\"option\"\n                                                [selected]=\"isSelected(option)\"\n                                                [label]=\"getOptionLabel(option)\"\n                                                [disabled]=\"isOptionDisabled(option)\"\n                                                [template]=\"itemTemplate\"\n                                                [checkIconTemplate]=\"checkIconTemplate\"\n                                                [itemSize]=\"scrollerOptions.itemSize\"\n                                                [focused]=\"focusedOptionIndex() === getOptionIndex(i, scrollerOptions)\"\n                                                [ariaPosInset]=\"getAriaPosInset(getOptionIndex(i, scrollerOptions))\"\n                                                [ariaSetSize]=\"ariaSetSize\"\n                                                (onClick)=\"onOptionSelect($event, false, getOptionIndex(i, scrollerOptions))\"\n                                                (onMouseEnter)=\"onOptionMouseEnter($event, getOptionIndex(i, scrollerOptions))\"\n                                            ></p-multiSelectItem>\n                                        </ng-container>\n                                    </ng-template>\n\n                                    <li *ngIf=\"hasFilter() && isEmpty()\" class=\"p-multiselect-empty-message\" [ngStyle]=\"{ height: scrollerOptions.itemSize + 'px' }\">\n                                        <ng-container *ngIf=\"!emptyFilterTemplate && !emptyTemplate; else emptyFilter\">\n                                            {{ emptyFilterMessageLabel }}\n                                        </ng-container>\n                                        <ng-container #emptyFilter *ngTemplateOutlet=\"emptyFilterTemplate || emptyTemplate\"></ng-container>\n                                    </li>\n                                    <li *ngIf=\"!hasFilter() && isEmpty()\" class=\"p-multiselect-empty-message\" [ngStyle]=\"{ height: scrollerOptions.itemSize + 'px' }\">\n                                        <ng-container *ngIf=\"!emptyTemplate; else empty\">\n                                            {{ emptyMessageLabel }}\n                                        </ng-container>\n                                        <ng-container #empty *ngTemplateOutlet=\"emptyTemplate\"></ng-container>\n                                    </li>\n                                </ul>\n                            </ng-template>\n                        </div>\n                        <div class=\"p-multiselect-footer\" *ngIf=\"footerFacet || footerTemplate\">\n                            <ng-content select=\"p-footer\"></ng-content>\n                            <ng-container *ngTemplateOutlet=\"footerTemplate\"></ng-container>\n                        </div>\n\n                        <span\n                            #lastHiddenFocusableEl\n                            role=\"presentation\"\n                            [attr.aria-hidden]=\"true\"\n                            class=\"p-hidden-accessible p-hidden-focusable\"\n                            [attr.tabindex]=\"0\"\n                            (focus)=\"onLastHiddenFocus($event)\"\n                            [attr.data-p-hidden-accessible]=\"true\"\n                            [attr.data-p-hidden-focusable]=\"true\"\n                        ></span>\n                    </div>\n                </ng-template>\n            </p-overlay>\n        </div>\n    `,\n    host: {\n        class: 'p-element p-inputwrapper',\n        '[class.p-inputwrapper-filled]': 'filled',\n        '[class.p-inputwrapper-focus]': 'focused || overlayVisible'\n    },\n    providers: [MULTISELECT_VALUE_ACCESSOR],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    styleUrls: ['./multiselect.css']\n})\nexport class MultiSelect implements OnInit, AfterViewInit, AfterContentInit, AfterViewChecked, ControlValueAccessor {\n    /**\n     * Unique identifier of the component\n     * @group Props\n     */\n    @Input() id: string | undefined;\n    /**\n     * Defines a string that labels the input for accessibility.\n     * @group Props\n     */\n    @Input() ariaLabel: string | undefined;\n    /**\n     * Inline style of the element.\n     * @group Props\n     */\n    @Input() style: { [klass: string]: any } | null | undefined;\n    /**\n     * Style class of the element.\n     * @group Props\n     */\n    @Input() styleClass: string | undefined;\n    /**\n     * Inline style of the overlay panel.\n     * @group Props\n     */\n    @Input() panelStyle: any;\n    /**\n     * Style class of the overlay panel element.\n     * @group Props\n     */\n    @Input() panelStyleClass: string | undefined;\n    /**\n     * Identifier of the focus input to match a label defined for the component.\n     * @group Props\n     */\n    @Input() inputId: string | undefined;\n    /**\n     * When present, it specifies that the element should be disabled.\n     * @group Props\n     */\n    @Input() disabled: boolean | undefined;\n    /**\n     * When present, it specifies that the component cannot be edited.\n     * @group Props\n     */\n    @Input() readonly: boolean | undefined;\n    /**\n     * Whether to display options as grouped when nested options are provided.\n     * @group Props\n     */\n    @Input() group: boolean | undefined;\n    /**\n     * When specified, displays an input field to filter the items on keyup.\n     * @group Props\n     */\n    @Input() filter: boolean = true;\n    /**\n     * Defines placeholder of the filter input.\n     * @group Props\n     */\n    @Input() filterPlaceHolder: string | undefined;\n    /**\n     * Locale to use in filtering. The default locale is the host environment's current locale.\n     * @group Props\n     */\n    @Input() filterLocale: string | undefined;\n    /**\n     * Specifies the visibility of the options panel.\n     * @group Props\n     */\n    @Input() overlayVisible: boolean | undefined;\n    /**\n     * Index of the element in tabbing order.\n     * @group Props\n     */\n    @Input() tabindex: number | undefined = 0;\n    /**\n     * Target element to attach the overlay, valid values are \"body\" or a local ng-template variable of another element (note: use binding with brackets for template variables, e.g. [appendTo]=\"mydiv\" for a div element having #mydiv as variable name).\n     * @group Props\n     */\n    @Input() appendTo: HTMLElement | ElementRef | TemplateRef<any> | string | null | undefined | any;\n    /**\n     * A property to uniquely identify a value in options.\n     * @group Props\n     */\n    @Input() dataKey: string | undefined;\n    /**\n     * Name of the input element.\n     * @group Props\n     */\n    @Input() name: string | undefined;\n    /**\n     * Establishes relationships between the component and label(s) where its value should be one or more element IDs.\n     * @group Props\n     */\n    @Input() ariaLabelledBy: string | undefined;\n    /**\n     * Whether to show labels of selected item labels or use default label.\n     * @group Props\n     */\n    @Input() displaySelectedLabel: boolean = true;\n    /**\n     * Decides how many selected item labels to show at most.\n     * @group Props\n     */\n    @Input() maxSelectedLabels: number = 3;\n    /**\n     * Decides how many selected item labels to show at most.\n     * @group Props\n     */\n    @Input() selectionLimit: number | undefined;\n    /**\n     * Label to display after exceeding max selected labels e.g. ({0} items selected), defaults \"ellipsis\" keyword to indicate a text-overflow.\n     * @group Props\n     */\n    @Input() selectedItemsLabel: string = '{0} items selected';\n    /**\n     * Whether to show the checkbox at header to toggle all items at once.\n     * @group Props\n     */\n    @Input() showToggleAll: boolean = true;\n    /**\n     * Text to display when filtering does not return any results.\n     * @group Props\n     */\n    @Input() emptyFilterMessage: string = '';\n    /**\n     * Text to display when there is no data. Defaults to global value in i18n translation configuration.\n     * @group Props\n     */\n    @Input() emptyMessage: string = '';\n    /**\n     * Clears the filter value when hiding the dropdown.\n     * @group Props\n     */\n    @Input() resetFilterOnHide: boolean = false;\n    /**\n     * Icon class of the dropdown icon.\n     * @group Props\n     */\n    @Input() dropdownIcon: string | undefined;\n    /**\n     * Name of the label field of an option.\n     * @group Props\n     */\n    @Input() optionLabel: string | undefined;\n    /**\n     * Name of the value field of an option.\n     * @group Props\n     */\n    @Input() optionValue: string | undefined;\n    /**\n     * Name of the disabled field of an option.\n     * @group Props\n     */\n    @Input() optionDisabled: string | undefined;\n    /**\n     * Name of the label field of an option group.\n     * @group Props\n     */\n    @Input() optionGroupLabel: string | undefined = 'label';\n    /**\n     * Name of the options field of an option group.\n     * @group Props\n     */\n    @Input() optionGroupChildren: string = 'items';\n    /**\n     * Whether to show the header.\n     * @group Props\n     */\n    @Input() showHeader: boolean = true;\n    /**\n     * When filtering is enabled, filterBy decides which field or fields (comma separated) to search against.\n     * @group Props\n     */\n    @Input() filterBy: string | undefined;\n    /**\n     * Height of the viewport in pixels, a scrollbar is defined if height of list exceeds this value.\n     * @group Props\n     */\n    @Input() scrollHeight: string = '200px';\n    /**\n     * Defines if data is loaded and interacted with in lazy manner.\n     * @group Props\n     */\n    @Input() lazy: boolean = false;\n    /**\n     * Whether the data should be loaded on demand during scroll.\n     * @group Props\n     */\n    @Input() virtualScroll: boolean | undefined;\n    /**\n     * Height of an item in the list for VirtualScrolling.\n     * @group Props\n     */\n    @Input() virtualScrollItemSize: number | undefined;\n    /**\n     * Whether to use the scroller feature. The properties of scroller component can be used like an object in it.\n     * @group Props\n     */\n    @Input() virtualScrollOptions: ScrollerOptions | undefined;\n    /**\n     * Whether to use overlay API feature. The properties of overlay API can be used like an object in it.\n     * @group Props\n     */\n    @Input() overlayOptions: OverlayOptions | undefined;\n    /**\n     * Defines a string that labels the filter input.\n     * @group Props\n     */\n    @Input() ariaFilterLabel: string | undefined;\n    /**\n     * Defines how the items are filtered.\n     * @group Props\n     */\n    @Input() filterMatchMode: 'contains' | 'startsWith' | 'endsWith' | 'equals' | 'notEquals' | 'in' | 'lt' | 'lte' | 'gt' | 'gte' = 'contains';\n    /**\n     * Advisory information to display in a tooltip on hover.\n     * @group Props\n     */\n    @Input() tooltip: string = '';\n    /**\n     * Position of the tooltip.\n     * @group Props\n     */\n    @Input() tooltipPosition: 'top' | 'left' | 'right' | 'bottom' = 'right';\n    /**\n     * Type of CSS position.\n     * @group Props\n     */\n    @Input() tooltipPositionStyle: string = 'absolute';\n    /**\n     * Style class of the tooltip.\n     * @group Props\n     */\n    @Input() tooltipStyleClass: string | undefined;\n    /**\n     * Applies focus to the filter element when the overlay is shown.\n     * @group Props\n     */\n    @Input() autofocusFilter: boolean = true;\n    /**\n     * Defines how the selected items are displayed.\n     * @group Props\n     */\n    @Input() display: string | 'comma' | 'chip' = 'comma';\n    /**\n     * Defines the autocomplete is active.\n     * @group Props\n     */\n    @Input() autocomplete: string = 'off';\n    /**\n     * When enabled, a clear icon is displayed to clear the value.\n     * @group Props\n     */\n    @Input() showClear: boolean = false;\n    /**\n     * @deprecated since v14.2.0, use overlayOptions property instead.\n     * Whether to automatically manage layering.\n     * @group Props\n     */\n    @Input() get autoZIndex(): boolean | undefined {\n        return this._autoZIndex;\n    }\n    set autoZIndex(val: boolean | undefined) {\n        this._autoZIndex = val;\n        console.warn('The autoZIndex property is deprecated since v14.2.0, use overlayOptions property instead.');\n    }\n    /**\n     * @deprecated since v14.2.0, use overlayOptions property instead.\n     * Base zIndex value to use in layering.\n     * @group Props\n     */\n    @Input() get baseZIndex(): number | undefined {\n        return this._baseZIndex;\n    }\n    set baseZIndex(val: number | undefined) {\n        this._baseZIndex = val;\n        console.warn('The baseZIndex property is deprecated since v14.2.0, use overlayOptions property instead.');\n    }\n    /**\n     * Transition options of the show animation.\n     * @group Props\n     * @deprecated since v14.2.0, use overlayOptions property instead.\n     */\n    @Input() get showTransitionOptions(): string | undefined {\n        return this._showTransitionOptions;\n    }\n    set showTransitionOptions(val: string | undefined) {\n        this._showTransitionOptions = val;\n        console.warn('The showTransitionOptions property is deprecated since v14.2.0, use overlayOptions property instead.');\n    }\n    /**\n     * Transition options of the hide animation.\n     * @group Props\n     * @deprecated since v14.2.0, use overlayOptions property instead.\n     */\n    @Input() get hideTransitionOptions(): string | undefined {\n        return this._hideTransitionOptions;\n    }\n    set hideTransitionOptions(val: string | undefined) {\n        this._hideTransitionOptions = val;\n        console.warn('The hideTransitionOptions property is deprecated since v14.2.0, use overlayOptions property instead.');\n    }\n    /**\n     * Label to display when there are no selections.\n     * @group Props\n     * @deprecated Use placeholder instead.\n     */\n    @Input() set defaultLabel(val: string | undefined) {\n        this._defaultLabel = val;\n        console.warn('defaultLabel property is deprecated since 16.6.0, use placeholder instead');\n    }\n    get defaultLabel(): string | undefined {\n        return this._defaultLabel;\n    }\n    /**\n     * Label to display when there are no selections.\n     * @group Props\n     */\n    @Input() set placeholder(val: string | undefined) {\n        this._placeholder = val;\n    }\n    get placeholder(): string | undefined {\n        return this._placeholder;\n    }\n    /**\n     * An array of objects to display as the available options.\n     * @group Props\n     */\n    @Input() get options(): any[] | undefined {\n        const options = this._options();\n        return options;\n    }\n    set options(val: any[] | undefined) {\n        this._options.set(val);\n    }\n    /**\n     * When specified, filter displays with this value.\n     * @group Props\n     */\n    @Input() get filterValue(): string | undefined | null {\n        return this._filterValue();\n    }\n    set filterValue(val: string | undefined | null) {\n        this._filterValue.set(val);\n    }\n    /**\n     * Item size of item to be virtual scrolled.\n     * @group Props\n     * @deprecated use virtualScrollItemSize property instead.\n     */\n    @Input() get itemSize(): number | undefined {\n        return this._itemSize;\n    }\n    set itemSize(val: number | undefined) {\n        this._itemSize = val;\n        console.warn('The itemSize property is deprecated, use virtualScrollItemSize property instead.');\n    }\n    /**\n     * Fields used when filtering the options, defaults to optionLabel.\n     * @group Props\n     */\n    @Input() focusOnHover: boolean = false;\n    /**\n     * Fields used when filtering the options, defaults to optionLabel.\n     * @group Props\n     */\n    @Input() filterFields: any[] | undefined;\n    /**\n     * Determines if the option will be selected on focus.\n     * @group Props\n     */\n    @Input() selectOnFocus: boolean = false;\n    /**\n     * Whether to focus on the first visible or selected element when the overlay panel is shown.\n     * @group Props\n     */\n    @Input() autoOptionFocus: boolean = true;\n    /**\n     * Callback to invoke when value changes.\n     * @param {MultiSelectChangeEvent} event - Custom change event.\n     * @group Emits\n     */\n    @Output() onChange: EventEmitter<MultiSelectChangeEvent> = new EventEmitter<MultiSelectChangeEvent>();\n    /**\n     * Callback to invoke when data is filtered.\n     * @param {MultiSelectFilterEvent} event - Custom filter event.\n     * @group Emits\n     */\n    @Output() onFilter: EventEmitter<MultiSelectFilterEvent> = new EventEmitter<MultiSelectFilterEvent>();\n    /**\n     * Callback to invoke when multiselect receives focus.\n     * @param {MultiSelectFocusEvent} event - Custom focus event.\n     * @group Emits\n     */\n    @Output() onFocus: EventEmitter<MultiSelectFocusEvent> = new EventEmitter<MultiSelectFocusEvent>();\n    /**\n     * Callback to invoke when multiselect loses focus.\n     * @param {MultiSelectBlurEvent} event - Custom blur event.\n     * @group Emits\n     */\n    @Output() onBlur: EventEmitter<MultiSelectBlurEvent> = new EventEmitter<MultiSelectBlurEvent>();\n    /**\n     * Callback to invoke when component is clicked.\n     * @param {Event} event - Browser event.\n     * @group Emits\n     */\n    @Output() onClick: EventEmitter<Event> = new EventEmitter<Event>();\n    /**\n     * Callback to invoke when input field is cleared.\n     * @group Emits\n     */\n    @Output() onClear: EventEmitter<void> = new EventEmitter<void>();\n    /**\n     * Callback to invoke when overlay panel becomes visible.\n     * @group Emits\n     */\n    @Output() onPanelShow: EventEmitter<void> = new EventEmitter<void>();\n    /**\n     * Callback to invoke when overlay panel becomes hidden.\n     * @group Emits\n     */\n    @Output() onPanelHide: EventEmitter<void> = new EventEmitter<void>();\n    /**\n     * Callback to invoke in lazy mode to load new data.\n     * @param {MultiSelectLazyLoadEvent} event - Lazy load event.\n     * @group Emits\n     */\n    @Output() onLazyLoad: EventEmitter<MultiSelectLazyLoadEvent> = new EventEmitter<MultiSelectLazyLoadEvent>();\n    /**\n     * Callback to invoke in lazy mode to load new data.\n     * @param {MultiSelectRemoveEvent} event - Remove event.\n     * @group Emits\n     */\n    @Output() onRemove: EventEmitter<MultiSelectRemoveEvent> = new EventEmitter<MultiSelectRemoveEvent>();\n\n    @ViewChild('container') containerViewChild: Nullable<ElementRef>;\n\n    @ViewChild('overlay') overlayViewChild: Nullable<Overlay>;\n\n    @ViewChild('filterInput') filterInputChild: Nullable<ElementRef>;\n\n    @ViewChild('focusInput') focusInputViewChild: Nullable<ElementRef>;\n\n    @ViewChild('items') itemsViewChild: Nullable<ElementRef>;\n\n    @ViewChild('scroller') scroller: Nullable<Scroller>;\n\n    @ViewChild('lastHiddenFocusableEl') lastHiddenFocusableElementOnOverlay: Nullable<ElementRef>;\n\n    @ViewChild('firstHiddenFocusableEl') firstHiddenFocusableElementOnOverlay: Nullable<ElementRef>;\n\n    @ViewChild('headerCheckbox') headerCheckboxViewChild: Nullable<ElementRef>;\n\n    @ContentChild(Footer) footerFacet: any;\n\n    @ContentChild(Header) headerFacet: any;\n\n    @ContentChildren(PrimeTemplate) templates: Nullable<QueryList<PrimeTemplate>>;\n\n    searchValue: Nullable<string>;\n\n    searchTimeout: any;\n\n    _autoZIndex: boolean | undefined;\n\n    _baseZIndex: number | undefined;\n\n    _showTransitionOptions: string | undefined;\n\n    _hideTransitionOptions: string | undefined;\n\n    _defaultLabel: string | undefined;\n\n    _placeholder: string | undefined;\n\n    _itemSize: number | undefined;\n\n    _selectionLimit: number | undefined;\n\n    public value: any[] | undefined | null;\n\n    public _filteredOptions: any[] | undefined | null;\n\n    public onModelChange: Function = () => {};\n\n    public onModelTouched: Function = () => {};\n\n    public valuesAsString: string | undefined;\n\n    public focus: boolean | undefined;\n\n    public filtered: boolean | undefined;\n\n    public itemTemplate: TemplateRef<any> | undefined;\n\n    public groupTemplate: TemplateRef<any> | undefined;\n\n    public loaderTemplate: TemplateRef<any> | undefined;\n\n    public headerTemplate: TemplateRef<any> | undefined;\n\n    public filterTemplate: TemplateRef<any> | undefined;\n\n    public footerTemplate: TemplateRef<any> | undefined;\n\n    public emptyFilterTemplate: TemplateRef<any> | undefined;\n\n    public emptyTemplate: TemplateRef<any> | undefined;\n\n    public selectedItemsTemplate: TemplateRef<any> | undefined;\n\n    checkIconTemplate: TemplateRef<any> | undefined;\n\n    filterIconTemplate: TemplateRef<any> | undefined;\n\n    removeTokenIconTemplate: TemplateRef<any> | undefined;\n\n    closeIconTemplate: TemplateRef<any> | undefined;\n\n    clearIconTemplate: TemplateRef<any> | undefined;\n\n    dropdownIconTemplate: TemplateRef<any> | undefined;\n\n    public headerCheckboxFocus: boolean | undefined;\n\n    filterOptions: MultiSelectFilterOptions | undefined;\n\n    maxSelectionLimitReached: boolean | undefined;\n\n    preventModelTouched: boolean | undefined;\n\n    preventDocumentDefault: boolean | undefined;\n\n    focused: boolean = false;\n\n    itemsWrapper: any;\n\n    modelValue = signal<any>(null);\n\n    _filterValue = signal<any>(null);\n\n    _options = signal<any[]>(null);\n\n    startRangeIndex = signal<number>(-1);\n\n    focusedOptionIndex = signal<number>(-1);\n\n    get containerClass() {\n        return {\n            'p-multiselect p-component p-inputwrapper': true,\n            'p-disabled': this.disabled,\n            'p-multiselect-clearable': this.showClear && !this.disabled,\n            'p-multiselect-chip': this.display === 'chip',\n            'p-focus': this.focused,\n            'p-inputwrapper-filled': ObjectUtils.isNotEmpty(this.modelValue()),\n            'p-inputwrapper-focus': this.focused || this.overlayVisible\n        };\n    }\n\n    get inputClass() {\n        return {\n            'p-multiselect-label p-inputtext': true,\n            'p-placeholder': (this.placeholder || this.defaultLabel) && (this.label() === this.placeholder || this.label() === this.defaultLabel),\n            'p-multiselect-label-empty': !this.selectedItemsTemplate && (this.label() === 'p-emptylabel' || this.label().length === 0)\n        };\n    }\n\n    get panelClass() {\n        return {\n            'p-multiselect-panel p-component': true,\n            'p-input-filled': this.config.inputStyle === 'filled',\n            'p-ripple-disabled': this.config.ripple === false\n        };\n    }\n\n    get labelClass() {\n        return {\n            'p-multiselect-label': true,\n            'p-placeholder': this.label() === this.placeholder || this.label() === this.defaultLabel,\n            'p-multiselect-label-empty': !this.placeholder && !this.defaultLabel && (!this.modelValue() || this.modelValue().length === 0)\n        };\n    }\n\n    get emptyMessageLabel(): string {\n        return this.emptyMessage || this.config.getTranslation(TranslationKeys.EMPTY_MESSAGE);\n    }\n\n    get emptyFilterMessageLabel(): string {\n        return this.emptyFilterMessage || this.config.getTranslation(TranslationKeys.EMPTY_FILTER_MESSAGE);\n    }\n\n    get filled(): boolean {\n        if (typeof this.modelValue() === 'string') return !!this.modelValue();\n\n        return this.modelValue() || this.modelValue() != null || this.modelValue() != undefined;\n    }\n\n    get isVisibleClearIcon(): boolean | undefined {\n        return this.modelValue() != null && this.modelValue() !== '' && this.showClear && !this.disabled;\n    }\n\n    get toggleAllAriaLabel() {\n        return this.config.translation.aria ? this.config.translation.aria[this.allSelected() ? 'selectAll' : 'unselectAll'] : undefined;\n    }\n\n    get closeAriaLabel() {\n        return this.config.translation.aria ? this.config.translation.aria.close : undefined;\n    }\n\n    visibleOptions = computed(() => {\n        const options = this.group ? this.flatOptions(this.options) : this.options || [];\n\n        if (this._filterValue()) {\n            const filteredOptions = this.filterService.filter(options, this.searchFields(), this._filterValue(), this.filterMatchMode, this.filterLocale);\n            if (this.group) {\n                const optionGroups = this.options || [];\n                const filtered = [];\n\n                optionGroups.forEach((group) => {\n                    const groupChildren = this.getOptionGroupChildren(group);\n                    const filteredItems = groupChildren.filter((item) => filteredOptions.includes(item));\n\n                    if (filteredItems.length > 0) filtered.push({ ...group, [typeof this.optionGroupChildren === 'string' ? this.optionGroupChildren : 'items']: [...filteredItems] });\n                });\n\n                return this.flatOptions(filtered);\n            }\n\n            return filteredOptions;\n        }\n        return options;\n    });\n\n    label = computed(() => {\n        let label;\n        const modelValue = this.modelValue();\n\n        if (modelValue && modelValue.length) {\n            if (ObjectUtils.isNotEmpty(this.maxSelectedLabels) && modelValue.length > this.maxSelectedLabels) {\n                return this.getSelectedItemsLabel();\n            } else {\n                label = '';\n\n                for (let i = 0; i < modelValue.length; i++) {\n                    if (i !== 0) {\n                        label += ', ';\n                    }\n\n                    label += this.getLabelByValue(modelValue[i]);\n                }\n            }\n        } else {\n            label = this.placeholder || this.defaultLabel || '';\n        }\n        return label;\n    });\n\n    chipSelectedItems = computed(() => {\n        return ObjectUtils.isNotEmpty(this.maxSelectedLabels) && this.modelValue() && this.modelValue().length > this.maxSelectedLabels ? this.modelValue().slice(0, this.maxSelectedLabels) : this.modelValue();\n    });\n\n    constructor(public el: ElementRef, public renderer: Renderer2, public cd: ChangeDetectorRef, public zone: NgZone, public filterService: FilterService, public config: PrimeNGConfig, public overlayService: OverlayService) {}\n\n    ngOnInit() {\n        this.id = this.id || UniqueComponentId();\n        this.autoUpdateModel();\n\n        if (this.filterBy) {\n            this.filterOptions = {\n                filter: (value) => this.onFilterInputChange(value),\n                reset: () => this.resetFilter()\n            };\n        }\n    }\n\n    ngAfterContentInit() {\n        (this.templates as QueryList<PrimeTemplate>).forEach((item) => {\n            switch (item.getType()) {\n                case 'item':\n                    this.itemTemplate = item.template;\n                    break;\n\n                case 'group':\n                    this.groupTemplate = item.template;\n                    break;\n\n                case 'selectedItems':\n                    this.selectedItemsTemplate = item.template;\n                    break;\n\n                case 'header':\n                    this.headerTemplate = item.template;\n                    break;\n\n                case 'filter':\n                    this.filterTemplate = item.template;\n                    break;\n\n                case 'emptyfilter':\n                    this.emptyFilterTemplate = item.template;\n                    break;\n\n                case 'empty':\n                    this.emptyTemplate = item.template;\n                    break;\n\n                case 'footer':\n                    this.footerTemplate = item.template;\n                    break;\n\n                case 'loader':\n                    this.loaderTemplate = item.template;\n                    break;\n\n                case 'checkicon':\n                    this.checkIconTemplate = item.template;\n                    break;\n\n                case 'filtericon':\n                    this.filterIconTemplate = item.template;\n                    break;\n\n                case 'removetokenicon':\n                    this.removeTokenIconTemplate = item.template;\n                    break;\n\n                case 'closeicon':\n                    this.closeIconTemplate = item.template;\n                    break;\n\n                case 'clearicon':\n                    this.clearIconTemplate = item.template;\n                    break;\n\n                case 'dropdownicon':\n                    this.dropdownIconTemplate = item.template;\n                    break;\n\n                default:\n                    this.itemTemplate = item.template;\n                    break;\n            }\n        });\n    }\n\n    ngAfterViewInit() {\n        if (this.overlayVisible) {\n            this.show();\n        }\n    }\n\n    ngAfterViewChecked() {\n        if (this.filtered) {\n            this.zone.runOutsideAngular(() => {\n                setTimeout(() => {\n                    this.overlayViewChild?.alignOverlay();\n                }, 1);\n            });\n            this.filtered = false;\n        }\n    }\n\n    flatOptions(options) {\n        return (options || []).reduce((result, option, index) => {\n            result.push({ optionGroup: option, group: true, index });\n\n            const optionGroupChildren = this.getOptionGroupChildren(option);\n\n            optionGroupChildren && optionGroupChildren.forEach((o) => result.push(o));\n\n            return result;\n        }, []);\n    }\n\n    autoUpdateModel() {\n        if (this.selectOnFocus && this.autoOptionFocus && !this.hasSelectedOption()) {\n            this.focusedOptionIndex.set(this.findFirstFocusedOptionIndex());\n            const value = this.getOptionValue(this.visibleOptions()[this.focusedOptionIndex()]);\n            this.onOptionSelect({ originalEvent: null, option: [value] });\n        }\n    }\n\n    updateModel(value, event?) {\n        this.value = value;\n        this.onModelChange(value);\n        this.modelValue.set(value);\n\n        this.onChange.emit({\n            originalEvent: event,\n            value: value\n        });\n    }\n\n    onOptionSelect(event, isFocus = false, index = -1) {\n        const { originalEvent, option } = event;\n        if (this.disabled || this.isOptionDisabled(option)) {\n            return;\n        }\n\n        let selected = this.isSelected(option);\n        let value = null;\n\n        if (selected) {\n            value = this.modelValue().filter((val) => !ObjectUtils.equals(val, this.getOptionValue(option), this.equalityKey()));\n        } else {\n            value = [...(this.modelValue() || []), this.getOptionValue(option)];\n        }\n\n        this.updateModel(value, originalEvent);\n        index !== -1 && this.focusedOptionIndex.set(index);\n\n        isFocus && DomHandler.focus(this.focusInputViewChild?.nativeElement);\n    }\n\n    onOptionSelectRange(event, start = -1, end = -1) {\n        start === -1 && (start = this.findNearestSelectedOptionIndex(end, true));\n        end === -1 && (end = this.findNearestSelectedOptionIndex(start));\n\n        if (start !== -1 && end !== -1) {\n            const rangeStart = Math.min(start, end);\n            const rangeEnd = Math.max(start, end);\n            const value = this.visibleOptions()\n                .slice(rangeStart, rangeEnd + 1)\n                .filter((option) => this.isValidOption(option))\n                .map((option) => this.getOptionValue(option));\n\n            this.updateModel(value, event);\n        }\n    }\n\n    searchFields() {\n        return this.filterFields || [this.optionLabel];\n    }\n\n    findNearestSelectedOptionIndex(index, firstCheckUp = false) {\n        let matchedOptionIndex = -1;\n\n        if (this.hasSelectedOption()) {\n            if (firstCheckUp) {\n                matchedOptionIndex = this.findPrevSelectedOptionIndex(index);\n                matchedOptionIndex = matchedOptionIndex === -1 ? this.findNextSelectedOptionIndex(index) : matchedOptionIndex;\n            } else {\n                matchedOptionIndex = this.findNextSelectedOptionIndex(index);\n                matchedOptionIndex = matchedOptionIndex === -1 ? this.findPrevSelectedOptionIndex(index) : matchedOptionIndex;\n            }\n        }\n\n        return matchedOptionIndex > -1 ? matchedOptionIndex : index;\n    }\n\n    findPrevSelectedOptionIndex(index) {\n        const matchedOptionIndex = this.hasSelectedOption() && index > 0 ? ObjectUtils.findLastIndex(this.visibleOptions().slice(0, index), (option) => this.isValidSelectedOption(option)) : -1;\n\n        return matchedOptionIndex > -1 ? matchedOptionIndex : -1;\n    }\n\n    findFirstFocusedOptionIndex() {\n        const selectedIndex = this.findFirstSelectedOptionIndex();\n\n        return selectedIndex < 0 ? this.findFirstOptionIndex() : selectedIndex;\n    }\n\n    findFirstOptionIndex() {\n        return this.visibleOptions().findIndex((option) => this.isValidOption(option));\n    }\n\n    findFirstSelectedOptionIndex() {\n        return this.hasSelectedOption() ? this.visibleOptions().findIndex((option) => this.isValidSelectedOption(option)) : -1;\n    }\n\n    findNextSelectedOptionIndex(index) {\n        const matchedOptionIndex =\n            this.hasSelectedOption() && index < this.visibleOptions().length - 1\n                ? this.visibleOptions()\n                      .slice(index + 1)\n                      .findIndex((option) => this.isValidSelectedOption(option))\n                : -1;\n\n        return matchedOptionIndex > -1 ? matchedOptionIndex + index + 1 : -1;\n    }\n\n    equalityKey() {\n        return this.optionValue ? null : this.dataKey;\n    }\n\n    hasSelectedOption() {\n        return ObjectUtils.isNotEmpty(this.modelValue());\n    }\n\n    isValidSelectedOption(option) {\n        return this.isValidOption(option) && this.isSelected(option);\n    }\n\n    isOptionGroup(option) {\n        return (this.group || this.optionGroupLabel) && option.optionGroup && option.group;\n    }\n\n    isValidOption(option) {\n        return option && !(this.isOptionDisabled(option) || this.isOptionGroup(option));\n    }\n\n    isOptionDisabled(option: any) {\n        let disabled = this.optionDisabled ? ObjectUtils.resolveFieldData(option, this.optionDisabled) : option && option.disabled !== undefined ? option.disabled : false;\n        return disabled || (this.maxSelectionLimitReached && !this.isSelected(option));\n    }\n\n    isSelected(option) {\n        const optionValue = this.getOptionValue(option);\n\n        return (this.modelValue() || []).some((value) => ObjectUtils.equals(value, optionValue, this.equalityKey()));\n    }\n\n    isOptionMatched(option) {\n        return this.isValidOption(option) && this.getOptionLabel(option).toLocaleLowerCase(this.filterLocale).startsWith(this.searchValue.toLocaleLowerCase(this.filterLocale));\n    }\n\n    isEmpty() {\n        return !this._options() || (this._options() && this._options().length === 0);\n    }\n\n    getOptionIndex(index, scrollerOptions) {\n        return this.virtualScrollerDisabled ? index : scrollerOptions && scrollerOptions.getItemOptions(index)['index'];\n    }\n\n    getAriaPosInset(index) {\n        return (\n            (this.optionGroupLabel\n                ? index -\n                  this.visibleOptions()\n                      .slice(0, index)\n                      .filter((option) => this.isOptionGroup(option)).length\n                : index) + 1\n        );\n    }\n\n    get ariaSetSize() {\n        return this.visibleOptions().filter((option) => !this.isOptionGroup(option)).length;\n    }\n\n    getLabelByValue(value) {\n        const options = this.group ? this.flatOptions(this._options()) : this._options() || [];\n        const matchedOption = options.find((option) => !this.isOptionGroup(option) && ObjectUtils.equals(this.getOptionValue(option), value, this.equalityKey()));\n        return matchedOption ? this.getOptionLabel(matchedOption) : null;\n    }\n\n    getSelectedItemsLabel() {\n        let pattern = /{(.*?)}/;\n\n        if (pattern.test(this.selectedItemsLabel)) {\n            return this.selectedItemsLabel.replace(this.selectedItemsLabel.match(pattern)[0], this.modelValue().length + '');\n        }\n\n        return this.selectedItemsLabel;\n    }\n\n    getOptionLabel(option: any) {\n        return this.optionLabel ? ObjectUtils.resolveFieldData(option, this.optionLabel) : option && option.label != undefined ? option.label : option;\n    }\n\n    getOptionValue(option: any) {\n        return this.optionValue ? ObjectUtils.resolveFieldData(option, this.optionValue) : !this.optionLabel && option && option.value !== undefined ? option.value : option;\n    }\n\n    getOptionGroupLabel(optionGroup: any) {\n        return this.optionGroupLabel ? ObjectUtils.resolveFieldData(optionGroup, this.optionGroupLabel) : optionGroup && optionGroup.label != undefined ? optionGroup.label : optionGroup;\n    }\n\n    getOptionGroupChildren(optionGroup: any) {\n        return this.optionGroupChildren ? ObjectUtils.resolveFieldData(optionGroup, this.optionGroupChildren) : optionGroup.items;\n    }\n\n    onKeyDown(event: KeyboardEvent) {\n        if (this.disabled) {\n            event.preventDefault();\n            return;\n        }\n\n        const metaKey = event.metaKey || event.ctrlKey;\n\n        switch (event.code) {\n            case 'ArrowDown':\n                this.onArrowDownKey(event);\n                break;\n\n            case 'ArrowUp':\n                this.onArrowUpKey(event);\n                break;\n\n            case 'Home':\n                this.onHomeKey(event);\n                break;\n\n            case 'End':\n                this.onEndKey(event);\n                break;\n\n            case 'PageDown':\n                this.onPageDownKey(event);\n                break;\n\n            case 'PageUp':\n                this.onPageUpKey(event);\n                break;\n\n            case 'Enter':\n            case 'Space':\n                this.onEnterKey(event);\n                break;\n\n            case 'Escape':\n                this.onEscapeKey(event);\n                break;\n\n            case 'Tab':\n                this.onTabKey(event);\n                break;\n\n            case 'ShiftLeft':\n            case 'ShiftRight':\n                this.onShiftKey();\n                break;\n\n            default:\n                if (event.code === 'KeyA' && metaKey) {\n                    const value = this.visibleOptions()\n                        .filter((option) => this.isValidOption(option))\n                        .map((option) => this.getOptionValue(option));\n\n                    this.updateModel(value, event);\n\n                    event.preventDefault();\n                    break;\n                }\n\n                if (!metaKey && ObjectUtils.isPrintableCharacter(event.key)) {\n                    !this.overlayVisible && this.show();\n                    this.searchOptions(event, event.key);\n                    event.preventDefault();\n                }\n\n                break;\n        }\n    }\n\n    onFilterKeyDown(event: KeyboardEvent) {\n        switch (event.code) {\n            case 'ArrowDown':\n                this.onArrowDownKey(event);\n                break;\n\n            case 'ArrowUp':\n                this.onArrowUpKey(event, true);\n                break;\n\n            case 'ArrowLeft':\n            case 'ArrowRight':\n                this.onArrowLeftKey(event, true);\n                break;\n\n            case 'Home':\n                this.onHomeKey(event, true);\n                break;\n\n            case 'End':\n                this.onEndKey(event, true);\n                break;\n\n            case 'Enter':\n                this.onEnterKey(event);\n                break;\n\n            case 'Escape':\n                this.onEscapeKey(event);\n                break;\n\n            case 'Tab':\n                this.onTabKey(event, true);\n                break;\n\n            default:\n                break;\n        }\n    }\n\n    onArrowLeftKey(event: KeyboardEvent, pressedInInputText: boolean = false) {\n        pressedInInputText && this.focusedOptionIndex.set(-1);\n    }\n\n    onArrowDownKey(event) {\n        const optionIndex = this.focusedOptionIndex() !== -1 ? this.findNextOptionIndex(this.focusedOptionIndex()) : this.findFirstFocusedOptionIndex();\n\n        if (event.shiftKey) {\n            this.onOptionSelectRange(event, this.startRangeIndex(), optionIndex);\n        }\n\n        this.changeFocusedOptionIndex(event, optionIndex);\n        !this.overlayVisible && this.show();\n        event.preventDefault();\n    }\n\n    onArrowUpKey(event, pressedInInputText = false) {\n        if (event.altKey && !pressedInInputText) {\n            if (this.focusedOptionIndex() !== -1) {\n                this.onOptionSelect(event, this.visibleOptions()[this.focusedOptionIndex()]);\n            }\n\n            this.overlayVisible && this.hide();\n            event.preventDefault();\n        } else {\n            const optionIndex = this.focusedOptionIndex() !== -1 ? this.findPrevOptionIndex(this.focusedOptionIndex()) : this.findLastFocusedOptionIndex();\n\n            if (event.shiftKey) {\n                this.onOptionSelectRange(event, optionIndex, this.startRangeIndex());\n            }\n\n            this.changeFocusedOptionIndex(event, optionIndex);\n\n            !this.overlayVisible && this.show();\n            event.preventDefault();\n        }\n    }\n\n    onHomeKey(event, pressedInInputText = false) {\n        const { currentTarget } = event;\n\n        if (pressedInInputText) {\n            const len = currentTarget.value.length;\n\n            currentTarget.setSelectionRange(0, event.shiftKey ? len : 0);\n            this.focusedOptionIndex.set(-1);\n        } else {\n            let metaKey = event.metaKey || event.ctrlKey;\n            let optionIndex = this.findFirstOptionIndex();\n\n            if (event.shiftKey && metaKey) {\n                this.onOptionSelectRange(event, optionIndex, this.startRangeIndex());\n            }\n\n            this.changeFocusedOptionIndex(event, optionIndex);\n\n            !this.overlayVisible && this.show();\n        }\n\n        event.preventDefault();\n    }\n\n    onEndKey(event, pressedInInputText = false) {\n        const { currentTarget } = event;\n\n        if (pressedInInputText) {\n            const len = currentTarget.value.length;\n            currentTarget.setSelectionRange(event.shiftKey ? 0 : len, len);\n            this.focusedOptionIndex.set(-1);\n        } else {\n            let metaKey = event.metaKey || event.ctrlKey;\n            let optionIndex = this.findLastFocusedOptionIndex();\n\n            if (event.shiftKey && metaKey) {\n                this.onOptionSelectRange(event, this.startRangeIndex(), optionIndex);\n            }\n\n            this.changeFocusedOptionIndex(event, optionIndex);\n\n            !this.overlayVisible && this.show();\n        }\n\n        event.preventDefault();\n    }\n\n    onPageDownKey(event) {\n        this.scrollInView(this.visibleOptions().length - 1);\n        event.preventDefault();\n    }\n\n    onPageUpKey(event) {\n        this.scrollInView(0);\n        event.preventDefault();\n    }\n\n    onEnterKey(event) {\n        if (!this.overlayVisible) {\n            this.onArrowDownKey(event);\n        } else {\n            if (this.focusedOptionIndex() !== -1) {\n                if (event.shiftKey) {\n                    this.onOptionSelectRange(event, this.focusedOptionIndex());\n                } else {\n                    this.onOptionSelect({ originalEvent: event, option: this.visibleOptions()[this.focusedOptionIndex()] });\n                }\n            }\n        }\n\n        event.preventDefault();\n    }\n\n    onEscapeKey(event) {\n        this.overlayVisible && this.hide(true);\n        event.preventDefault();\n    }\n\n    onDeleteKey(event: KeyboardEvent) {\n        if (this.showClear) {\n            this.clear(event);\n            event.preventDefault();\n        }\n    }\n\n    onTabKey(event, pressedInInputText = false) {\n        if (!pressedInInputText) {\n            if (this.overlayVisible && this.hasFocusableElements()) {\n                DomHandler.focus(event.shiftKey ? this.lastHiddenFocusableElementOnOverlay.nativeElement : this.firstHiddenFocusableElementOnOverlay.nativeElement);\n\n                event.preventDefault();\n            } else {\n                if (this.focusedOptionIndex() !== -1) {\n                    this.onOptionSelect({ originalEvent: event, option: this.visibleOptions()[this.focusedOptionIndex()] });\n                }\n\n                this.overlayVisible && this.hide(this.filter);\n            }\n        }\n    }\n\n    onShiftKey() {\n        this.startRangeIndex.set(this.focusedOptionIndex());\n    }\n\n    onContainerClick(event: any) {\n        if (this.disabled || this.readonly || (<Node>event.target).isSameNode(this.focusInputViewChild?.nativeElement)) {\n            return;\n        }\n\n        if (event.target.tagName === 'INPUT' || event.target.getAttribute('data-pc-section') === 'clearicon' || event.target.closest('[data-pc-section=\"clearicon\"]')) {\n            event.preventDefault();\n            return;\n        } else if (!this.overlayViewChild || !this.overlayViewChild.el.nativeElement.contains(event.target)) {\n            this.overlayVisible ? this.hide(true) : this.show(true);\n        }\n        this.focusInputViewChild?.nativeElement.focus({ preventScroll: true });\n        this.onClick.emit(event);\n        this.cd.detectChanges();\n    }\n\n    onFirstHiddenFocus(event) {\n        const focusableEl =\n            event.relatedTarget === this.focusInputViewChild?.nativeElement\n                ? DomHandler.getFirstFocusableElement(this.overlayViewChild?.overlayViewChild?.nativeElement, ':not([data-p-hidden-focusable=\"true\"])')\n                : this.focusInputViewChild?.nativeElement;\n\n        DomHandler.focus(focusableEl);\n    }\n\n    onInputFocus(event: Event) {\n        this.focused = true;\n        const focusedOptionIndex = this.focusedOptionIndex() !== -1 ? this.focusedOptionIndex() : this.overlayVisible && this.autoOptionFocus ? this.findFirstFocusedOptionIndex() : -1;\n        this.focusedOptionIndex.set(focusedOptionIndex);\n        this.overlayVisible && this.scrollInView(this.focusedOptionIndex());\n        this.onFocus.emit({ originalEvent: event });\n    }\n\n    onInputBlur(event: Event) {\n        this.focused = false;\n        this.onBlur.emit({ originalEvent: event });\n\n        if (!this.preventModelTouched) {\n            this.onModelTouched();\n        }\n        this.preventModelTouched = false;\n    }\n\n    onFilterInputChange(event: KeyboardEvent) {\n        let value: string = (event.target as HTMLInputElement).value?.trim();\n        this._filterValue.set(value);\n        this.focusedOptionIndex.set(-1);\n        this.onFilter.emit({ originalEvent: event, filter: this._filterValue() });\n\n        !this.virtualScrollerDisabled && this.scroller.scrollToIndex(0);\n    }\n\n    onLastHiddenFocus(event) {\n        const focusableEl =\n            event.relatedTarget === this.focusInputViewChild?.nativeElement\n                ? DomHandler.getLastFocusableElement(this.overlayViewChild?.overlayViewChild?.nativeElement, ':not([data-p-hidden-focusable=\"true\"])')\n                : this.focusInputViewChild?.nativeElement;\n\n        DomHandler.focus(focusableEl);\n    }\n\n    onOptionMouseEnter(event, index) {\n        if (this.focusOnHover) {\n            this.changeFocusedOptionIndex(event, index);\n        }\n    }\n\n    onHeaderCheckboxKeyDown(event) {\n        if (this.disabled) {\n            event.preventDefault();\n\n            return;\n        }\n\n        switch (event.code) {\n            case 'Space':\n                this.onToggleAll(event);\n                break;\n            case 'Enter':\n                this.onToggleAll(event);\n                break;\n            default:\n                break;\n        }\n    }\n\n    onFilterBlur(event) {\n        this.focusedOptionIndex.set(-1);\n    }\n\n    onHeaderCheckboxFocus() {\n        this.headerCheckboxFocus = true;\n    }\n\n    onHeaderCheckboxBlur() {\n        this.headerCheckboxFocus = false;\n    }\n\n    onToggleAll(event) {\n        if (this.disabled || this.readonly) {\n            return;\n        }\n\n        DomHandler.focus(this.headerCheckboxViewChild.nativeElement);\n\n        const value = this.allSelected()\n            ? []\n            : this.visibleOptions()\n                  .filter((option) => this.isValidOption(option))\n                  .map((option) => this.getOptionValue(option));\n        this.updateModel(value, event);\n        this.onChange.emit({ originalEvent: event, value: this.value });\n        this.headerCheckboxFocus = true;\n\n        event.preventDefault();\n        event.stopPropagation();\n    }\n\n    changeFocusedOptionIndex(event, index) {\n        if (this.focusedOptionIndex() !== index) {\n            this.focusedOptionIndex.set(index);\n            this.scrollInView();\n        }\n    }\n\n    get virtualScrollerDisabled() {\n        return !this.virtualScroll;\n    }\n\n    scrollInView(index = -1) {\n        const id = index !== -1 ? `${this.id}_${index}` : this.focusedOptionId;\n        if (this.itemsViewChild && this.itemsViewChild.nativeElement) {\n            const element = DomHandler.findSingle(this.itemsViewChild.nativeElement, `li[id=\"${id}\"]`);\n            if (element) {\n                element.scrollIntoView && element.scrollIntoView({ block: 'nearest', inline: 'nearest' });\n            } else if (!this.virtualScrollerDisabled) {\n                setTimeout(() => {\n                    this.virtualScroll && this.scroller?.scrollToIndex(index !== -1 ? index : this.focusedOptionIndex());\n                }, 0);\n            }\n        }\n    }\n\n    get focusedOptionId() {\n        return this.focusedOptionIndex() !== -1 ? `${this.id}_${this.focusedOptionIndex()}` : null;\n    }\n\n    checkSelectionLimit() {\n        if (this.selectionLimit && this.value && this.value.length === this.selectionLimit) {\n            this.maxSelectionLimitReached = true;\n        } else {\n            this.maxSelectionLimitReached = false;\n        }\n    }\n\n    writeValue(value: any): void {\n        this.value = value;\n        this.modelValue.set(this.value);\n        this.updateModel(this.value);\n        this.checkSelectionLimit();\n\n        this.cd.markForCheck();\n    }\n\n    registerOnChange(fn: Function): void {\n        this.onModelChange = fn;\n    }\n\n    registerOnTouched(fn: Function): void {\n        this.onModelTouched = fn;\n    }\n\n    setDisabledState(val: boolean): void {\n        this.disabled = val;\n        this.cd.markForCheck();\n    }\n\n    allSelected() {\n        const allSelected = this.visibleOptions().length > 0 && this.visibleOptions().every((option) => this.isOptionGroup(option) || this.isOptionDisabled(option) || this.isSelected(option));\n        return ObjectUtils.isNotEmpty(this.visibleOptions()) && allSelected;\n    }\n\n    /**\n     * Displays the panel.\n     * @group Method\n     */\n    public show(isFocus?) {\n        this.overlayVisible = true;\n        const focusedOptionIndex = this.focusedOptionIndex() !== -1 ? this.focusedOptionIndex() : this.autoOptionFocus ? this.findFirstFocusedOptionIndex() : -1;\n        this.focusedOptionIndex.set(focusedOptionIndex);\n\n        if (isFocus) {\n            DomHandler.focus(this.focusInputViewChild?.nativeElement);\n        }\n\n        this.cd.markForCheck();\n    }\n\n    /**\n     * Hides the panel.\n     * @group Method\n     */\n    public hide(isFocus?) {\n        this.overlayVisible = false;\n        this.focusedOptionIndex.set(-1);\n\n        if (this.filter && this.resetFilterOnHide) {\n            this.resetFilter();\n        }\n\n        isFocus && DomHandler.focus(this.focusInputViewChild?.nativeElement);\n        this.onPanelHide.emit();\n        this.cd.markForCheck();\n    }\n\n    onOverlayAnimationStart(event: AnimationEvent) {\n        switch (event.toState) {\n            case 'visible':\n                this.itemsWrapper = DomHandler.findSingle(this.overlayViewChild?.overlayViewChild?.nativeElement, this.virtualScroll ? '.p-scroller' : '.p-multiselect-items-wrapper');\n                this.virtualScroll && this.scroller?.setContentEl(this.itemsViewChild?.nativeElement);\n\n                if (this._options() && this._options().length) {\n                    if (this.virtualScroll) {\n                        const selectedIndex = ObjectUtils.isNotEmpty(this.modelValue()) ? this.focusedOptionIndex() : -1;\n                        if (selectedIndex !== -1) {\n                            this.scroller?.scrollToIndex(0);\n                        }\n                    } else {\n                        let selectedListItem = DomHandler.findSingle(this.itemsWrapper, '.p-multiselect-item.p-highlight');\n\n                        if (selectedListItem) {\n                            selectedListItem.scrollIntoView({ block: 'nearest', inline: 'center' });\n                        }\n                    }\n                    this.onPanelShow.emit();\n                }\n            case 'void':\n                this.itemsWrapper = null;\n                this.onModelTouched();\n                break;\n        }\n    }\n\n    resetFilter() {\n        if (this.filterInputChild && this.filterInputChild.nativeElement) {\n            this.filterInputChild.nativeElement.value = '';\n        }\n\n        this._filterValue = null;\n        this._filteredOptions = null;\n    }\n\n    close(event: Event) {\n        this.hide();\n        event.preventDefault();\n        event.stopPropagation();\n    }\n\n    clear(event: Event) {\n        this.value = null;\n        this.checkSelectionLimit();\n        this.updateModel(null, event);\n        this.onClear.emit();\n\n        event.stopPropagation();\n    }\n\n    removeOption(optionValue, event) {\n        let value = this.modelValue().filter((val) => !ObjectUtils.equals(val, optionValue, this.equalityKey()));\n\n        this.updateModel(value, event);\n\n        event && event.stopPropagation();\n    }\n\n    findNextItem(item: any): HTMLElement | null {\n        let nextItem = item.nextElementSibling;\n\n        if (nextItem) return DomHandler.hasClass(nextItem.children[0], 'p-disabled') || DomHandler.isHidden(nextItem.children[0]) || DomHandler.hasClass(nextItem, 'p-multiselect-item-group') ? this.findNextItem(nextItem) : nextItem.children[0];\n        else return null;\n    }\n\n    findPrevItem(item: any): HTMLElement | null {\n        let prevItem = item.previousElementSibling;\n\n        if (prevItem) return DomHandler.hasClass(prevItem.children[0], 'p-disabled') || DomHandler.isHidden(prevItem.children[0]) || DomHandler.hasClass(prevItem, 'p-multiselect-item-group') ? this.findPrevItem(prevItem) : prevItem.children[0];\n        else return null;\n    }\n\n    findNextOptionIndex(index) {\n        const matchedOptionIndex =\n            index < this.visibleOptions().length - 1\n                ? this.visibleOptions()\n                      .slice(index + 1)\n                      .findIndex((option) => this.isValidOption(option))\n                : -1;\n        return matchedOptionIndex > -1 ? matchedOptionIndex + index + 1 : index;\n    }\n\n    findPrevOptionIndex(index) {\n        const matchedOptionIndex = index > 0 ? ObjectUtils.findLastIndex(this.visibleOptions().slice(0, index), (option) => this.isValidOption(option)) : -1;\n\n        return matchedOptionIndex > -1 ? matchedOptionIndex : index;\n    }\n\n    findLastSelectedOptionIndex() {\n        return this.hasSelectedOption() ? ObjectUtils.findLastIndex(this.visibleOptions(), (option) => this.isValidSelectedOption(option)) : -1;\n    }\n\n    findLastFocusedOptionIndex() {\n        const selectedIndex = this.findLastSelectedOptionIndex();\n\n        return selectedIndex < 0 ? this.findLastOptionIndex() : selectedIndex;\n    }\n\n    findLastOptionIndex() {\n        return ObjectUtils.findLastIndex(this.visibleOptions(), (option) => this.isValidOption(option));\n    }\n\n    searchOptions(event, char) {\n        this.searchValue = (this.searchValue || '') + char;\n\n        let optionIndex = -1;\n        let matched = false;\n\n        if (this.focusedOptionIndex() !== -1) {\n            optionIndex = this.visibleOptions()\n                .slice(this.focusedOptionIndex())\n                .findIndex((option) => this.isOptionMatched(option));\n            optionIndex =\n                optionIndex === -1\n                    ? this.visibleOptions()\n                          .slice(0, this.focusedOptionIndex())\n                          .findIndex((option) => this.isOptionMatched(option))\n                    : optionIndex + this.focusedOptionIndex();\n        } else {\n            optionIndex = this.visibleOptions().findIndex((option) => this.isOptionMatched(option));\n        }\n\n        if (optionIndex !== -1) {\n            matched = true;\n        }\n\n        if (optionIndex === -1 && this.focusedOptionIndex() === -1) {\n            optionIndex = this.findFirstFocusedOptionIndex();\n        }\n\n        if (optionIndex !== -1) {\n            this.changeFocusedOptionIndex(event, optionIndex);\n        }\n\n        if (this.searchTimeout) {\n            clearTimeout(this.searchTimeout);\n        }\n\n        this.searchTimeout = setTimeout(() => {\n            this.searchValue = '';\n            this.searchTimeout = null;\n        }, 500);\n\n        return matched;\n    }\n\n    activateFilter() {\n        if (this.hasFilter() && this._options) {\n            let searchFields: string[] = (this.filterBy || this.optionLabel || 'label').split(',');\n\n            if (this.group) {\n                let filteredGroups = [];\n                for (let optgroup of this.options as any[]) {\n                    let filteredSubOptions = this.filterService.filter(this.getOptionGroupChildren(optgroup), searchFields, this.filterValue, this.filterMatchMode, this.filterLocale);\n                    if (filteredSubOptions && filteredSubOptions.length) {\n                        filteredGroups.push({ ...optgroup, ...{ [this.optionGroupChildren]: filteredSubOptions } });\n                    }\n                }\n\n                this._filteredOptions = filteredGroups;\n            } else {\n                this._filteredOptions = this.filterService.filter(this.options as any[], searchFields, this._filterValue, this.filterMatchMode, this.filterLocale);\n            }\n        } else {\n            this._filteredOptions = null;\n        }\n    }\n\n    hasFocusableElements() {\n        return DomHandler.getFocusableElements(this.overlayViewChild.overlayViewChild.nativeElement, ':not([data-p-hidden-focusable=\"true\"])').length > 0;\n    }\n\n    hasFilter() {\n        return this._filterValue() && this._filterValue().trim().length > 0;\n    }\n}\n\n@NgModule({\n    imports: [CommonModule, OverlayModule, SharedModule, TooltipModule, RippleModule, ScrollerModule, CheckIcon, SearchIcon, TimesCircleIcon, TimesIcon, ChevronDownIcon, CheckIcon],\n    exports: [MultiSelect, OverlayModule, SharedModule, ScrollerModule],\n    declarations: [MultiSelect, MultiSelectItem]\n})\nexport class MultiSelectModule {}\n"]}
|