@po-ui/ng-components 17.5.0 → 17.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/po-dynamic/index.mjs +3 -1
- package/esm2022/lib/components/po-dynamic/po-dynamic-container/po-dynamic-container.component.mjs +56 -0
- package/esm2022/lib/components/po-dynamic/po-dynamic-field.interface.mjs +1 -1
- package/esm2022/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-fields/po-dynamic-form-fields-base.component.mjs +8 -5
- package/esm2022/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-fields/po-dynamic-form-fields.component.mjs +221 -196
- package/esm2022/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form.component.mjs +9 -2
- package/esm2022/lib/components/po-dynamic/po-dynamic-view/po-dynamic-view-base.component.mjs +17 -6
- package/esm2022/lib/components/po-dynamic/po-dynamic-view/po-dynamic-view.component.mjs +68 -39
- package/esm2022/lib/components/po-dynamic/po-dynamic.module.mjs +20 -7
- package/esm2022/lib/components/po-dynamic/shared/po-dynamic-shared-base.mjs +41 -0
- package/esm2022/lib/components/po-search/interfaces/po-search-option.interface.mjs +2 -0
- package/esm2022/lib/components/po-search/po-search-base.component.mjs +27 -2
- package/esm2022/lib/components/po-search/po-search.component.mjs +264 -48
- package/esm2022/lib/components/po-search/po-search.module.mjs +25 -4
- package/fesm2022/po-ui-ng-components.mjs +994 -564
- package/fesm2022/po-ui-ng-components.mjs.map +1 -1
- package/lib/components/po-dynamic/index.d.ts +2 -0
- package/lib/components/po-dynamic/po-dynamic-container/po-dynamic-container.component.d.ts +8 -0
- package/lib/components/po-dynamic/po-dynamic-field.interface.d.ts +7 -0
- package/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-fields/po-dynamic-form-fields-base.component.d.ts +2 -3
- package/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form.component.d.ts +7 -0
- package/lib/components/po-dynamic/po-dynamic-view/po-dynamic-view-base.component.d.ts +5 -3
- package/lib/components/po-dynamic/po-dynamic-view/po-dynamic-view.component.d.ts +5 -0
- package/lib/components/po-dynamic/po-dynamic.module.d.ts +11 -9
- package/lib/components/po-dynamic/shared/po-dynamic-shared-base.d.ts +18 -0
- package/lib/components/po-search/interfaces/po-search-option.interface.d.ts +21 -0
- package/lib/components/po-search/po-search-base.component.d.ts +20 -1
- package/lib/components/po-search/po-search.component.d.ts +53 -4
- package/lib/components/po-search/po-search.module.d.ts +2 -1
- package/package.json +4 -4
- package/po-ui-ng-components-17.7.0.tgz +0 -0
- package/schematics/ng-add/index.js +1 -1
- package/schematics/ng-update/v14/index.js +1 -1
- package/schematics/ng-update/v15/index.js +1 -1
- package/schematics/ng-update/v16/index.js +1 -1
- package/schematics/ng-update/v17/index.js +1 -1
- package/schematics/ng-update/v2/index.js +1 -1
- package/schematics/ng-update/v3/index.js +1 -1
- package/schematics/ng-update/v4/index.js +1 -1
- package/schematics/ng-update/v5/index.js +1 -1
- package/schematics/ng-update/v6/index.js +1 -1
- package/po-ui-ng-components-17.5.0.tgz +0 -0
|
@@ -1,14 +1,21 @@
|
|
|
1
|
-
import { Component, ElementRef, ViewChild } from '@angular/core';
|
|
2
|
-
import {
|
|
1
|
+
import { ChangeDetectionStrategy, Component, ElementRef, ViewChild } from '@angular/core';
|
|
2
|
+
import { PoControlPositionService } from '../../services/po-control-position/po-control-position.service';
|
|
3
3
|
import { PoSearchFilterMode } from './enum/po-search-filter-mode.enum';
|
|
4
|
+
import { PoSearchBaseComponent } from './po-search-base.component';
|
|
5
|
+
import { PoKeyCodeEnum } from './../../enums/po-key-code.enum';
|
|
4
6
|
import * as i0 from "@angular/core";
|
|
5
7
|
import * as i1 from "../../services/po-language/po-language.service";
|
|
6
|
-
import * as i2 from "
|
|
7
|
-
import * as i3 from "
|
|
8
|
+
import * as i2 from "../../services/po-control-position/po-control-position.service";
|
|
9
|
+
import * as i3 from "@angular/common";
|
|
10
|
+
import * as i4 from "../po-icon/po-icon.component";
|
|
11
|
+
import * as i5 from "../po-listbox/po-listbox.component";
|
|
8
12
|
const _c0 = ["poSearchInput"];
|
|
13
|
+
const _c1 = ["poListboxContainerElement"];
|
|
14
|
+
const _c2 = ["poListboxElement"];
|
|
15
|
+
const _c3 = ["poListbox"];
|
|
9
16
|
function PoSearchComponent_div_1_Template(rf, ctx) { if (rf & 1) {
|
|
10
|
-
i0.ɵɵelementStart(0, "div",
|
|
11
|
-
i0.ɵɵelement(1, "po-icon",
|
|
17
|
+
i0.ɵɵelementStart(0, "div", 11);
|
|
18
|
+
i0.ɵɵelement(1, "po-icon", 12);
|
|
12
19
|
i0.ɵɵelementEnd();
|
|
13
20
|
} if (rf & 2) {
|
|
14
21
|
const ctx_r0 = i0.ɵɵnextContext();
|
|
@@ -16,20 +23,20 @@ function PoSearchComponent_div_1_Template(rf, ctx) { if (rf & 1) {
|
|
|
16
23
|
i0.ɵɵproperty("p-icon", ctx_r0.icon ? ctx_r0.icon : "po-icon-search");
|
|
17
24
|
} }
|
|
18
25
|
function PoSearchComponent_button_5_Template(rf, ctx) { if (rf & 1) {
|
|
19
|
-
const
|
|
20
|
-
i0.ɵɵelementStart(0, "button",
|
|
21
|
-
i0.ɵɵlistener("click", function PoSearchComponent_button_5_Template_button_click_0_listener() { i0.ɵɵrestoreView(
|
|
22
|
-
i0.ɵɵelement(1, "po-icon",
|
|
26
|
+
const _r8 = i0.ɵɵgetCurrentView();
|
|
27
|
+
i0.ɵɵelementStart(0, "button", 13);
|
|
28
|
+
i0.ɵɵlistener("click", function PoSearchComponent_button_5_Template_button_click_0_listener() { i0.ɵɵrestoreView(_r8); const ctx_r7 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r7.clearSearch()); })("keydown.enter", function PoSearchComponent_button_5_Template_button_keydown_enter_0_listener() { i0.ɵɵrestoreView(_r8); const ctx_r9 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r9.clearSearch()); });
|
|
29
|
+
i0.ɵɵelement(1, "po-icon", 14);
|
|
23
30
|
i0.ɵɵelementEnd();
|
|
24
31
|
} if (rf & 2) {
|
|
25
32
|
const ctx_r2 = i0.ɵɵnextContext();
|
|
26
33
|
i0.ɵɵproperty("ariaLabel", ctx_r2.literals.clean);
|
|
27
34
|
} }
|
|
28
35
|
function PoSearchComponent_button_6_Template(rf, ctx) { if (rf & 1) {
|
|
29
|
-
const
|
|
30
|
-
i0.ɵɵelementStart(0, "button",
|
|
31
|
-
i0.ɵɵlistener("click", function PoSearchComponent_button_6_Template_button_click_0_listener() { i0.ɵɵrestoreView(
|
|
32
|
-
i0.ɵɵelement(1, "po-icon",
|
|
36
|
+
const _r11 = i0.ɵɵgetCurrentView();
|
|
37
|
+
i0.ɵɵelementStart(0, "button", 15);
|
|
38
|
+
i0.ɵɵlistener("click", function PoSearchComponent_button_6_Template_button_click_0_listener() { i0.ɵɵrestoreView(_r11); const ctx_r10 = i0.ɵɵnextContext(); const _r1 = i0.ɵɵreference(3); return i0.ɵɵresetView(ctx_r10.onSearchChange(_r1.value, true, true)); })("keydown.enter", function PoSearchComponent_button_6_Template_button_keydown_enter_0_listener() { i0.ɵɵrestoreView(_r11); const ctx_r12 = i0.ɵɵnextContext(); const _r1 = i0.ɵɵreference(3); return i0.ɵɵresetView(ctx_r12.onSearchChange(_r1.value, true, true)); });
|
|
39
|
+
i0.ɵɵelement(1, "po-icon", 12);
|
|
33
40
|
i0.ɵɵelementEnd();
|
|
34
41
|
} if (rf & 2) {
|
|
35
42
|
const ctx_r3 = i0.ɵɵnextContext();
|
|
@@ -37,6 +44,8 @@ function PoSearchComponent_button_6_Template(rf, ctx) { if (rf & 1) {
|
|
|
37
44
|
i0.ɵɵadvance();
|
|
38
45
|
i0.ɵɵproperty("p-icon", ctx_r3.icon ? ctx_r3.icon : "po-icon-search");
|
|
39
46
|
} }
|
|
47
|
+
const poSearchContainerOffset = 8;
|
|
48
|
+
const poSearchContainerPositionDefault = 'bottom';
|
|
40
49
|
/**
|
|
41
50
|
* @docsExtends PoSearchBaseComponent
|
|
42
51
|
*
|
|
@@ -59,71 +68,265 @@ function PoSearchComponent_button_6_Template(rf, ctx) { if (rf & 1) {
|
|
|
59
68
|
* <file name="sample-po-search-find-people/sample-po-search-find-people.service.ts"> </file>
|
|
60
69
|
* </example>
|
|
61
70
|
*
|
|
71
|
+
* <example name="po-search-listbox" title="PO Search With Listbox">
|
|
72
|
+
* <file name="sample-po-search-listbox/sample-po-search-listbox.component.html"> </file>
|
|
73
|
+
* <file name="sample-po-search-listbox/sample-po-search-listbox.component.ts"> </file>
|
|
74
|
+
* <file name="sample-po-search-listbox/sample-po-search-listbox.service.ts"> </file>
|
|
75
|
+
* </example>
|
|
76
|
+
*
|
|
62
77
|
*/
|
|
63
78
|
export class PoSearchComponent extends PoSearchBaseComponent {
|
|
64
79
|
languageService;
|
|
65
80
|
renderer;
|
|
81
|
+
changeDetector;
|
|
82
|
+
controlPosition;
|
|
83
|
+
clickoutListener;
|
|
84
|
+
eventResizeListener;
|
|
66
85
|
poSearchInput;
|
|
86
|
+
poListboxContainerElement;
|
|
87
|
+
poListboxElement;
|
|
88
|
+
poListbox;
|
|
89
|
+
listboxFilteredItems = [];
|
|
67
90
|
filteredItems = [];
|
|
68
|
-
|
|
91
|
+
listboxOpen = false;
|
|
92
|
+
shouldMarkLetters = true;
|
|
93
|
+
isFiltering = false;
|
|
94
|
+
listboxItemclicked = false;
|
|
95
|
+
constructor(languageService, renderer, changeDetector, controlPosition) {
|
|
69
96
|
super(languageService);
|
|
70
97
|
this.languageService = languageService;
|
|
71
98
|
this.renderer = renderer;
|
|
99
|
+
this.changeDetector = changeDetector;
|
|
100
|
+
this.controlPosition = controlPosition;
|
|
72
101
|
}
|
|
73
102
|
ngOnInit() {
|
|
74
103
|
this.filteredItems = this.items;
|
|
104
|
+
if (this.showListbox) {
|
|
105
|
+
this.listboxFilteredItems = this.listboxItems;
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
ngOnDestroy() {
|
|
109
|
+
this.removeListeners();
|
|
75
110
|
}
|
|
76
111
|
clearSearch() {
|
|
77
112
|
this.poSearchInput.nativeElement.value = '';
|
|
78
113
|
this.onSearchChange('', true);
|
|
79
114
|
this.filteredItemsChange.emit(this.items);
|
|
115
|
+
this.onCloseListbox();
|
|
116
|
+
}
|
|
117
|
+
onSearchChange(searchText, activated, buttonClick) {
|
|
118
|
+
searchText = searchText.toLowerCase();
|
|
119
|
+
this.isFiltering = true;
|
|
120
|
+
if (this.showListbox && !buttonClick && searchText.length > 0) {
|
|
121
|
+
this.controlListboxVisibility(true);
|
|
122
|
+
this.listboxFilteredItems = this.getListboxFilteredItems(searchText);
|
|
123
|
+
}
|
|
124
|
+
else {
|
|
125
|
+
if (searchText.length === 0) {
|
|
126
|
+
this.listboxFilteredItems = this.listboxItems;
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
if (activated && !this.listboxItemclicked) {
|
|
130
|
+
this.updateFilteredItems(searchText);
|
|
131
|
+
this.filteredItemsChange.emit(this.filteredItems);
|
|
132
|
+
this.changeModel.emit(searchText);
|
|
133
|
+
}
|
|
134
|
+
if (this.listboxItemclicked) {
|
|
135
|
+
this.listboxItemclicked = false;
|
|
136
|
+
}
|
|
137
|
+
this.changeDetector.detectChanges();
|
|
138
|
+
}
|
|
139
|
+
updateFilteredItems(searchText) {
|
|
140
|
+
if (this.items && this.items.length > 0) {
|
|
141
|
+
this.filteredItems = this.getFilteredItems(searchText);
|
|
142
|
+
}
|
|
143
|
+
else {
|
|
144
|
+
this.filteredItems = [];
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
getFilteredItems(searchText) {
|
|
148
|
+
return this.items.filter(item => this.itemMatchesFilter(item, searchText));
|
|
149
|
+
}
|
|
150
|
+
itemMatchesFilter(item, searchText) {
|
|
151
|
+
const valuesToSearch = this.filterKeys
|
|
152
|
+
.map(key => (typeof item[key] !== 'string' ? String(item[key]) : item[key]))
|
|
153
|
+
.map(value => (value ? value.toLowerCase() : ''));
|
|
154
|
+
return valuesToSearch.some(value => this.filterValue(value, searchText));
|
|
155
|
+
}
|
|
156
|
+
getListboxFilteredItems(searchText) {
|
|
157
|
+
return this.listboxItems.filter(item => this.filterValue(item.value, searchText));
|
|
158
|
+
}
|
|
159
|
+
filterValue(value, searchText) {
|
|
160
|
+
value = value?.toLowerCase();
|
|
161
|
+
switch (this.filterType) {
|
|
162
|
+
case PoSearchFilterMode.startsWith:
|
|
163
|
+
return value?.startsWith(searchText);
|
|
164
|
+
case PoSearchFilterMode.contains:
|
|
165
|
+
return value?.includes(searchText);
|
|
166
|
+
case PoSearchFilterMode.endsWith:
|
|
167
|
+
return value?.endsWith(searchText);
|
|
168
|
+
default:
|
|
169
|
+
return false;
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
get listboxItems() {
|
|
173
|
+
return this.items
|
|
174
|
+
.map(item => this.filterKeys.map(key => item[key]).map(item => (typeof item !== 'string' ? String(item) : item)))
|
|
175
|
+
.flat()
|
|
176
|
+
.map(value => ({ label: value, value }));
|
|
177
|
+
}
|
|
178
|
+
onCloseListbox() {
|
|
80
179
|
this.poSearchInput.nativeElement.focus();
|
|
180
|
+
this.controlListboxVisibility(false);
|
|
181
|
+
this.isFiltering = false;
|
|
182
|
+
}
|
|
183
|
+
onListboxClick(option, event) {
|
|
184
|
+
if (event) {
|
|
185
|
+
event.stopPropagation();
|
|
186
|
+
}
|
|
187
|
+
if (!event || event.code === 'Enter') {
|
|
188
|
+
this.listboxItemclicked = true;
|
|
189
|
+
}
|
|
190
|
+
this.poSearchInput.nativeElement.value = option.value;
|
|
191
|
+
this.listboxOnClick.emit(option.value);
|
|
192
|
+
this.onCloseListbox();
|
|
193
|
+
if (this.type === 'action') {
|
|
194
|
+
this.listboxItemclicked = false;
|
|
195
|
+
this.onSearchChange(option.value.toString(), true, true);
|
|
196
|
+
}
|
|
81
197
|
}
|
|
82
|
-
|
|
83
|
-
if (
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
this.filteredItems = this.items.filter(item => this.filterKeys.some(key => {
|
|
87
|
-
let value = item[key];
|
|
88
|
-
if (typeof value !== 'string') {
|
|
89
|
-
value = value != null ? value.toString() : null;
|
|
90
|
-
}
|
|
91
|
-
value = value != null ? value.toLowerCase() : null;
|
|
92
|
-
if (this.filterType === PoSearchFilterMode.startsWith) {
|
|
93
|
-
return value != null && value.startsWith(searchText);
|
|
94
|
-
}
|
|
95
|
-
else if (this.filterType === PoSearchFilterMode.contains) {
|
|
96
|
-
return value != null && value.includes(searchText);
|
|
97
|
-
}
|
|
98
|
-
else if (this.filterType === PoSearchFilterMode.endsWith) {
|
|
99
|
-
return value != null && value.endsWith(searchText);
|
|
100
|
-
}
|
|
101
|
-
return false;
|
|
102
|
-
}));
|
|
103
|
-
this.filteredItemsChange.emit(this.filteredItems);
|
|
198
|
+
onBlur() {
|
|
199
|
+
if (this.listboxOpen) {
|
|
200
|
+
if (!this.poListbox.items.length) {
|
|
201
|
+
this.controlListboxVisibility(false);
|
|
104
202
|
}
|
|
105
203
|
else {
|
|
106
|
-
this.
|
|
107
|
-
this.filteredItemsChange.emit(this.filteredItems);
|
|
204
|
+
this.focusItem();
|
|
108
205
|
}
|
|
109
|
-
this.changeModel.emit(searchText);
|
|
110
206
|
}
|
|
111
207
|
}
|
|
112
|
-
|
|
208
|
+
onKeyDown(event) {
|
|
209
|
+
const key = event.keyCode;
|
|
210
|
+
if (event.shiftKey && key === PoKeyCodeEnum.tab) {
|
|
211
|
+
this.controlListboxVisibility(false);
|
|
212
|
+
return;
|
|
213
|
+
}
|
|
214
|
+
if (key === PoKeyCodeEnum.tab) {
|
|
215
|
+
this.controlListboxVisibility(false);
|
|
216
|
+
return;
|
|
217
|
+
}
|
|
218
|
+
if (key === PoKeyCodeEnum.arrowDown) {
|
|
219
|
+
event.preventDefault();
|
|
220
|
+
if (!this.listboxOpen) {
|
|
221
|
+
return;
|
|
222
|
+
}
|
|
223
|
+
this.focusItem();
|
|
224
|
+
this.controlListboxVisibility(true);
|
|
225
|
+
return;
|
|
226
|
+
}
|
|
227
|
+
if (key === PoKeyCodeEnum.esc) {
|
|
228
|
+
this.controlListboxVisibility(false);
|
|
229
|
+
this.poSearchInput.nativeElement.focus();
|
|
230
|
+
}
|
|
231
|
+
if (key === PoKeyCodeEnum.enter && this.listboxOpen) {
|
|
232
|
+
this.controlListboxVisibility(false);
|
|
233
|
+
this.isFiltering = false;
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
focusItem() {
|
|
237
|
+
const listboxItemList = document.querySelectorAll('.po-listbox-item');
|
|
238
|
+
setTimeout(() => {
|
|
239
|
+
Array.from(listboxItemList).forEach((el) => {
|
|
240
|
+
el.tabIndex = -1;
|
|
241
|
+
el.classList.remove('cdk-option-active');
|
|
242
|
+
});
|
|
243
|
+
const firstOption = listboxItemList[0];
|
|
244
|
+
firstOption.focus();
|
|
245
|
+
firstOption.classList.add('cdk-option-active');
|
|
246
|
+
});
|
|
247
|
+
}
|
|
248
|
+
setContainerPosition() {
|
|
249
|
+
if (this.poListboxContainerElement && this.poSearchInput) {
|
|
250
|
+
this.controlPosition.setElements(this.poListboxContainerElement.nativeElement, poSearchContainerOffset, this.poSearchInput, ['top', 'bottom'], true);
|
|
251
|
+
this.adjustContainerPosition();
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
adjustContainerPosition() {
|
|
255
|
+
if (this.poListboxContainerElement && this.poSearchInput) {
|
|
256
|
+
this.controlPosition.adjustPosition(poSearchContainerPositionDefault);
|
|
257
|
+
}
|
|
258
|
+
}
|
|
259
|
+
controlListboxVisibility(toOpen) {
|
|
260
|
+
toOpen ? this.openListbox() : this.closeListbox();
|
|
261
|
+
}
|
|
262
|
+
openListbox() {
|
|
263
|
+
this.listboxOpen = true;
|
|
264
|
+
this.changeDetector.detectChanges();
|
|
265
|
+
this.initializeListeners();
|
|
266
|
+
this.poSearchInput.nativeElement.focus();
|
|
267
|
+
this.setContainerPosition();
|
|
268
|
+
}
|
|
269
|
+
closeListbox() {
|
|
270
|
+
this.listboxOpen = false;
|
|
271
|
+
this.changeDetector.detectChanges();
|
|
272
|
+
this.removeListeners();
|
|
273
|
+
}
|
|
274
|
+
clickedOutsideInput(event) {
|
|
275
|
+
if (this.listboxOpen &&
|
|
276
|
+
!this.poSearchInput.nativeElement.contains(event.target) &&
|
|
277
|
+
(!this.poListboxElement || !this.poListboxElement.nativeElement.contains(event.target))) {
|
|
278
|
+
this.controlListboxVisibility(false);
|
|
279
|
+
}
|
|
280
|
+
}
|
|
281
|
+
initializeListeners() {
|
|
282
|
+
this.removeListeners();
|
|
283
|
+
this.clickoutListener = this.renderer.listen('document', 'click', (event) => {
|
|
284
|
+
this.clickedOutsideInput(event);
|
|
285
|
+
});
|
|
286
|
+
this.eventResizeListener = this.renderer.listen('window', 'resize', () => {
|
|
287
|
+
setTimeout(() => this.adjustContainerPosition(), 250);
|
|
288
|
+
});
|
|
289
|
+
window.addEventListener('scroll', this.onScroll, true);
|
|
290
|
+
}
|
|
291
|
+
removeListeners() {
|
|
292
|
+
if (this.clickoutListener) {
|
|
293
|
+
this.clickoutListener();
|
|
294
|
+
}
|
|
295
|
+
if (this.eventResizeListener) {
|
|
296
|
+
this.eventResizeListener();
|
|
297
|
+
}
|
|
298
|
+
window.removeEventListener('scroll', this.onScroll, true);
|
|
299
|
+
}
|
|
300
|
+
onScroll = () => {
|
|
301
|
+
this.adjustContainerPosition();
|
|
302
|
+
};
|
|
303
|
+
getInputValue() {
|
|
304
|
+
return this.poSearchInput.nativeElement.value;
|
|
305
|
+
}
|
|
306
|
+
static ɵfac = function PoSearchComponent_Factory(t) { return new (t || PoSearchComponent)(i0.ɵɵdirectiveInject(i1.PoLanguageService), i0.ɵɵdirectiveInject(i0.Renderer2), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i2.PoControlPositionService)); };
|
|
113
307
|
static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoSearchComponent, selectors: [["po-search"]], viewQuery: function PoSearchComponent_Query(rf, ctx) { if (rf & 1) {
|
|
114
308
|
i0.ɵɵviewQuery(_c0, 7, ElementRef);
|
|
309
|
+
i0.ɵɵviewQuery(_c1, 5, ElementRef);
|
|
310
|
+
i0.ɵɵviewQuery(_c2, 5, ElementRef);
|
|
311
|
+
i0.ɵɵviewQuery(_c3, 5);
|
|
115
312
|
} if (rf & 2) {
|
|
116
313
|
let _t;
|
|
117
314
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.poSearchInput = _t.first);
|
|
118
|
-
|
|
315
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.poListboxContainerElement = _t.first);
|
|
316
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.poListboxElement = _t.first);
|
|
317
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.poListbox = _t.first);
|
|
318
|
+
} }, features: [i0.ɵɵProvidersFeature([PoControlPositionService]), i0.ɵɵInheritDefinitionFeature], decls: 12, vars: 19, consts: [[1, "po-search"], ["class", "po-search-icon", 4, "ngIf"], ["type", "text", 1, "po-search-input", 3, "ariaLabel", "disabled", "placeholder", "input", "keyup.enter", "keydown", "blur"], ["poSearchInput", ""], [1, "po-search-buttons"], ["class", "po-search-button po-search-button-clean", "type", "button", 3, "ariaLabel", "click", "keydown.enter", 4, "ngIf"], ["class", "po-search-button po-search-button-trigger", "type", "button", 3, "ariaLabel", "disabled", "click", "keydown.enter", 4, "ngIf"], [1, "po-search-listbox-container", 3, "hidden"], ["poListboxContainerElement", ""], ["p-type", "option", 3, "p-items", "p-visible", "p-filter-mode", "p-should-mark-letter", "p-filtering", "p-search-value", "p-selectcombo-item", "p-close"], ["poListbox", "", "poListboxElement", ""], [1, "po-search-icon"], [3, "p-icon"], ["type", "button", 1, "po-search-button", "po-search-button-clean", 3, "ariaLabel", "click", "keydown.enter"], ["p-icon", "po-icon-clear-content"], ["type", "button", 1, "po-search-button", "po-search-button-trigger", 3, "ariaLabel", "disabled", "click", "keydown.enter"]], template: function PoSearchComponent_Template(rf, ctx) { if (rf & 1) {
|
|
119
319
|
i0.ɵɵelementStart(0, "div", 0);
|
|
120
320
|
i0.ɵɵtemplate(1, PoSearchComponent_div_1_Template, 2, 1, "div", 1);
|
|
121
321
|
i0.ɵɵelementStart(2, "input", 2, 3);
|
|
122
|
-
i0.ɵɵlistener("input", function PoSearchComponent_Template_input_input_2_listener($event) { return ctx.onSearchChange($event.target.value, ctx.type === "action" ? true : false); })("keyup.enter", function PoSearchComponent_Template_input_keyup_enter_2_listener($event) {
|
|
322
|
+
i0.ɵɵlistener("input", function PoSearchComponent_Template_input_input_2_listener($event) { ctx.onSearchChange($event.target.value, false); return ctx.onSearchChange($event.target.value, ctx.type === "action" ? true : false); })("keyup.enter", function PoSearchComponent_Template_input_keyup_enter_2_listener($event) { ctx.listboxOpen ? ctx.closeListbox() : ctx.onSearchChange($event.target.value, ctx.type === "trigger" ? true : false, true); return ctx.closeListbox(); })("keydown", function PoSearchComponent_Template_input_keydown_2_listener($event) { return ctx.onKeyDown($event); })("blur", function PoSearchComponent_Template_input_blur_2_listener() { return ctx.onBlur(); });
|
|
123
323
|
i0.ɵɵelementEnd();
|
|
124
324
|
i0.ɵɵelementStart(4, "div", 4);
|
|
125
325
|
i0.ɵɵtemplate(5, PoSearchComponent_button_5_Template, 2, 1, "button", 5)(6, PoSearchComponent_button_6_Template, 2, 3, "button", 6);
|
|
126
326
|
i0.ɵɵelementEnd()();
|
|
327
|
+
i0.ɵɵelementStart(7, "div", 7, 8)(9, "po-listbox", 9, 10);
|
|
328
|
+
i0.ɵɵlistener("p-selectcombo-item", function PoSearchComponent_Template_po_listbox_p_selectcombo_item_9_listener($event) { return ctx.onListboxClick($event, $event.event); })("p-close", function PoSearchComponent_Template_po_listbox_p_close_9_listener() { return ctx.onCloseListbox(); });
|
|
329
|
+
i0.ɵɵelementEnd()();
|
|
127
330
|
} if (rf & 2) {
|
|
128
331
|
const _r1 = i0.ɵɵreference(3);
|
|
129
332
|
i0.ɵɵclassProp("po-search-disabled", ctx.disabled);
|
|
@@ -136,14 +339,27 @@ export class PoSearchComponent extends PoSearchBaseComponent {
|
|
|
136
339
|
i0.ɵɵproperty("ngIf", !!_r1.value && !ctx.disabled);
|
|
137
340
|
i0.ɵɵadvance();
|
|
138
341
|
i0.ɵɵproperty("ngIf", ctx.type === "trigger");
|
|
139
|
-
|
|
342
|
+
i0.ɵɵadvance();
|
|
343
|
+
i0.ɵɵproperty("hidden", !ctx.listboxOpen);
|
|
344
|
+
i0.ɵɵadvance(2);
|
|
345
|
+
i0.ɵɵproperty("p-items", ctx.listboxFilteredItems)("p-visible", ctx.listboxOpen)("p-filter-mode", ctx.filterType)("p-should-mark-letter", ctx.shouldMarkLetters)("p-filtering", ctx.isFiltering)("p-search-value", ctx.getInputValue());
|
|
346
|
+
} }, dependencies: [i3.NgIf, i4.PoIconComponent, i5.PoListBoxComponent], encapsulation: 2, changeDetection: 0 });
|
|
140
347
|
}
|
|
141
348
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoSearchComponent, [{
|
|
142
349
|
type: Component,
|
|
143
|
-
args: [{ selector: 'po-search', template: "<div class=\"po-search\" [class.po-search-disabled]=\"disabled\">\n <div *ngIf=\"type === 'action'\" class=\"po-search-icon\">\n <po-icon [p-icon]=\"icon ? icon : 'po-icon-search'\"></po-icon>\n </div>\n\n <input\n #poSearchInput\n class=\"po-search-input\"\n type=\"text\"\n [ariaLabel]=\"ariaLabel\"\n [class.po-search-input-clean]=\"!!poSearchInput.value && !disabled\"\n [class.po-search-input-trigger]=\"type === 'trigger'\"\n [disabled]=\"disabled\"\n [placeholder]=\"literals.search\"\n (input)=\"onSearchChange($event.target.value, type === 'action' ? true : false)\"\n (keyup.enter)=\"onSearchChange($event.target.value, type === 'trigger' ? true : false)\"\n />\n\n <div class=\"po-search-buttons\">\n <button\n *ngIf=\"!!poSearchInput.value && !disabled\"\n class=\"po-search-button po-search-button-clean\"\n type=\"button\"\n [ariaLabel]=\"literals.clean\"\n (click)=\"clearSearch()\"\n (keydown.enter)=\"clearSearch()\"\n >\n <po-icon p-icon=\"po-icon-clear-content\"></po-icon>\n </button>\n\n <button\n *ngIf=\"type === 'trigger'\"\n class=\"po-search-button po-search-button-trigger\"\n type=\"button\"\n [ariaLabel]=\"literals.search\"\n (click)=\"onSearchChange(poSearchInput.value, true)\"\n (keydown.enter)=\"onSearchChange(poSearchInput.value, true)\"\n [disabled]=\"disabled\"\n >\n <po-icon [p-icon]=\"icon ? icon : 'po-icon-search'\"> </po-icon>\n </button>\n </div>\n</div>\n" }]
|
|
144
|
-
}], () => [{ type: i1.PoLanguageService }, { type: i0.Renderer2 }], { poSearchInput: [{
|
|
350
|
+
args: [{ selector: 'po-search', changeDetection: ChangeDetectionStrategy.OnPush, providers: [PoControlPositionService], template: "<div class=\"po-search\" [class.po-search-disabled]=\"disabled\">\n <div *ngIf=\"type === 'action'\" class=\"po-search-icon\">\n <po-icon [p-icon]=\"icon ? icon : 'po-icon-search'\"></po-icon>\n </div>\n\n <input\n #poSearchInput\n class=\"po-search-input\"\n type=\"text\"\n [ariaLabel]=\"ariaLabel\"\n [class.po-search-input-clean]=\"!!poSearchInput.value && !disabled\"\n [class.po-search-input-trigger]=\"type === 'trigger'\"\n [disabled]=\"disabled\"\n [placeholder]=\"literals.search\"\n (input)=\"\n onSearchChange($event.target.value, false); onSearchChange($event.target.value, type === 'action' ? true : false)\n \"\n (keyup.enter)=\"\n listboxOpen ? closeListbox() : onSearchChange($event.target.value, type === 'trigger' ? true : false, true);\n closeListbox()\n \"\n (keydown)=\"onKeyDown($event)\"\n (blur)=\"onBlur()\"\n />\n\n <div class=\"po-search-buttons\">\n <button\n *ngIf=\"!!poSearchInput.value && !disabled\"\n class=\"po-search-button po-search-button-clean\"\n type=\"button\"\n [ariaLabel]=\"literals.clean\"\n (click)=\"clearSearch()\"\n (keydown.enter)=\"clearSearch()\"\n >\n <po-icon p-icon=\"po-icon-clear-content\"></po-icon>\n </button>\n\n <button\n *ngIf=\"type === 'trigger'\"\n class=\"po-search-button po-search-button-trigger\"\n type=\"button\"\n [ariaLabel]=\"literals.search\"\n (click)=\"onSearchChange(poSearchInput.value, true, true)\"\n (keydown.enter)=\"onSearchChange(poSearchInput.value, true, true)\"\n [disabled]=\"disabled\"\n >\n <po-icon [p-icon]=\"icon ? icon : 'po-icon-search'\"> </po-icon>\n </button>\n </div>\n</div>\n\n<div #poListboxContainerElement class=\"po-search-listbox-container\" [hidden]=\"!listboxOpen\">\n <po-listbox\n #poListbox\n #poListboxElement\n p-type=\"option\"\n [p-items]=\"listboxFilteredItems\"\n (p-selectcombo-item)=\"onListboxClick($event, $event.event)\"\n [p-visible]=\"listboxOpen\"\n [p-filter-mode]=\"filterType\"\n [p-should-mark-letter]=\"shouldMarkLetters\"\n [p-filtering]=\"isFiltering\"\n [p-search-value]=\"getInputValue()\"\n (p-close)=\"onCloseListbox()\"\n ></po-listbox>\n</div>\n" }]
|
|
351
|
+
}], () => [{ type: i1.PoLanguageService }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }, { type: i2.PoControlPositionService }], { poSearchInput: [{
|
|
145
352
|
type: ViewChild,
|
|
146
353
|
args: ['poSearchInput', { read: ElementRef, static: true }]
|
|
354
|
+
}], poListboxContainerElement: [{
|
|
355
|
+
type: ViewChild,
|
|
356
|
+
args: ['poListboxContainerElement', { read: ElementRef }]
|
|
357
|
+
}], poListboxElement: [{
|
|
358
|
+
type: ViewChild,
|
|
359
|
+
args: ['poListboxElement', { read: ElementRef }]
|
|
360
|
+
}], poListbox: [{
|
|
361
|
+
type: ViewChild,
|
|
362
|
+
args: ['poListbox']
|
|
147
363
|
}] }); })();
|
|
148
|
-
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoSearchComponent, { className: "PoSearchComponent", filePath: "lib/components/po-search/po-search.component.ts", lineNumber:
|
|
149
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-search.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/components/po-search/po-search.component.ts","../../../../../../projects/ui/src/lib/components/po-search/po-search.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, OnInit, Renderer2, ViewChild } from '@angular/core';\nimport { PoLanguageService } from '../../services/po-language/po-language.service';\nimport { PoSearchBaseComponent } from './po-search-base.component';\nimport { PoSearchFilterMode } from './enum/po-search-filter-mode.enum';\n\n/**\n * @docsExtends PoSearchBaseComponent\n *\n * @example\n *\n * <example name=\"po-search-basic\" title=\"PO Search Basic\">\n *  <file name=\"sample-po-search-basic/sample-po-search-basic.component.html\"> </file>\n *  <file name=\"sample-po-search-basic/sample-po-search-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-search-labs\" title=\"PO Search Labs\">\n *  <file name=\"sample-po-search-labs/sample-po-search-labs.component.html\"> </file>\n *  <file name=\"sample-po-search-labs/sample-po-search-labs.component.ts\"> </file>\n *  <file name=\"sample-po-search-labs/sample-po-search-labs.service.ts\"> </file>\n * </example>\n *\n * <example name=\"po-search-find-people\" title=\"PO Search Find People\">\n *  <file name=\"sample-po-search-find-people/sample-po-search-find-people.component.html\"> </file>\n *  <file name=\"sample-po-search-find-people/sample-po-search-find-people.component.ts\"> </file>\n *  <file name=\"sample-po-search-find-people/sample-po-search-find-people.service.ts\"> </file>\n * </example>\n *\n */\n@Component({\n  selector: 'po-search',\n  templateUrl: './po-search.component.html'\n})\nexport class PoSearchComponent extends PoSearchBaseComponent implements OnInit {\n  @ViewChild('poSearchInput', { read: ElementRef, static: true }) poSearchInput: ElementRef;\n\n  filteredItems: Array<any> = [];\n\n  constructor(\n    public languageService: PoLanguageService,\n    private renderer: Renderer2\n  ) {\n    super(languageService);\n  }\n\n  ngOnInit(): void {\n    this.filteredItems = this.items;\n  }\n\n  clearSearch(): void {\n    this.poSearchInput.nativeElement.value = '';\n    this.onSearchChange('', true);\n    this.filteredItemsChange.emit(this.items);\n    this.poSearchInput.nativeElement.focus();\n  }\n\n  onSearchChange(searchText: string, activated: boolean): void {\n    if (activated) {\n      searchText = searchText.toLowerCase();\n\n      if (this.items && this.items.length > 0) {\n        this.filteredItems = this.items.filter(item =>\n          this.filterKeys.some(key => {\n            let value = item[key];\n\n            if (typeof value !== 'string') {\n              value = value != null ? value.toString() : null;\n            }\n\n            value = value != null ? value.toLowerCase() : null;\n\n            if (this.filterType === PoSearchFilterMode.startsWith) {\n              return value != null && value.startsWith(searchText);\n            } else if (this.filterType === PoSearchFilterMode.contains) {\n              return value != null && value.includes(searchText);\n            } else if (this.filterType === PoSearchFilterMode.endsWith) {\n              return value != null && value.endsWith(searchText);\n            }\n\n            return false;\n          })\n        );\n        this.filteredItemsChange.emit(this.filteredItems);\n      } else {\n        this.filteredItems = [];\n        this.filteredItemsChange.emit(this.filteredItems);\n      }\n      this.changeModel.emit(searchText);\n    }\n  }\n}\n","<div class=\"po-search\" [class.po-search-disabled]=\"disabled\">\n  <div *ngIf=\"type === 'action'\" class=\"po-search-icon\">\n    <po-icon [p-icon]=\"icon ? icon : 'po-icon-search'\"></po-icon>\n  </div>\n\n  <input\n    #poSearchInput\n    class=\"po-search-input\"\n    type=\"text\"\n    [ariaLabel]=\"ariaLabel\"\n    [class.po-search-input-clean]=\"!!poSearchInput.value && !disabled\"\n    [class.po-search-input-trigger]=\"type === 'trigger'\"\n    [disabled]=\"disabled\"\n    [placeholder]=\"literals.search\"\n    (input)=\"onSearchChange($event.target.value, type === 'action' ? true : false)\"\n    (keyup.enter)=\"onSearchChange($event.target.value, type === 'trigger' ? true : false)\"\n  />\n\n  <div class=\"po-search-buttons\">\n    <button\n      *ngIf=\"!!poSearchInput.value && !disabled\"\n      class=\"po-search-button po-search-button-clean\"\n      type=\"button\"\n      [ariaLabel]=\"literals.clean\"\n      (click)=\"clearSearch()\"\n      (keydown.enter)=\"clearSearch()\"\n    >\n      <po-icon p-icon=\"po-icon-clear-content\"></po-icon>\n    </button>\n\n    <button\n      *ngIf=\"type === 'trigger'\"\n      class=\"po-search-button po-search-button-trigger\"\n      type=\"button\"\n      [ariaLabel]=\"literals.search\"\n      (click)=\"onSearchChange(poSearchInput.value, true)\"\n      (keydown.enter)=\"onSearchChange(poSearchInput.value, true)\"\n      [disabled]=\"disabled\"\n    >\n      <po-icon [p-icon]=\"icon ? icon : 'po-icon-search'\"> </po-icon>\n    </button>\n  </div>\n</div>\n"]}
|
|
364
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoSearchComponent, { className: "PoSearchComponent", filePath: "lib/components/po-search/po-search.component.ts", lineNumber: 56 }); })();
|
|
365
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-search.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/components/po-search/po-search.component.ts","../../../../../../projects/ui/src/lib/components/po-search/po-search.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  OnDestroy,\n  OnInit,\n  Renderer2,\n  ViewChild\n} from '@angular/core';\nimport { PoControlPositionService } from '../../services/po-control-position/po-control-position.service';\nimport { PoLanguageService } from '../../services/po-language/po-language.service';\nimport { PoSearchFilterMode } from './enum/po-search-filter-mode.enum';\nimport { PoSearchOption } from './interfaces/po-search-option.interface';\nimport { PoSearchBaseComponent } from './po-search-base.component';\nimport { PoKeyCodeEnum } from './../../enums/po-key-code.enum';\nimport { PoListBoxComponent } from '../po-listbox';\nimport { CdkOption } from '@angular/cdk/listbox';\nconst poSearchContainerOffset = 8;\nconst poSearchContainerPositionDefault = 'bottom';\n/**\n * @docsExtends PoSearchBaseComponent\n *\n * @example\n *\n * <example name=\"po-search-basic\" title=\"PO Search Basic\">\n *  <file name=\"sample-po-search-basic/sample-po-search-basic.component.html\"> </file>\n *  <file name=\"sample-po-search-basic/sample-po-search-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-search-labs\" title=\"PO Search Labs\">\n *  <file name=\"sample-po-search-labs/sample-po-search-labs.component.html\"> </file>\n *  <file name=\"sample-po-search-labs/sample-po-search-labs.component.ts\"> </file>\n *  <file name=\"sample-po-search-labs/sample-po-search-labs.service.ts\"> </file>\n * </example>\n *\n * <example name=\"po-search-find-people\" title=\"PO Search Find People\">\n *  <file name=\"sample-po-search-find-people/sample-po-search-find-people.component.html\"> </file>\n *  <file name=\"sample-po-search-find-people/sample-po-search-find-people.component.ts\"> </file>\n *  <file name=\"sample-po-search-find-people/sample-po-search-find-people.service.ts\"> </file>\n * </example>\n *\n * <example name=\"po-search-listbox\" title=\"PO Search With Listbox\">\n *  <file name=\"sample-po-search-listbox/sample-po-search-listbox.component.html\"> </file>\n *  <file name=\"sample-po-search-listbox/sample-po-search-listbox.component.ts\"> </file>\n *  <file name=\"sample-po-search-listbox/sample-po-search-listbox.service.ts\"> </file>\n * </example>\n *\n */\n@Component({\n  selector: 'po-search',\n  templateUrl: './po-search.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [PoControlPositionService]\n})\nexport class PoSearchComponent extends PoSearchBaseComponent implements OnInit, OnDestroy {\n  private clickoutListener: () => void;\n  private eventResizeListener: () => void;\n\n  @ViewChild('poSearchInput', { read: ElementRef, static: true }) poSearchInput: ElementRef;\n  @ViewChild('poListboxContainerElement', { read: ElementRef }) poListboxContainerElement: ElementRef;\n  @ViewChild('poListboxElement', { read: ElementRef }) poListboxElement: ElementRef;\n  @ViewChild('poListbox') poListbox: PoListBoxComponent;\n\n  listboxFilteredItems: Array<any> = [];\n  filteredItems: Array<any> = [];\n  listboxOpen: boolean = false;\n  shouldMarkLetters: boolean = true;\n  isFiltering: boolean = false;\n  listboxItemclicked: boolean = false;\n\n  constructor(\n    public languageService: PoLanguageService,\n    private renderer: Renderer2,\n    private changeDetector: ChangeDetectorRef,\n    private controlPosition: PoControlPositionService\n  ) {\n    super(languageService);\n  }\n\n  ngOnInit(): void {\n    this.filteredItems = this.items;\n    if (this.showListbox) {\n      this.listboxFilteredItems = this.listboxItems;\n    }\n  }\n\n  ngOnDestroy() {\n    this.removeListeners();\n  }\n\n  clearSearch(): void {\n    this.poSearchInput.nativeElement.value = '';\n    this.onSearchChange('', true);\n    this.filteredItemsChange.emit(this.items);\n    this.onCloseListbox();\n  }\n\n  onSearchChange(searchText: string, activated: boolean, buttonClick?: boolean): void {\n    searchText = searchText.toLowerCase();\n    this.isFiltering = true;\n\n    if (this.showListbox && !buttonClick && searchText.length > 0) {\n      this.controlListboxVisibility(true);\n      this.listboxFilteredItems = this.getListboxFilteredItems(searchText);\n    } else {\n      if (searchText.length === 0) {\n        this.listboxFilteredItems = this.listboxItems;\n      }\n    }\n\n    if (activated && !this.listboxItemclicked) {\n      this.updateFilteredItems(searchText);\n      this.filteredItemsChange.emit(this.filteredItems);\n      this.changeModel.emit(searchText);\n    }\n\n    if (this.listboxItemclicked) {\n      this.listboxItemclicked = false;\n    }\n\n    this.changeDetector.detectChanges();\n  }\n\n  private updateFilteredItems(searchText: string): void {\n    if (this.items && this.items.length > 0) {\n      this.filteredItems = this.getFilteredItems(searchText);\n    } else {\n      this.filteredItems = [];\n    }\n  }\n\n  private getFilteredItems(searchText) {\n    return this.items.filter(item => this.itemMatchesFilter(item, searchText));\n  }\n\n  private itemMatchesFilter(item: any, searchText: string): boolean {\n    const valuesToSearch: Array<string> = this.filterKeys\n      .map(key => (typeof item[key] !== 'string' ? String(item[key]) : item[key]))\n      .map(value => (value ? value.toLowerCase() : ''));\n\n    return valuesToSearch.some(value => this.filterValue(value, searchText));\n  }\n\n  getListboxFilteredItems(searchText) {\n    return this.listboxItems.filter(item => this.filterValue(item.value, searchText));\n  }\n\n  private filterValue(value: string, searchText: string) {\n    value = value?.toLowerCase();\n    switch (this.filterType) {\n      case PoSearchFilterMode.startsWith:\n        return value?.startsWith(searchText);\n      case PoSearchFilterMode.contains:\n        return value?.includes(searchText);\n      case PoSearchFilterMode.endsWith:\n        return value?.endsWith(searchText);\n      default:\n        return false;\n    }\n  }\n\n  get listboxItems() {\n    return this.items\n      .map(item => this.filterKeys.map(key => item[key]).map(item => (typeof item !== 'string' ? String(item) : item)))\n      .flat()\n      .map(value => ({ label: value, value }));\n  }\n\n  onCloseListbox() {\n    this.poSearchInput.nativeElement.focus();\n    this.controlListboxVisibility(false);\n    this.isFiltering = false;\n  }\n\n  onListboxClick(option: PoSearchOption, event?: any) {\n    if (event) {\n      event.stopPropagation();\n    }\n\n    if (!event || event.code === 'Enter') {\n      this.listboxItemclicked = true;\n    }\n\n    this.poSearchInput.nativeElement.value = option.value;\n    this.listboxOnClick.emit(option.value);\n\n    this.onCloseListbox();\n    if (this.type === 'action') {\n      this.listboxItemclicked = false;\n      this.onSearchChange(option.value.toString(), true, true);\n    }\n  }\n\n  onBlur() {\n    if (this.listboxOpen) {\n      if (!this.poListbox.items.length) {\n        this.controlListboxVisibility(false);\n      } else {\n        this.focusItem();\n      }\n    }\n  }\n\n  onKeyDown(event?: any) {\n    const key = event.keyCode;\n\n    if (event.shiftKey && key === PoKeyCodeEnum.tab) {\n      this.controlListboxVisibility(false);\n      return;\n    }\n\n    if (key === PoKeyCodeEnum.tab) {\n      this.controlListboxVisibility(false);\n      return;\n    }\n\n    if (key === PoKeyCodeEnum.arrowDown) {\n      event.preventDefault();\n\n      if (!this.listboxOpen) {\n        return;\n      }\n\n      this.focusItem();\n      this.controlListboxVisibility(true);\n      return;\n    }\n\n    if (key === PoKeyCodeEnum.esc) {\n      this.controlListboxVisibility(false);\n      this.poSearchInput.nativeElement.focus();\n    }\n\n    if (key === PoKeyCodeEnum.enter && this.listboxOpen) {\n      this.controlListboxVisibility(false);\n      this.isFiltering = false;\n    }\n  }\n\n  private focusItem() {\n    const listboxItemList = document.querySelectorAll('.po-listbox-item');\n    setTimeout(() => {\n      Array.from(listboxItemList).forEach((el: HTMLElement) => {\n        el.tabIndex = -1;\n        el.classList.remove('cdk-option-active');\n      });\n\n      const firstOption = listboxItemList[0] as HTMLElement;\n      firstOption.focus();\n      firstOption.classList.add('cdk-option-active');\n    });\n  }\n\n  private setContainerPosition() {\n    if (this.poListboxContainerElement && this.poSearchInput) {\n      this.controlPosition.setElements(\n        this.poListboxContainerElement.nativeElement,\n        poSearchContainerOffset,\n        this.poSearchInput,\n        ['top', 'bottom'],\n        true\n      );\n\n      this.adjustContainerPosition();\n    }\n  }\n\n  private adjustContainerPosition() {\n    if (this.poListboxContainerElement && this.poSearchInput) {\n      this.controlPosition.adjustPosition(poSearchContainerPositionDefault);\n    }\n  }\n\n  controlListboxVisibility(toOpen: boolean) {\n    toOpen ? this.openListbox() : this.closeListbox();\n  }\n\n  private openListbox() {\n    this.listboxOpen = true;\n    this.changeDetector.detectChanges();\n    this.initializeListeners();\n    this.poSearchInput.nativeElement.focus();\n    this.setContainerPosition();\n  }\n\n  closeListbox() {\n    this.listboxOpen = false;\n    this.changeDetector.detectChanges();\n    this.removeListeners();\n  }\n\n  clickedOutsideInput(event: MouseEvent): void {\n    if (\n      this.listboxOpen &&\n      !this.poSearchInput.nativeElement.contains(event.target) &&\n      (!this.poListboxElement || !this.poListboxElement.nativeElement.contains(event.target))\n    ) {\n      this.controlListboxVisibility(false);\n    }\n  }\n\n  private initializeListeners() {\n    this.removeListeners();\n\n    this.clickoutListener = this.renderer.listen('document', 'click', (event: MouseEvent) => {\n      this.clickedOutsideInput(event);\n    });\n\n    this.eventResizeListener = this.renderer.listen('window', 'resize', () => {\n      setTimeout(() => this.adjustContainerPosition(), 250);\n    });\n\n    window.addEventListener('scroll', this.onScroll, true);\n  }\n\n  private removeListeners() {\n    if (this.clickoutListener) {\n      this.clickoutListener();\n    }\n\n    if (this.eventResizeListener) {\n      this.eventResizeListener();\n    }\n\n    window.removeEventListener('scroll', this.onScroll, true);\n  }\n\n  private onScroll = (): void => {\n    this.adjustContainerPosition();\n  };\n\n  getInputValue() {\n    return this.poSearchInput.nativeElement.value;\n  }\n}\n","<div class=\"po-search\" [class.po-search-disabled]=\"disabled\">\n  <div *ngIf=\"type === 'action'\" class=\"po-search-icon\">\n    <po-icon [p-icon]=\"icon ? icon : 'po-icon-search'\"></po-icon>\n  </div>\n\n  <input\n    #poSearchInput\n    class=\"po-search-input\"\n    type=\"text\"\n    [ariaLabel]=\"ariaLabel\"\n    [class.po-search-input-clean]=\"!!poSearchInput.value && !disabled\"\n    [class.po-search-input-trigger]=\"type === 'trigger'\"\n    [disabled]=\"disabled\"\n    [placeholder]=\"literals.search\"\n    (input)=\"\n      onSearchChange($event.target.value, false); onSearchChange($event.target.value, type === 'action' ? true : false)\n    \"\n    (keyup.enter)=\"\n      listboxOpen ? closeListbox() : onSearchChange($event.target.value, type === 'trigger' ? true : false, true);\n      closeListbox()\n    \"\n    (keydown)=\"onKeyDown($event)\"\n    (blur)=\"onBlur()\"\n  />\n\n  <div class=\"po-search-buttons\">\n    <button\n      *ngIf=\"!!poSearchInput.value && !disabled\"\n      class=\"po-search-button po-search-button-clean\"\n      type=\"button\"\n      [ariaLabel]=\"literals.clean\"\n      (click)=\"clearSearch()\"\n      (keydown.enter)=\"clearSearch()\"\n    >\n      <po-icon p-icon=\"po-icon-clear-content\"></po-icon>\n    </button>\n\n    <button\n      *ngIf=\"type === 'trigger'\"\n      class=\"po-search-button po-search-button-trigger\"\n      type=\"button\"\n      [ariaLabel]=\"literals.search\"\n      (click)=\"onSearchChange(poSearchInput.value, true, true)\"\n      (keydown.enter)=\"onSearchChange(poSearchInput.value, true, true)\"\n      [disabled]=\"disabled\"\n    >\n      <po-icon [p-icon]=\"icon ? icon : 'po-icon-search'\"> </po-icon>\n    </button>\n  </div>\n</div>\n\n<div #poListboxContainerElement class=\"po-search-listbox-container\" [hidden]=\"!listboxOpen\">\n  <po-listbox\n    #poListbox\n    #poListboxElement\n    p-type=\"option\"\n    [p-items]=\"listboxFilteredItems\"\n    (p-selectcombo-item)=\"onListboxClick($event, $event.event)\"\n    [p-visible]=\"listboxOpen\"\n    [p-filter-mode]=\"filterType\"\n    [p-should-mark-letter]=\"shouldMarkLetters\"\n    [p-filtering]=\"isFiltering\"\n    [p-search-value]=\"getInputValue()\"\n    (p-close)=\"onCloseListbox()\"\n  ></po-listbox>\n</div>\n"]}
|
|
@@ -6,6 +6,7 @@ import { PoLoadingModule } from '../po-loading';
|
|
|
6
6
|
import { PoSearchComponent } from './po-search.component';
|
|
7
7
|
import { FormsModule } from '@angular/forms';
|
|
8
8
|
import { PoAccordionModule } from '../po-accordion/po-accordion.module';
|
|
9
|
+
import { PoListBoxModule } from '../po-listbox';
|
|
9
10
|
import * as i0 from "@angular/core";
|
|
10
11
|
/**
|
|
11
12
|
* @description
|
|
@@ -15,15 +16,35 @@ import * as i0 from "@angular/core";
|
|
|
15
16
|
export class PoSearchModule {
|
|
16
17
|
static ɵfac = function PoSearchModule_Factory(t) { return new (t || PoSearchModule)(); };
|
|
17
18
|
static ɵmod = /*@__PURE__*/ i0.ɵɵdefineNgModule({ type: PoSearchModule });
|
|
18
|
-
static ɵinj = /*@__PURE__*/ i0.ɵɵdefineInjector({ imports: [CommonModule,
|
|
19
|
+
static ɵinj = /*@__PURE__*/ i0.ɵɵdefineInjector({ imports: [CommonModule,
|
|
20
|
+
PoCleanModule,
|
|
21
|
+
PoIconModule,
|
|
22
|
+
PoLoadingModule,
|
|
23
|
+
PoAccordionModule,
|
|
24
|
+
FormsModule,
|
|
25
|
+
PoListBoxModule] });
|
|
19
26
|
}
|
|
20
27
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoSearchModule, [{
|
|
21
28
|
type: NgModule,
|
|
22
29
|
args: [{
|
|
23
|
-
imports: [
|
|
30
|
+
imports: [
|
|
31
|
+
CommonModule,
|
|
32
|
+
PoCleanModule,
|
|
33
|
+
PoIconModule,
|
|
34
|
+
PoLoadingModule,
|
|
35
|
+
PoAccordionModule,
|
|
36
|
+
FormsModule,
|
|
37
|
+
PoListBoxModule
|
|
38
|
+
],
|
|
24
39
|
declarations: [PoSearchComponent],
|
|
25
40
|
exports: [PoSearchComponent]
|
|
26
41
|
}]
|
|
27
42
|
}], null, null); })();
|
|
28
|
-
(function () { (typeof ngJitMode === "undefined" || ngJitMode) && i0.ɵɵsetNgModuleScope(PoSearchModule, { declarations: [PoSearchComponent], imports: [CommonModule,
|
|
29
|
-
|
|
43
|
+
(function () { (typeof ngJitMode === "undefined" || ngJitMode) && i0.ɵɵsetNgModuleScope(PoSearchModule, { declarations: [PoSearchComponent], imports: [CommonModule,
|
|
44
|
+
PoCleanModule,
|
|
45
|
+
PoIconModule,
|
|
46
|
+
PoLoadingModule,
|
|
47
|
+
PoAccordionModule,
|
|
48
|
+
FormsModule,
|
|
49
|
+
PoListBoxModule], exports: [PoSearchComponent] }); })();
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8tc2VhcmNoLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL3NyYy9saWIvY29tcG9uZW50cy9wby1zZWFyY2gvcG8tc2VhcmNoLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQzVDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFDMUMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNoRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDeEUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFFaEQ7Ozs7R0FJRztBQWNILE1BQU0sT0FBTyxjQUFjO3dFQUFkLGNBQWM7NERBQWQsY0FBYztnRUFYdkIsWUFBWTtZQUNaLGFBQWE7WUFDYixZQUFZO1lBQ1osZUFBZTtZQUNmLGlCQUFpQjtZQUNqQixXQUFXO1lBQ1gsZUFBZTs7aUZBS04sY0FBYztjQWIxQixRQUFRO2VBQUM7Z0JBQ1IsT0FBTyxFQUFFO29CQUNQLFlBQVk7b0JBQ1osYUFBYTtvQkFDYixZQUFZO29CQUNaLGVBQWU7b0JBQ2YsaUJBQWlCO29CQUNqQixXQUFXO29CQUNYLGVBQWU7aUJBQ2hCO2dCQUNELFlBQVksRUFBRSxDQUFDLGlCQUFpQixDQUFDO2dCQUNqQyxPQUFPLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQzthQUM3Qjs7d0ZBQ1ksY0FBYyxtQkFIVixpQkFBaUIsYUFSOUIsWUFBWTtRQUNaLGFBQWE7UUFDYixZQUFZO1FBQ1osZUFBZTtRQUNmLGlCQUFpQjtRQUNqQixXQUFXO1FBQ1gsZUFBZSxhQUdQLGlCQUFpQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUG9DbGVhbk1vZHVsZSB9IGZyb20gJy4uL3BvLWZpZWxkJztcbmltcG9ydCB7IFBvSWNvbk1vZHVsZSB9IGZyb20gJy4uL3BvLWljb24nO1xuaW1wb3J0IHsgUG9Mb2FkaW5nTW9kdWxlIH0gZnJvbSAnLi4vcG8tbG9hZGluZyc7XG5pbXBvcnQgeyBQb1NlYXJjaENvbXBvbmVudCB9IGZyb20gJy4vcG8tc2VhcmNoLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IFBvQWNjb3JkaW9uTW9kdWxlIH0gZnJvbSAnLi4vcG8tYWNjb3JkaW9uL3BvLWFjY29yZGlvbi5tb2R1bGUnO1xuaW1wb3J0IHsgUG9MaXN0Qm94TW9kdWxlIH0gZnJvbSAnLi4vcG8tbGlzdGJveCc7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uXG4gKlxuICogTcOzZHVsbyBkbyBjb21wb25lbnRlIHBvLXNlYXJjaC5cbiAqL1xuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBQb0NsZWFuTW9kdWxlLFxuICAgIFBvSWNvbk1vZHVsZSxcbiAgICBQb0xvYWRpbmdNb2R1bGUsXG4gICAgUG9BY2NvcmRpb25Nb2R1bGUsXG4gICAgRm9ybXNNb2R1bGUsXG4gICAgUG9MaXN0Qm94TW9kdWxlXG4gIF0sXG4gIGRlY2xhcmF0aW9uczogW1BvU2VhcmNoQ29tcG9uZW50XSxcbiAgZXhwb3J0czogW1BvU2VhcmNoQ29tcG9uZW50XVxufSlcbmV4cG9ydCBjbGFzcyBQb1NlYXJjaE1vZHVsZSB7fVxuIl19
|