@po-ui/ng-components 14.4.0 → 14.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/components/po-button-group/po-button-group-base.component.mjs +2 -2
- package/esm2020/lib/components/po-field/po-combo/po-combo.component.mjs +6 -6
- package/esm2020/lib/components/po-field/po-datepicker/po-datepicker.component.mjs +5 -5
- package/esm2020/lib/components/po-field/po-datepicker-range/po-datepicker-range.component.mjs +7 -3
- package/esm2020/lib/components/po-field/po-decimal/po-decimal.component.mjs +5 -5
- package/esm2020/lib/components/po-field/po-email/po-email.component.mjs +9 -7
- package/esm2020/lib/components/po-field/po-input/po-input.component.mjs +9 -7
- package/esm2020/lib/components/po-field/po-login/po-login.component.mjs +12 -11
- package/esm2020/lib/components/po-field/po-lookup/po-lookup-modal/po-lookup-modal.component.mjs +3 -3
- package/esm2020/lib/components/po-field/po-lookup/po-lookup.component.mjs +6 -5
- package/esm2020/lib/components/po-field/po-multiselect/po-multiselect-base.component.mjs +31 -20
- package/esm2020/lib/components/po-field/po-multiselect/po-multiselect-dropdown/po-multiselect-dropdown.component.mjs +19 -13
- package/esm2020/lib/components/po-field/po-multiselect/po-multiselect-filter.interface.mjs +1 -1
- package/esm2020/lib/components/po-field/po-multiselect/po-multiselect-filter.service.mjs +2 -2
- package/esm2020/lib/components/po-field/po-multiselect/po-multiselect-search/po-multiselect-search.component.mjs +7 -4
- package/esm2020/lib/components/po-field/po-multiselect/po-multiselect.component.mjs +24 -17
- package/esm2020/lib/components/po-field/po-number/po-number.component.mjs +5 -5
- package/esm2020/lib/components/po-field/po-password/po-password.component.mjs +14 -13
- package/esm2020/lib/components/po-field/po-radio/po-radio-size.enum.mjs +10 -3
- package/esm2020/lib/components/po-field/po-radio/po-radio.component.mjs +98 -34
- package/esm2020/lib/components/po-field/po-radio-group/po-radio-group-base.component.mjs +16 -2
- package/esm2020/lib/components/po-field/po-radio-group/po-radio-group.component.mjs +18 -25
- package/esm2020/lib/components/po-field/po-select/po-select.component.mjs +38 -250
- package/esm2020/lib/components/po-field/po-textarea/po-textarea-base.component.mjs +11 -1
- package/esm2020/lib/components/po-field/po-textarea/po-textarea.component.mjs +6 -7
- package/esm2020/lib/components/po-field/po-url/po-url.component.mjs +9 -7
- package/esm2020/lib/components/po-page/po-page-list/po-page-list.component.mjs +3 -3
- package/esm2020/lib/components/po-table/po-table-column-manager/po-table-column-manager.component.mjs +26 -73
- package/esm2020/lib/components/po-table/po-table-detail/po-table-detail.component.mjs +27 -8
- package/esm2020/lib/components/po-table/po-table-list-manager/po-table-list-manager.component.mjs +111 -0
- package/esm2020/lib/components/po-table/po-table.module.mjs +4 -1
- package/esm2020/lib/components/po-tag/po-tag-base.component.mjs +11 -3
- package/esm2020/lib/components/po-tag/po-tag.component.mjs +16 -9
- package/esm2020/lib/components/po-tree-view/po-tree-view-base.component.mjs +6 -4
- package/fesm2015/po-ui-ng-components.mjs +889 -984
- package/fesm2015/po-ui-ng-components.mjs.map +1 -1
- package/fesm2020/po-ui-ng-components.mjs +871 -962
- package/fesm2020/po-ui-ng-components.mjs.map +1 -1
- package/lib/components/po-button-group/po-button-group-base.component.d.ts +1 -1
- package/lib/components/po-field/po-multiselect/po-multiselect-base.component.d.ts +26 -15
- package/lib/components/po-field/po-multiselect/po-multiselect-dropdown/po-multiselect-dropdown.component.d.ts +5 -3
- package/lib/components/po-field/po-multiselect/po-multiselect-filter.interface.d.ts +2 -2
- package/lib/components/po-field/po-multiselect/po-multiselect-filter.service.d.ts +2 -2
- package/lib/components/po-field/po-multiselect/po-multiselect-search/po-multiselect-search.component.d.ts +2 -1
- package/lib/components/po-field/po-multiselect/po-multiselect.component.d.ts +7 -1
- package/lib/components/po-field/po-radio/po-radio-size.enum.d.ts +9 -2
- package/lib/components/po-field/po-radio/po-radio.component.d.ts +27 -10
- package/lib/components/po-field/po-radio-group/po-radio-group-base.component.d.ts +21 -1
- package/lib/components/po-field/po-select/po-select.component.d.ts +1 -32
- package/lib/components/po-field/po-textarea/po-textarea-base.component.d.ts +10 -0
- package/lib/components/po-modal/po-modal.component.d.ts +1 -1
- package/lib/components/po-table/po-table-column-manager/po-table-column-manager.component.d.ts +4 -12
- package/lib/components/po-table/po-table-detail/po-table-detail.component.d.ts +1 -0
- package/lib/components/po-table/po-table-list-manager/po-table-list-manager.component.d.ts +35 -0
- package/lib/components/po-table/po-table.module.d.ts +25 -24
- package/lib/components/po-tag/po-tag-base.component.d.ts +8 -2
- package/package.json +4 -4
- package/po-ui-ng-components-14.5.0.tgz +0 -0
- package/schematics/ng-add/index.js +1 -1
- package/schematics/ng-update/v14/index.js +1 -1
- package/schematics/ng-update/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/esm2020/lib/components/po-field/po-radio/po-radio-base.component.mjs +0 -104
- package/lib/components/po-field/po-radio/po-radio-base.component.d.ts +0 -58
- package/po-ui-ng-components-14.4.0.tgz +0 -0
|
@@ -1,79 +1,37 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
|
-
import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, forwardRef,
|
|
2
|
+
import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, forwardRef, Input, Output, ViewChild } from '@angular/core';
|
|
3
3
|
import { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
4
|
-
import {
|
|
5
|
-
import { PoKeyCodeEnum } from './../../../enums/po-key-code.enum';
|
|
6
|
-
import { PoControlPositionService } from './../../../services/po-control-position/po-control-position.service';
|
|
4
|
+
import { removeDuplicatedOptions, removeDuplicatedOptionsWithFieldValue, removeUndefinedAndNullOptions, removeUndefinedAndNullOptionsWithFieldValue, validValue } from '../../../utils/util';
|
|
7
5
|
import { InputBoolean } from '../../../decorators';
|
|
8
6
|
import { PoFieldValidateModel } from '../po-field-validate.model';
|
|
9
7
|
import * as i0 from "@angular/core";
|
|
10
|
-
import * as i1 from "
|
|
11
|
-
import * as i2 from "@angular/
|
|
12
|
-
import * as i3 from "
|
|
13
|
-
import * as i4 from "../po-field-container/po-field-container
|
|
14
|
-
|
|
15
|
-
const _c0 = ["contentList"];
|
|
16
|
-
const _c1 = ["icon"];
|
|
17
|
-
const _c2 = ["select"];
|
|
18
|
-
const _c3 = ["selectButton"];
|
|
19
|
-
function PoSelectComponent_option_3_Template(rf, ctx) { if (rf & 1) {
|
|
20
|
-
i0.ɵɵelement(0, "option", 14);
|
|
21
|
-
} }
|
|
8
|
+
import * as i1 from "@angular/common";
|
|
9
|
+
import * as i2 from "@angular/forms";
|
|
10
|
+
import * as i3 from "../po-field-container/po-field-container-bottom/po-field-container-bottom.component";
|
|
11
|
+
import * as i4 from "../po-field-container/po-field-container.component";
|
|
12
|
+
const _c0 = ["select"];
|
|
22
13
|
function PoSelectComponent_option_4_Template(rf, ctx) { if (rf & 1) {
|
|
23
|
-
|
|
24
|
-
i0.ɵɵelementStart(0, "option", 15);
|
|
25
|
-
i0.ɵɵlistener("click", function PoSelectComponent_option_4_Template_option_click_0_listener() { const restoredCtx = i0.ɵɵrestoreView(_r9); const option_r7 = restoredCtx.$implicit; const ctx_r8 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r8.onOptionClick(option_r7)); });
|
|
14
|
+
i0.ɵɵelementStart(0, "option", 6);
|
|
26
15
|
i0.ɵɵtext(1);
|
|
27
16
|
i0.ɵɵelementEnd();
|
|
28
17
|
} if (rf & 2) {
|
|
29
|
-
const
|
|
30
|
-
|
|
31
|
-
i0.ɵɵproperty("disabled",
|
|
18
|
+
const ctx_r1 = i0.ɵɵnextContext();
|
|
19
|
+
let tmp_3_0;
|
|
20
|
+
i0.ɵɵproperty("disabled", !!ctx_r1.placeholder)("hidden", !ctx_r1.selectedValue && !ctx_r1.placeholder)("selected", !ctx_r1.selectedValue)("value", (tmp_3_0 = ctx_r1.placeholder) !== null && tmp_3_0 !== undefined ? tmp_3_0 : "");
|
|
32
21
|
i0.ɵɵadvance(1);
|
|
33
|
-
i0.ɵɵtextInterpolate1(" ",
|
|
22
|
+
i0.ɵɵtextInterpolate1(" ", ctx_r1.placeholder, " ");
|
|
34
23
|
} }
|
|
35
|
-
function
|
|
36
|
-
i0.ɵɵ
|
|
37
|
-
} }
|
|
38
|
-
function PoSelectComponent_li_15_ng_template_3_Template(rf, ctx) { if (rf & 1) {
|
|
39
|
-
i0.ɵɵelementStart(0, "span");
|
|
24
|
+
function PoSelectComponent_option_5_Template(rf, ctx) { if (rf & 1) {
|
|
25
|
+
i0.ɵɵelementStart(0, "option", 7);
|
|
40
26
|
i0.ɵɵtext(1);
|
|
41
27
|
i0.ɵɵelementEnd();
|
|
42
28
|
} if (rf & 2) {
|
|
43
|
-
const
|
|
44
|
-
const
|
|
29
|
+
const option_r3 = ctx.$implicit;
|
|
30
|
+
const ctx_r2 = i0.ɵɵnextContext();
|
|
31
|
+
i0.ɵɵproperty("disabled", ctx_r2.readonly)("value", option_r3 == null ? null : option_r3[ctx_r2.fieldValue]);
|
|
45
32
|
i0.ɵɵadvance(1);
|
|
46
|
-
i0.ɵɵ
|
|
33
|
+
i0.ɵɵtextInterpolate1(" ", option_r3 == null ? null : option_r3[ctx_r2.fieldLabel], " ");
|
|
47
34
|
} }
|
|
48
|
-
function PoSelectComponent_li_15_ng_template_5_Template(rf, ctx) { }
|
|
49
|
-
const _c4 = function (a0) { return { $implicit: a0 }; };
|
|
50
|
-
function PoSelectComponent_li_15_Template(rf, ctx) { if (rf & 1) {
|
|
51
|
-
const _r18 = i0.ɵɵgetCurrentView();
|
|
52
|
-
i0.ɵɵelementStart(0, "li", 16);
|
|
53
|
-
i0.ɵɵlistener("click", function PoSelectComponent_li_15_Template_li_click_0_listener() { const restoredCtx = i0.ɵɵrestoreView(_r18); const option_r10 = restoredCtx.$implicit; const ctx_r17 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r17.onOptionClick(option_r10)); });
|
|
54
|
-
i0.ɵɵelementStart(1, "div", 17);
|
|
55
|
-
i0.ɵɵtemplate(2, PoSelectComponent_li_15_ng_container_2_Template, 1, 0, "ng-container", 18);
|
|
56
|
-
i0.ɵɵtemplate(3, PoSelectComponent_li_15_ng_template_3_Template, 2, 1, "ng-template", null, 19, i0.ɵɵtemplateRefExtractor);
|
|
57
|
-
i0.ɵɵtemplate(5, PoSelectComponent_li_15_ng_template_5_Template, 0, 0, "ng-template", 20, 21, i0.ɵɵtemplateRefExtractor);
|
|
58
|
-
i0.ɵɵelementEnd()();
|
|
59
|
-
} if (rf & 2) {
|
|
60
|
-
const option_r10 = ctx.$implicit;
|
|
61
|
-
const _r12 = i0.ɵɵreference(4);
|
|
62
|
-
const _r14 = i0.ɵɵreference(6);
|
|
63
|
-
const ctx_r6 = i0.ɵɵnextContext();
|
|
64
|
-
i0.ɵɵclassProp("po-select-item-selected", ctx_r6.selectedValue === (option_r10 == null ? null : option_r10[ctx_r6.fieldLabel]));
|
|
65
|
-
i0.ɵɵproperty("value", option_r10 == null ? null : option_r10[ctx_r6.fieldValue]);
|
|
66
|
-
i0.ɵɵadvance(2);
|
|
67
|
-
i0.ɵɵproperty("ngIf", ctx_r6.selectOptionTemplate)("ngIfThen", _r14)("ngIfElse", _r12);
|
|
68
|
-
i0.ɵɵadvance(3);
|
|
69
|
-
i0.ɵɵproperty("ngTemplateOutlet", ctx_r6.selectOptionTemplate == null ? null : ctx_r6.selectOptionTemplate.templateRef)("ngTemplateOutletContext", i0.ɵɵpureFunction1(8, _c4, option_r10));
|
|
70
|
-
} }
|
|
71
|
-
const _c5 = function (a0, a1) { return { "po-select-mobile": a0, "po-invisible": a1 }; };
|
|
72
|
-
const _c6 = function (a0, a1) { return { "po-select-button-disabled": a0, "po-select-button-readonly": a1 }; };
|
|
73
|
-
const _c7 = function (a0, a1) { return { "po-field-icon-disabled": a0, "po-field-icon-readonly": a1 }; };
|
|
74
|
-
const _c8 = function (a0) { return { "po-invisible": a0 }; };
|
|
75
|
-
const poSelectContentOffset = 8;
|
|
76
|
-
const poSelectContentPositionDefault = 'bottom';
|
|
77
35
|
const PO_SELECT_FIELD_LABEL_DEFAULT = 'label';
|
|
78
36
|
const PO_SELECT_FIELD_VALUE_DEFAULT = 'value';
|
|
79
37
|
/**
|
|
@@ -120,12 +78,10 @@ const PO_SELECT_FIELD_VALUE_DEFAULT = 'value';
|
|
|
120
78
|
*/
|
|
121
79
|
export class PoSelectComponent extends PoFieldValidateModel {
|
|
122
80
|
/* istanbul ignore next */
|
|
123
|
-
constructor(
|
|
81
|
+
constructor(changeDetector, differs, renderer) {
|
|
124
82
|
super();
|
|
125
|
-
this.element = element;
|
|
126
83
|
this.changeDetector = changeDetector;
|
|
127
84
|
this.renderer = renderer;
|
|
128
|
-
this.controlPosition = controlPosition;
|
|
129
85
|
/**
|
|
130
86
|
* @optional
|
|
131
87
|
*
|
|
@@ -151,14 +107,8 @@ export class PoSelectComponent extends PoFieldValidateModel {
|
|
|
151
107
|
* @default `false`
|
|
152
108
|
*/
|
|
153
109
|
this.readonly = false;
|
|
154
|
-
this.isMobile = isMobile();
|
|
155
|
-
this.open = false;
|
|
156
|
-
this.selectIcon = 'po-icon-arrow-down';
|
|
157
110
|
this._fieldLabel = PO_SELECT_FIELD_LABEL_DEFAULT;
|
|
158
111
|
this._fieldValue = PO_SELECT_FIELD_VALUE_DEFAULT;
|
|
159
|
-
this.onScroll = () => {
|
|
160
|
-
this.controlPosition.adjustPosition(poSelectContentPositionDefault);
|
|
161
|
-
};
|
|
162
112
|
this.differ = differs.find([]).create(null);
|
|
163
113
|
}
|
|
164
114
|
/**
|
|
@@ -227,41 +177,10 @@ export class PoSelectComponent extends PoFieldValidateModel {
|
|
|
227
177
|
get fieldValue() {
|
|
228
178
|
return this._fieldValue;
|
|
229
179
|
}
|
|
230
|
-
get isInvisibleSelectNative() {
|
|
231
|
-
return this.readonly && this.isMobile;
|
|
232
|
-
}
|
|
233
|
-
onKeydown($event) {
|
|
234
|
-
const charCode = $event.which || $event.keyCode;
|
|
235
|
-
// Tratamentos para quando o readonly for ativado.
|
|
236
|
-
if (this.readonly) {
|
|
237
|
-
// deve matar o evento do teclado devido a alterar o valor do model mesmo com os options fechados
|
|
238
|
-
if (charCode !== PoKeyCodeEnum.tab) {
|
|
239
|
-
this.disableDefaultEventAndToggleButton();
|
|
240
|
-
$event.preventDefault();
|
|
241
|
-
}
|
|
242
|
-
return;
|
|
243
|
-
}
|
|
244
|
-
// Seleciona os itens com as teclas "up" e "down"
|
|
245
|
-
if ((!this.open || $event.altKey) && (charCode === PoKeyCodeEnum.arrowDown || charCode === PoKeyCodeEnum.arrowUp)) {
|
|
246
|
-
this.disableDefaultEventAndToggleButton();
|
|
247
|
-
}
|
|
248
|
-
// Abre o po-select com as teclas "enter" e "espaço"
|
|
249
|
-
if (charCode === PoKeyCodeEnum.enter || charCode === PoKeyCodeEnum.space) {
|
|
250
|
-
this.disableDefaultEventAndToggleButton();
|
|
251
|
-
}
|
|
252
|
-
// Fecha o po-select com a tecla "tab"
|
|
253
|
-
if (this.open && charCode === PoKeyCodeEnum.tab) {
|
|
254
|
-
$event.preventDefault();
|
|
255
|
-
this.toggleButton();
|
|
256
|
-
}
|
|
257
|
-
}
|
|
258
180
|
ngDoCheck() {
|
|
259
181
|
const change = this.differ.diff(this.options);
|
|
260
182
|
if (change) {
|
|
261
|
-
|
|
262
|
-
removeUndefinedAndNullOptions(this.options);
|
|
263
|
-
removeDuplicatedOptionsWithFieldValue(this.options, this.fieldValue);
|
|
264
|
-
removeUndefinedAndNullOptionsWithFieldValue(this.options, this.fieldValue);
|
|
183
|
+
this.validateOptions(this.options);
|
|
265
184
|
}
|
|
266
185
|
}
|
|
267
186
|
/**
|
|
@@ -286,28 +205,15 @@ export class PoSelectComponent extends PoFieldValidateModel {
|
|
|
286
205
|
this.selectElement.nativeElement.focus();
|
|
287
206
|
}
|
|
288
207
|
}
|
|
289
|
-
hideDropDown() {
|
|
290
|
-
this.selectIcon = 'po-icon-arrow-down';
|
|
291
|
-
this.selector('.po-select-container').classList.remove('po-select-show');
|
|
292
|
-
this.open = false;
|
|
293
|
-
this.changeDetector.markForCheck();
|
|
294
|
-
this.selectElement.nativeElement.focus();
|
|
295
|
-
this.removeListeners();
|
|
296
|
-
}
|
|
297
208
|
onBlur() {
|
|
298
209
|
this.onModelTouched?.();
|
|
299
210
|
}
|
|
300
|
-
onOptionClick(option) {
|
|
301
|
-
this.updateValues(option);
|
|
302
|
-
this.toggleButton();
|
|
303
|
-
}
|
|
304
211
|
// Altera o valor ao selecionar um item.
|
|
305
212
|
onSelectChange(value) {
|
|
306
213
|
if (value && this.options && this.options.length) {
|
|
307
214
|
const optionFound = this.findOptionValue(value);
|
|
308
215
|
if (optionFound) {
|
|
309
216
|
this.updateValues(optionFound);
|
|
310
|
-
this.setScrollPosition(optionFound.value);
|
|
311
217
|
}
|
|
312
218
|
}
|
|
313
219
|
}
|
|
@@ -316,16 +222,6 @@ export class PoSelectComponent extends PoFieldValidateModel {
|
|
|
316
222
|
this.onSelectChange(this.modelValue);
|
|
317
223
|
}
|
|
318
224
|
}
|
|
319
|
-
scrollValue(index, clientHeight) {
|
|
320
|
-
const heightScrollValue = index * this.getSelectItemHeight();
|
|
321
|
-
return (this.scrollPosition = heightScrollValue > clientHeight ? heightScrollValue : 0);
|
|
322
|
-
}
|
|
323
|
-
selector(query) {
|
|
324
|
-
return this.element.nativeElement.querySelector(query);
|
|
325
|
-
}
|
|
326
|
-
toggleButton() {
|
|
327
|
-
this.open ? this.hideDropDown() : this.showDropdown();
|
|
328
|
-
}
|
|
329
225
|
// Atualiza valores
|
|
330
226
|
updateValues(option) {
|
|
331
227
|
if (this.selectedValue !== option[this.fieldValue]) {
|
|
@@ -336,13 +232,6 @@ export class PoSelectComponent extends PoFieldValidateModel {
|
|
|
336
232
|
this.emitChange(option[this.fieldValue]);
|
|
337
233
|
}
|
|
338
234
|
}
|
|
339
|
-
// Esconde Content do Select quando for clicado fora
|
|
340
|
-
wasClickedOnToggle(event) {
|
|
341
|
-
if (!this.selectButtonElement.nativeElement.contains(event.target) &&
|
|
342
|
-
!this.iconElement.nativeElement.contains(event.target)) {
|
|
343
|
-
this.hideDropDown();
|
|
344
|
-
}
|
|
345
|
-
}
|
|
346
235
|
// Recebe as alterações do model
|
|
347
236
|
onWriteValue(value) {
|
|
348
237
|
const optionFound = this.findOptionValue(value);
|
|
@@ -350,7 +239,6 @@ export class PoSelectComponent extends PoFieldValidateModel {
|
|
|
350
239
|
this.selectElement.nativeElement.value = optionFound.value;
|
|
351
240
|
this.selectedValue = optionFound[this.fieldValue];
|
|
352
241
|
this.displayValue = optionFound[this.fieldLabel];
|
|
353
|
-
this.setScrollPosition(optionFound[this.fieldValue]);
|
|
354
242
|
}
|
|
355
243
|
else if (validValue(this.selectedValue)) {
|
|
356
244
|
this.selectElement.nativeElement.value = undefined;
|
|
@@ -373,66 +261,9 @@ export class PoSelectComponent extends PoFieldValidateModel {
|
|
|
373
261
|
}
|
|
374
262
|
return value === inputValue;
|
|
375
263
|
}
|
|
376
|
-
// Método necessário para bloquear o evento default do select nativo.
|
|
377
|
-
// Ao utilizar event.preventDefault(), nos navegadores Firefox e IE o mesmo não cancela o evento.
|
|
378
|
-
disableDefaultEventAndToggleButton() {
|
|
379
|
-
this.selectElement.nativeElement.style.display = 'none';
|
|
380
|
-
setTimeout(() => {
|
|
381
|
-
this.selectElement.nativeElement.style.display = 'block';
|
|
382
|
-
this.toggleButton();
|
|
383
|
-
});
|
|
384
|
-
}
|
|
385
264
|
findOptionValue(value) {
|
|
386
265
|
return this.options.find(option => this.isEqual(option.value, value));
|
|
387
266
|
}
|
|
388
|
-
getSelectItemHeight() {
|
|
389
|
-
const selectItem = this.selector('div.po-select-item');
|
|
390
|
-
return selectItem && selectItem.clientHeight;
|
|
391
|
-
}
|
|
392
|
-
initializeListeners() {
|
|
393
|
-
this.clickoutListener = this.renderer.listen('document', 'click', (event) => {
|
|
394
|
-
this.wasClickedOnToggle(event);
|
|
395
|
-
});
|
|
396
|
-
this.eventResizeListener = this.renderer.listen('window', 'resize', () => {
|
|
397
|
-
this.hideDropDown();
|
|
398
|
-
});
|
|
399
|
-
window.addEventListener('scroll', this.onScroll, true);
|
|
400
|
-
}
|
|
401
|
-
removeListeners() {
|
|
402
|
-
if (this.clickoutListener) {
|
|
403
|
-
this.clickoutListener();
|
|
404
|
-
}
|
|
405
|
-
this.eventResizeListener();
|
|
406
|
-
window.removeEventListener('scroll', this.onScroll, true);
|
|
407
|
-
}
|
|
408
|
-
setPositionDropdown() {
|
|
409
|
-
this.controlPosition.setElements(this.contentList.nativeElement, poSelectContentOffset, this.selectButtonElement, ['top', 'bottom'], true);
|
|
410
|
-
this.controlPosition.adjustPosition(poSelectContentPositionDefault);
|
|
411
|
-
}
|
|
412
|
-
setScrollPosition(value) {
|
|
413
|
-
const ulDropdpwn = this.element.nativeElement.querySelector('ul.po-select-content');
|
|
414
|
-
if (value && this.options && this.options.length) {
|
|
415
|
-
const optionFound = this.findOptionValue(value);
|
|
416
|
-
if (optionFound) {
|
|
417
|
-
const index = this.options.indexOf(optionFound);
|
|
418
|
-
ulDropdpwn.scrollTop = this.scrollValue(index, ulDropdpwn.clientHeight);
|
|
419
|
-
}
|
|
420
|
-
}
|
|
421
|
-
}
|
|
422
|
-
showDropdown() {
|
|
423
|
-
if (!this.readonly) {
|
|
424
|
-
this.selectElement.nativeElement.focus();
|
|
425
|
-
this.selectIcon = 'po-icon-arrow-up';
|
|
426
|
-
this.selector('.po-select-container').classList.add('po-select-show');
|
|
427
|
-
this.open = true;
|
|
428
|
-
this.changeDetector.markForCheck();
|
|
429
|
-
this.setPositionDropdown();
|
|
430
|
-
this.initializeListeners();
|
|
431
|
-
if (this.options && this.options.length) {
|
|
432
|
-
this.setScrollPosition(this.selectedValue);
|
|
433
|
-
}
|
|
434
|
-
}
|
|
435
|
-
}
|
|
436
267
|
validateOptions(options) {
|
|
437
268
|
removeDuplicatedOptions(options);
|
|
438
269
|
removeUndefinedAndNullOptions(options);
|
|
@@ -440,20 +271,12 @@ export class PoSelectComponent extends PoFieldValidateModel {
|
|
|
440
271
|
removeUndefinedAndNullOptionsWithFieldValue(options, this.fieldValue);
|
|
441
272
|
}
|
|
442
273
|
}
|
|
443
|
-
PoSelectComponent.ɵfac = function PoSelectComponent_Factory(t) { return new (t || PoSelectComponent)(i0.ɵɵdirectiveInject(i0.
|
|
274
|
+
PoSelectComponent.ɵfac = function PoSelectComponent_Factory(t) { return new (t || PoSelectComponent)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i0.IterableDiffers), i0.ɵɵdirectiveInject(i0.Renderer2)); };
|
|
444
275
|
PoSelectComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoSelectComponent, selectors: [["po-select"]], viewQuery: function PoSelectComponent_Query(rf, ctx) { if (rf & 1) {
|
|
445
276
|
i0.ɵɵviewQuery(_c0, 7, ElementRef);
|
|
446
|
-
i0.ɵɵviewQuery(_c1, 7, ElementRef);
|
|
447
|
-
i0.ɵɵviewQuery(_c2, 7, ElementRef);
|
|
448
|
-
i0.ɵɵviewQuery(_c3, 7, ElementRef);
|
|
449
277
|
} if (rf & 2) {
|
|
450
278
|
let _t;
|
|
451
|
-
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.contentList = _t.first);
|
|
452
|
-
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.iconElement = _t.first);
|
|
453
279
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.selectElement = _t.first);
|
|
454
|
-
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.selectButtonElement = _t.first);
|
|
455
|
-
} }, hostBindings: function PoSelectComponent_HostBindings(rf, ctx) { if (rf & 1) {
|
|
456
|
-
i0.ɵɵlistener("keydown", function PoSelectComponent_keydown_HostBindingHandler($event) { return ctx.onKeydown($event); });
|
|
457
280
|
} }, inputs: { readonly: ["p-readonly", "readonly"], placeholder: ["p-placeholder", "placeholder"], options: ["p-options", "options"], fieldLabel: ["p-field-label", "fieldLabel"], fieldValue: ["p-field-value", "fieldValue"] }, outputs: { ngModelChange: "ngModelChange" }, features: [i0.ɵɵProvidersFeature([
|
|
458
281
|
{
|
|
459
282
|
provide: NG_VALUE_ACCESSOR,
|
|
@@ -464,48 +287,26 @@ PoSelectComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoSelectC
|
|
|
464
287
|
provide: NG_VALIDATORS,
|
|
465
288
|
useExisting: forwardRef(() => PoSelectComponent),
|
|
466
289
|
multi: true
|
|
467
|
-
}
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
i0.ɵɵ
|
|
471
|
-
i0.ɵɵ
|
|
472
|
-
i0.ɵɵtemplate(
|
|
473
|
-
i0.ɵɵtemplate(4, PoSelectComponent_option_4_Template, 2, 3, "option", 4);
|
|
474
|
-
i0.ɵɵelementEnd();
|
|
475
|
-
i0.ɵɵelementStart(5, "div", 5)(6, "div", 6, 7);
|
|
476
|
-
i0.ɵɵlistener("click", function PoSelectComponent_Template_div_click_6_listener() { return ctx.toggleButton(); });
|
|
477
|
-
i0.ɵɵelementStart(8, "span");
|
|
478
|
-
i0.ɵɵtext(9);
|
|
479
|
-
i0.ɵɵelementEnd();
|
|
480
|
-
i0.ɵɵelementStart(10, "div", 8);
|
|
481
|
-
i0.ɵɵelement(11, "span", 9, 10);
|
|
482
|
-
i0.ɵɵelementEnd()();
|
|
483
|
-
i0.ɵɵelementStart(13, "ul", 11, 12);
|
|
484
|
-
i0.ɵɵtemplate(15, PoSelectComponent_li_15_Template, 7, 10, "li", 13);
|
|
290
|
+
}
|
|
291
|
+
]), i0.ɵɵInheritDefinitionFeature], decls: 7, vars: 11, consts: [[3, "p-label", "p-help", "p-optional"], [1, "po-field-container-content"], [1, "po-select", 3, "disabled", "required", "blur", "change"], ["select", ""], [3, "disabled", "hidden", "selected", "value", 4, "ngIf"], [3, "disabled", "value", 4, "ngFor", "ngForOf"], [3, "disabled", "hidden", "selected", "value"], [3, "disabled", "value"]], template: function PoSelectComponent_Template(rf, ctx) { if (rf & 1) {
|
|
292
|
+
i0.ɵɵelementStart(0, "po-field-container", 0)(1, "div", 1)(2, "select", 2, 3);
|
|
293
|
+
i0.ɵɵlistener("blur", function PoSelectComponent_Template_select_blur_2_listener() { return ctx.onBlur(); })("change", function PoSelectComponent_Template_select_change_2_listener($event) { return ctx.onSelectChange($event.target.value); });
|
|
294
|
+
i0.ɵɵtemplate(4, PoSelectComponent_option_4_Template, 2, 5, "option", 4);
|
|
295
|
+
i0.ɵɵtemplate(5, PoSelectComponent_option_5_Template, 2, 3, "option", 5);
|
|
485
296
|
i0.ɵɵelementEnd()();
|
|
486
|
-
i0.ɵɵelement(
|
|
297
|
+
i0.ɵɵelement(6, "po-field-container-bottom");
|
|
487
298
|
i0.ɵɵelementEnd();
|
|
488
299
|
} if (rf & 2) {
|
|
489
300
|
i0.ɵɵproperty("p-label", ctx.label)("p-help", ctx.help)("p-optional", !ctx.required && ctx.optional);
|
|
490
|
-
i0.ɵɵadvance(1);
|
|
491
|
-
i0.ɵɵproperty("disabled", ctx.disabled)("ngClass", i0.ɵɵpureFunction2(17, _c5, ctx.isMobile, ctx.isInvisibleSelectNative))("required", ctx.required);
|
|
492
|
-
i0.ɵɵattribute("name", ctx.name);
|
|
493
|
-
i0.ɵɵadvance(2);
|
|
494
|
-
i0.ɵɵproperty("ngIf", ctx.isMobile);
|
|
495
|
-
i0.ɵɵadvance(1);
|
|
496
|
-
i0.ɵɵproperty("ngForOf", ctx.options);
|
|
497
|
-
i0.ɵɵadvance(2);
|
|
498
|
-
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction2(20, _c6, ctx.disabled, ctx.readonly));
|
|
499
|
-
i0.ɵɵadvance(3);
|
|
500
|
-
i0.ɵɵtextInterpolate(ctx.displayValue || ctx.placeholder);
|
|
501
301
|
i0.ɵɵadvance(2);
|
|
502
|
-
i0.ɵɵ
|
|
503
|
-
i0.ɵɵproperty("
|
|
504
|
-
i0.ɵɵ
|
|
505
|
-
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(26, _c8, ctx.isMobile));
|
|
302
|
+
i0.ɵɵclassProp("po-select-placeholder", !ctx.selectedValue && !!ctx.placeholder);
|
|
303
|
+
i0.ɵɵproperty("disabled", ctx.disabled)("required", ctx.required);
|
|
304
|
+
i0.ɵɵattribute("aria-label", ctx.label)("name", ctx.name);
|
|
506
305
|
i0.ɵɵadvance(2);
|
|
306
|
+
i0.ɵɵproperty("ngIf", !ctx.selectedValue || !!ctx.placeholder);
|
|
307
|
+
i0.ɵɵadvance(1);
|
|
507
308
|
i0.ɵɵproperty("ngForOf", ctx.options);
|
|
508
|
-
} }, dependencies: [
|
|
309
|
+
} }, dependencies: [i1.NgForOf, i1.NgIf, i2.NgSelectOption, i2.ɵNgSelectMultipleOption, i3.PoFieldContainerBottomComponent, i4.PoFieldContainerComponent], encapsulation: 2, changeDetection: 0 });
|
|
509
310
|
__decorate([
|
|
510
311
|
InputBoolean()
|
|
511
312
|
], PoSelectComponent.prototype, "readonly", void 0);
|
|
@@ -521,21 +322,11 @@ __decorate([
|
|
|
521
322
|
provide: NG_VALIDATORS,
|
|
522
323
|
useExisting: forwardRef(() => PoSelectComponent),
|
|
523
324
|
multi: true
|
|
524
|
-
}
|
|
525
|
-
|
|
526
|
-
|
|
527
|
-
}], function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i0.IterableDiffers }, { type: i0.Renderer2 }, { type: i1.PoControlPositionService }]; }, { contentList: [{
|
|
528
|
-
type: ViewChild,
|
|
529
|
-
args: ['contentList', { read: ElementRef, static: true }]
|
|
530
|
-
}], iconElement: [{
|
|
531
|
-
type: ViewChild,
|
|
532
|
-
args: ['icon', { read: ElementRef, static: true }]
|
|
533
|
-
}], selectElement: [{
|
|
325
|
+
}
|
|
326
|
+
], template: "<po-field-container [p-label]=\"label\" [p-help]=\"help\" [p-optional]=\"!required && optional\">\n <div class=\"po-field-container-content\">\n <select\n #select\n class=\"po-select\"\n [attr.aria-label]=\"label\"\n [attr.name]=\"name\"\n [class.po-select-placeholder]=\"!selectedValue && !!placeholder\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n (blur)=\"onBlur()\"\n (change)=\"onSelectChange($event.target.value)\"\n >\n <option\n *ngIf=\"!selectedValue || !!placeholder\"\n [disabled]=\"!!placeholder\"\n [hidden]=\"!selectedValue && !placeholder\"\n [selected]=\"!selectedValue\"\n [value]=\"placeholder ?? ''\"\n >\n {{ placeholder }}\n </option>\n <option *ngFor=\"let option of options\" [disabled]=\"readonly\" [value]=\"option?.[this.fieldValue]\">\n {{ option?.[this.fieldLabel] }}\n </option>\n </select>\n </div>\n\n <po-field-container-bottom></po-field-container-bottom>\n</po-field-container>\n" }]
|
|
327
|
+
}], function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.IterableDiffers }, { type: i0.Renderer2 }]; }, { selectElement: [{
|
|
534
328
|
type: ViewChild,
|
|
535
329
|
args: ['select', { read: ElementRef, static: true }]
|
|
536
|
-
}], selectButtonElement: [{
|
|
537
|
-
type: ViewChild,
|
|
538
|
-
args: ['selectButton', { read: ElementRef, static: true }]
|
|
539
330
|
}], ngModelChange: [{
|
|
540
331
|
type: Output,
|
|
541
332
|
args: ['ngModelChange']
|
|
@@ -554,8 +345,5 @@ __decorate([
|
|
|
554
345
|
}], fieldValue: [{
|
|
555
346
|
type: Input,
|
|
556
347
|
args: ['p-field-value']
|
|
557
|
-
}], onKeydown: [{
|
|
558
|
-
type: HostListener,
|
|
559
|
-
args: ['keydown', ['$event']]
|
|
560
348
|
}] }); })();
|
|
561
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-select.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-select/po-select.component.ts","../../../../../../../projects/ui/src/lib/components/po-field/po-select/po-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DoCheck,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  HostListener,\n  Input,\n  IterableDiffers,\n  Output,\n  Renderer2,\n  ViewChild\n} from '@angular/core';\nimport { AbstractControl, NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport {\n  isMobile,\n  removeDuplicatedOptions,\n  removeDuplicatedOptionsWithFieldValue,\n  removeUndefinedAndNullOptions,\n  removeUndefinedAndNullOptionsWithFieldValue,\n  validValue\n} from '../../../utils/util';\nimport { PoKeyCodeEnum } from './../../../enums/po-key-code.enum';\nimport { PoControlPositionService } from './../../../services/po-control-position/po-control-position.service';\n\nimport { InputBoolean } from '../../../decorators';\nimport { PoFieldValidateModel } from '../po-field-validate.model';\nimport { PoSelectOption } from './po-select-option.interface';\n\nconst poSelectContentOffset = 8;\nconst poSelectContentPositionDefault = 'bottom';\nconst PO_SELECT_FIELD_LABEL_DEFAULT = 'label';\nconst PO_SELECT_FIELD_VALUE_DEFAULT = 'value';\n\n/**\n * @docsExtends PoFieldValidateModel\n *\n * @example\n *\n * <example name=\"po-select-basic\" title=\"PO Select Basic\">\n *   <file name=\"sample-po-select-basic/sample-po-select-basic.component.html\"> </file>\n *   <file name=\"sample-po-select-basic/sample-po-select-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-select-labs\" title=\"PO Select Labs\">\n *   <file name=\"sample-po-select-labs/sample-po-select-labs.component.html\"> </file>\n *   <file name=\"sample-po-select-labs/sample-po-select-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-select-customer-registration\" title=\"PO Select - Customer registration\">\n *   <file name=\"sample-po-select-customer-registration/sample-po-select-customer-registration.component.html\"> </file>\n *   <file name=\"sample-po-select-customer-registration/sample-po-select-customer-registration.component.ts\"> </file>\n *   <file name=\"sample-po-select-customer-registration/sample-po-select-customer-registration.service.ts\"> </file>\n *   <file name='sample-po-select-customer-registration/sample-po-select-customer-registration.component.e2e-spec.ts'> </file>\n *   <file name='sample-po-select-customer-registration/sample-po-select-customer-registration.component.po.ts'> </file>\n * </example>\n *\n * <example name=\"po-select-companies\" title=\"PO Select Companies\">\n *   <file name=\"sample-po-select-companies/sample-po-select-companies.component.html\"> </file>\n *   <file name=\"sample-po-select-companies/sample-po-select-companies.component.ts\"> </file>\n * </example>\n *\n * @description\n *\n * O componente po-select exibe uma lista de valores e permite que o usuário selecione um desses valores.\n * Os valores listados podem ser fixos ou dinâmicos de acordo com a necessidade do desenvolvedor, dando mais flexibilidade ao componente.\n * O po-select não permite que o usuário informe um valor diferente dos valores listados, isso garante a consistência da informação.\n * O po-select não permite que sejam passados valores duplicados, undefined e null para as opções, excluindo-os da lista.\n *\n * > Ao passar um valor para o _model_ que não está na lista de opções, o mesmo será definido como `undefined`.\n *\n * Também existe a possibilidade de utilizar um _template_ para a exibição dos itens da lista,\n * veja mais em **[p-combo-option-template](/documentation/po-combo-option-template)**.\n *\n * > Obs: o template **[p-select-option-template](/documentation/po-select-option-template)** será depreciado na versão 14.x.x.\n */\n@Component({\n  selector: 'po-select',\n  templateUrl: './po-select.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PoSelectComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => PoSelectComponent),\n      multi: true\n    },\n    PoControlPositionService\n  ]\n})\nexport class PoSelectComponent extends PoFieldValidateModel<any> implements DoCheck {\n  @ViewChild('contentList', { read: ElementRef, static: true }) contentList: ElementRef;\n  @ViewChild('icon', { read: ElementRef, static: true }) iconElement: ElementRef;\n  @ViewChild('select', { read: ElementRef, static: true }) selectElement: ElementRef;\n  @ViewChild('selectButton', { read: ElementRef, static: true }) selectButtonElement: ElementRef;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Função para atualizar o ngModel do componente, necessário quando não for utilizado dentro da tag form.\n   *\n   * Na versão 12.2.0 do Angular a verificação `strictTemplates` vem true como default. Portanto, para utilizar\n   * two-way binding no componente deve se utilizar da seguinte forma:\n   *\n   * ```\n   * <po-select ... [ngModel]=\"selectModel\" (ngModelChange)=\"selectModel = $event\"> </po-select>\n   * ```\n   */\n  @Output('ngModelChange') ngModelChange: EventEmitter<any> = new EventEmitter<any>();\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica que o campo será somente para leitura.\n   *\n   * @default `false`\n   */\n  @Input('p-readonly') @InputBoolean() readonly: boolean = false;\n\n  /** Mensagem que aparecerá enquanto nenhuma opção estiver selecionada. */\n  @Input('p-placeholder') placeholder?: string;\n\n  displayValue;\n  isMobile: any = isMobile();\n  modelValue: any;\n  onModelChange: any;\n  open: boolean = false;\n  selectedValue: any;\n  selectOptionTemplate: any;\n  selectIcon: string = 'po-icon-arrow-down';\n  scrollPosition: number;\n\n  eventListenerFunction: () => void;\n  eventResizeListener: () => void;\n\n  onModelTouched: any;\n  protected clickoutListener: () => void;\n  private differ: any;\n  private _fieldLabel?: string = PO_SELECT_FIELD_LABEL_DEFAULT;\n  private _fieldValue?: string = PO_SELECT_FIELD_VALUE_DEFAULT;\n  private _options: Array<PoSelectOption> | Array<any>;\n\n  /**\n   * Nesta propriedade deve ser definido uma coleção de objetos que implementam a interface `PoSelectOption`.\n   *\n   * Caso esta lista estiver vazia, o model será `undefined`.\n   *\n   * > Essa propriedade é imutável, ou seja, sempre que quiser atualizar a lista de opções disponíveis\n   * atualize a referência do objeto:\n   *\n   * ```\n   * // atualiza a referência do objeto garantindo a atualização do template\n   * this.options = [...this.options, { value: 'x', label: 'Nova opção' }];\n   *\n   * // evite, pois não atualiza a referência do objeto podendo gerar atrasos na atualização do template\n   * this.options.push({ value: 'x', label: 'Nova opção' });\n   * ```\n   */\n  @Input('p-options') set options(options: Array<any>) {\n    if (this.fieldLabel && this.fieldValue) {\n      options.map(option => {\n        option.label = option[this.fieldLabel];\n        option.value = option[this.fieldValue];\n      });\n    }\n\n    this.validateOptions([...options]);\n    this.onUpdateOptions();\n    this._options = [...options];\n  }\n\n  get options() {\n    return this._options;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   * Deve ser informado o nome da propriedade do objeto que será utilizado para a conversão dos itens apresentados na lista do componente\n   * (`p-options`), esta propriedade será responsável pelo texto de apresentação de cada item da lista.\n   *\n   * @default `label`\n   */\n  @Input('p-field-label') set fieldLabel(value: string) {\n    this._fieldLabel = value || PO_SELECT_FIELD_LABEL_DEFAULT;\n    if (this.options && this.options.length > 0) {\n      this.options = [...this.options];\n    }\n  }\n\n  get fieldLabel() {\n    return this._fieldLabel;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   * Deve ser informado o nome da propriedade do objeto que será utilizado para a conversão dos itens apresentados na lista do componente\n   * (`p-options`), esta propriedade será responsável pelo valor de cada item da lista.\n   *\n   * @default `value`\n   */\n  @Input('p-field-value') set fieldValue(value: string) {\n    this._fieldValue = value || PO_SELECT_FIELD_VALUE_DEFAULT;\n    if (this.options && this.options.length > 0) {\n      this.options = [...this.options];\n    }\n  }\n\n  get fieldValue() {\n    return this._fieldValue;\n  }\n\n  /* istanbul ignore next */\n  constructor(\n    private element: ElementRef,\n    private changeDetector: ChangeDetectorRef,\n    differs: IterableDiffers,\n    public renderer: Renderer2,\n    private controlPosition: PoControlPositionService\n  ) {\n    super();\n    this.differ = differs.find([]).create(null);\n  }\n\n  get isInvisibleSelectNative() {\n    return this.readonly && this.isMobile;\n  }\n\n  @HostListener('keydown', ['$event']) onKeydown($event?: any) {\n    const charCode = $event.which || $event.keyCode;\n\n    // Tratamentos para quando o readonly for ativado.\n    if (this.readonly) {\n      // deve matar o evento do teclado devido a alterar o valor do model mesmo com os options fechados\n      if (charCode !== PoKeyCodeEnum.tab) {\n        this.disableDefaultEventAndToggleButton();\n        $event.preventDefault();\n      }\n      return;\n    }\n\n    // Seleciona os itens com as teclas \"up\" e \"down\"\n    if ((!this.open || $event.altKey) && (charCode === PoKeyCodeEnum.arrowDown || charCode === PoKeyCodeEnum.arrowUp)) {\n      this.disableDefaultEventAndToggleButton();\n    }\n\n    // Abre o po-select com as teclas \"enter\" e \"espaço\"\n    if (charCode === PoKeyCodeEnum.enter || charCode === PoKeyCodeEnum.space) {\n      this.disableDefaultEventAndToggleButton();\n    }\n\n    // Fecha o po-select com a tecla \"tab\"\n    if (this.open && charCode === PoKeyCodeEnum.tab) {\n      $event.preventDefault();\n      this.toggleButton();\n    }\n  }\n\n  ngDoCheck() {\n    const change = this.differ.diff(this.options);\n    if (change) {\n      removeDuplicatedOptions(this.options);\n      removeUndefinedAndNullOptions(this.options);\n      removeDuplicatedOptionsWithFieldValue(this.options, this.fieldValue);\n      removeUndefinedAndNullOptionsWithFieldValue(this.options, this.fieldValue);\n    }\n  }\n\n  /**\n   * Função que atribui foco ao componente.\n   *\n   * Para utilizá-la é necessário ter a instância do componente no DOM, podendo ser utilizado o ViewChild da seguinte forma:\n   *\n   * ```\n   * import { PoSelectComponent } from '@po-ui/ng-components';\n   *\n   * ...\n   *\n   * @ViewChild(PoSelectComponent, { static: true }) select: PoSelectComponent;\n   *\n   * focusSelect() {\n   *   this.select.focus();\n   * }\n   * ```\n   */\n  focus(): void {\n    if (!this.disabled) {\n      this.selectElement.nativeElement.focus();\n    }\n  }\n\n  hideDropDown() {\n    this.selectIcon = 'po-icon-arrow-down';\n    this.selector('.po-select-container').classList.remove('po-select-show');\n    this.open = false;\n\n    this.changeDetector.markForCheck();\n    this.selectElement.nativeElement.focus();\n\n    this.removeListeners();\n  }\n\n  onBlur() {\n    this.onModelTouched?.();\n  }\n\n  onOptionClick(option: any) {\n    this.updateValues(option);\n    this.toggleButton();\n  }\n\n  // Altera o valor ao selecionar um item.\n  onSelectChange(value: any) {\n    if (value && this.options && this.options.length) {\n      const optionFound: any = this.findOptionValue(value);\n\n      if (optionFound) {\n        this.updateValues(optionFound);\n        this.setScrollPosition(optionFound.value);\n      }\n    }\n  }\n\n  onUpdateOptions() {\n    if (this.modelValue) {\n      this.onSelectChange(this.modelValue);\n    }\n  }\n\n  scrollValue(index, clientHeight) {\n    const heightScrollValue: number = index * this.getSelectItemHeight();\n\n    return (this.scrollPosition = heightScrollValue > clientHeight ? heightScrollValue : 0);\n  }\n\n  selector(query: string): Element {\n    return this.element.nativeElement.querySelector(query);\n  }\n\n  toggleButton(): void {\n    this.open ? this.hideDropDown() : this.showDropdown();\n  }\n\n  // Atualiza valores\n  updateValues(option: any): void {\n    if (this.selectedValue !== option[this.fieldValue]) {\n      this.selectedValue = option[this.fieldValue];\n      this.selectElement.nativeElement.value = option[this.fieldValue];\n      this.updateModel(option[this.fieldValue]);\n      this.displayValue = option[this.fieldLabel];\n      this.emitChange(option[this.fieldValue]);\n    }\n  }\n\n  // Esconde Content do Select quando for clicado fora\n  wasClickedOnToggle(event: MouseEvent): void {\n    if (\n      !this.selectButtonElement.nativeElement.contains(event.target) &&\n      !this.iconElement.nativeElement.contains(event.target)\n    ) {\n      this.hideDropDown();\n    }\n  }\n\n  // Recebe as alterações do model\n  onWriteValue(value: any) {\n    const optionFound: any = this.findOptionValue(value);\n\n    if (optionFound) {\n      this.selectElement.nativeElement.value = optionFound.value;\n      this.selectedValue = optionFound[this.fieldValue];\n      this.displayValue = optionFound[this.fieldLabel];\n      this.setScrollPosition(optionFound[this.fieldValue]);\n    } else if (validValue(this.selectedValue)) {\n      this.selectElement.nativeElement.value = undefined;\n      this.updateModel(undefined);\n      this.selectedValue = undefined;\n      this.displayValue = undefined;\n    }\n\n    this.modelValue = value;\n    this.changeDetector.detectChanges();\n  }\n\n  extraValidation(c: AbstractControl): { [key: string]: any } {\n    return null;\n  }\n\n  private isEqual(value: any, inputValue: any): boolean {\n    if ((value || value === 0) && inputValue) {\n      return value.toString() === inputValue.toString();\n    }\n\n    if ((value === null && inputValue !== null) || (value === undefined && inputValue !== undefined)) {\n      value = `${value}`; // Transformando em string\n    }\n\n    return value === inputValue;\n  }\n\n  // Método necessário para bloquear o evento default do select nativo.\n  // Ao utilizar event.preventDefault(), nos navegadores Firefox e IE o mesmo não cancela o evento.\n  private disableDefaultEventAndToggleButton() {\n    this.selectElement.nativeElement.style.display = 'none';\n\n    setTimeout(() => {\n      this.selectElement.nativeElement.style.display = 'block';\n      this.toggleButton();\n    });\n  }\n\n  private findOptionValue(value: any) {\n    return this.options.find(option => this.isEqual(option.value, value));\n  }\n\n  private getSelectItemHeight() {\n    const selectItem = this.selector('div.po-select-item');\n\n    return selectItem && selectItem.clientHeight;\n  }\n\n  private initializeListeners() {\n    this.clickoutListener = this.renderer.listen('document', 'click', (event: MouseEvent) => {\n      this.wasClickedOnToggle(event);\n    });\n\n    this.eventResizeListener = this.renderer.listen('window', 'resize', () => {\n      this.hideDropDown();\n    });\n\n    window.addEventListener('scroll', this.onScroll, true);\n  }\n\n  private onScroll = (): void => {\n    this.controlPosition.adjustPosition(poSelectContentPositionDefault);\n  };\n\n  private removeListeners() {\n    if (this.clickoutListener) {\n      this.clickoutListener();\n    }\n\n    this.eventResizeListener();\n    window.removeEventListener('scroll', this.onScroll, true);\n  }\n\n  private setPositionDropdown() {\n    this.controlPosition.setElements(\n      this.contentList.nativeElement,\n      poSelectContentOffset,\n      this.selectButtonElement,\n      ['top', 'bottom'],\n      true\n    );\n\n    this.controlPosition.adjustPosition(poSelectContentPositionDefault);\n  }\n\n  private setScrollPosition(value: any) {\n    const ulDropdpwn = this.element.nativeElement.querySelector('ul.po-select-content');\n\n    if (value && this.options && this.options.length) {\n      const optionFound: any = this.findOptionValue(value);\n\n      if (optionFound) {\n        const index = this.options.indexOf(optionFound);\n        ulDropdpwn.scrollTop = this.scrollValue(index, ulDropdpwn.clientHeight);\n      }\n    }\n  }\n\n  private showDropdown() {\n    if (!this.readonly) {\n      this.selectElement.nativeElement.focus();\n      this.selectIcon = 'po-icon-arrow-up';\n      this.selector('.po-select-container').classList.add('po-select-show');\n      this.open = true;\n      this.changeDetector.markForCheck();\n      this.setPositionDropdown();\n      this.initializeListeners();\n\n      if (this.options && this.options.length) {\n        this.setScrollPosition(this.selectedValue);\n      }\n    }\n  }\n\n  private validateOptions(options: Array<any>) {\n    removeDuplicatedOptions(options);\n    removeUndefinedAndNullOptions(options);\n    removeDuplicatedOptionsWithFieldValue(options, this.fieldValue);\n    removeUndefinedAndNullOptionsWithFieldValue(options, this.fieldValue);\n  }\n}\n","<po-field-container [p-label]=\"label\" [p-help]=\"help\" [p-optional]=\"!required && optional\">\n  <select\n    #select\n    class=\"po-select\"\n    [attr.name]=\"name\"\n    [disabled]=\"disabled\"\n    [ngClass]=\"{ 'po-select-mobile': isMobile, 'po-invisible': isInvisibleSelectNative }\"\n    [required]=\"required\"\n    (change)=\"onSelectChange($event.target.value)\"\n    (blur)=\"onBlur()\"\n  >\n    <option *ngIf=\"isMobile\" disabled hidden selected></option>\n    <option\n      *ngFor=\"let option of options\"\n      [disabled]=\"readonly\"\n      [value]=\"option?.[this.fieldValue]\"\n      (click)=\"onOptionClick(option)\"\n    >\n      {{ option?.[this.fieldLabel] }}\n    </option>\n  </select>\n\n  <div class=\"po-select-container\">\n    <div\n      #selectButton\n      class=\"po-select-button\"\n      [ngClass]=\"{ 'po-select-button-disabled': disabled, 'po-select-button-readonly': readonly }\"\n      (click)=\"toggleButton()\"\n    >\n      <span>{{ displayValue || placeholder }}</span>\n\n      <div class=\"po-field-icon-container-right\">\n        <span\n          #icon\n          class=\"po-icon {{ selectIcon }} po-field-icon\"\n          [ngClass]=\"{ 'po-field-icon-disabled': disabled, 'po-field-icon-readonly': readonly }\"\n        ></span>\n      </div>\n    </div>\n\n    <ul #contentList class=\"po-select-content\" [ngClass]=\"{ 'po-invisible': isMobile }\">\n      <li\n        *ngFor=\"let option of options\"\n        [class.po-select-item-selected]=\"selectedValue === option?.[this.fieldLabel]\"\n        [value]=\"option?.[this.fieldValue]\"\n        (click)=\"onOptionClick(option)\"\n      >\n        <div class=\"po-select-item\">\n          <ng-container *ngIf=\"selectOptionTemplate; then optionTemplate; else defaultOptionTemplate\"></ng-container>\n\n          <ng-template #defaultOptionTemplate>\n            <span>{{ option?.[this.fieldLabel] }}</span>\n          </ng-template>\n\n          <ng-template\n            #optionTemplate\n            [ngTemplateOutlet]=\"selectOptionTemplate?.templateRef\"\n            [ngTemplateOutletContext]=\"{ $implicit: option }\"\n          >\n          </ng-template>\n        </div>\n      </li>\n    </ul>\n  </div>\n\n  <po-field-container-bottom></po-field-container-bottom>\n</po-field-container>\n"]}
|
|
349
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-select.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-select/po-select.component.ts","../../../../../../../projects/ui/src/lib/components/po-field/po-select/po-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DoCheck,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Input,\n  IterableDiffers,\n  Output,\n  Renderer2,\n  ViewChild\n} from '@angular/core';\nimport { AbstractControl, NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport {\n  removeDuplicatedOptions,\n  removeDuplicatedOptionsWithFieldValue,\n  removeUndefinedAndNullOptions,\n  removeUndefinedAndNullOptionsWithFieldValue,\n  validValue\n} from '../../../utils/util';\n\nimport { InputBoolean } from '../../../decorators';\nimport { PoFieldValidateModel } from '../po-field-validate.model';\nimport { PoSelectOption } from './po-select-option.interface';\n\nconst PO_SELECT_FIELD_LABEL_DEFAULT = 'label';\nconst PO_SELECT_FIELD_VALUE_DEFAULT = 'value';\n\n/**\n * @docsExtends PoFieldValidateModel\n *\n * @example\n *\n * <example name=\"po-select-basic\" title=\"PO Select Basic\">\n *   <file name=\"sample-po-select-basic/sample-po-select-basic.component.html\"> </file>\n *   <file name=\"sample-po-select-basic/sample-po-select-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-select-labs\" title=\"PO Select Labs\">\n *   <file name=\"sample-po-select-labs/sample-po-select-labs.component.html\"> </file>\n *   <file name=\"sample-po-select-labs/sample-po-select-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-select-customer-registration\" title=\"PO Select - Customer registration\">\n *   <file name=\"sample-po-select-customer-registration/sample-po-select-customer-registration.component.html\"> </file>\n *   <file name=\"sample-po-select-customer-registration/sample-po-select-customer-registration.component.ts\"> </file>\n *   <file name=\"sample-po-select-customer-registration/sample-po-select-customer-registration.service.ts\"> </file>\n *   <file name='sample-po-select-customer-registration/sample-po-select-customer-registration.component.e2e-spec.ts'> </file>\n *   <file name='sample-po-select-customer-registration/sample-po-select-customer-registration.component.po.ts'> </file>\n * </example>\n *\n * <example name=\"po-select-companies\" title=\"PO Select Companies\">\n *   <file name=\"sample-po-select-companies/sample-po-select-companies.component.html\"> </file>\n *   <file name=\"sample-po-select-companies/sample-po-select-companies.component.ts\"> </file>\n * </example>\n *\n * @description\n *\n * O componente po-select exibe uma lista de valores e permite que o usuário selecione um desses valores.\n * Os valores listados podem ser fixos ou dinâmicos de acordo com a necessidade do desenvolvedor, dando mais flexibilidade ao componente.\n * O po-select não permite que o usuário informe um valor diferente dos valores listados, isso garante a consistência da informação.\n * O po-select não permite que sejam passados valores duplicados, undefined e null para as opções, excluindo-os da lista.\n *\n * > Ao passar um valor para o _model_ que não está na lista de opções, o mesmo será definido como `undefined`.\n *\n * Também existe a possibilidade de utilizar um _template_ para a exibição dos itens da lista,\n * veja mais em **[p-combo-option-template](/documentation/po-combo-option-template)**.\n *\n * > Obs: o template **[p-select-option-template](/documentation/po-select-option-template)** será depreciado na versão 14.x.x.\n */\n@Component({\n  selector: 'po-select',\n  templateUrl: './po-select.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PoSelectComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => PoSelectComponent),\n      multi: true\n    }\n  ]\n})\nexport class PoSelectComponent extends PoFieldValidateModel<any> implements DoCheck {\n  @ViewChild('select', { read: ElementRef, static: true }) selectElement: ElementRef;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Função para atualizar o ngModel do componente, necessário quando não for utilizado dentro da tag form.\n   *\n   * Na versão 12.2.0 do Angular a verificação `strictTemplates` vem true como default. Portanto, para utilizar\n   * two-way binding no componente deve se utilizar da seguinte forma:\n   *\n   * ```\n   * <po-select ... [ngModel]=\"selectModel\" (ngModelChange)=\"selectModel = $event\"> </po-select>\n   * ```\n   */\n  @Output('ngModelChange') ngModelChange: EventEmitter<any> = new EventEmitter<any>();\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica que o campo será somente para leitura.\n   *\n   * @default `false`\n   */\n  @Input('p-readonly') @InputBoolean() readonly: boolean = false;\n\n  /** Mensagem que aparecerá enquanto nenhuma opção estiver selecionada. */\n  @Input('p-placeholder') placeholder?: string;\n\n  displayValue;\n  modelValue: any;\n  selectedValue: any;\n  onModelTouched: any;\n\n  private differ: any;\n  private _fieldLabel?: string = PO_SELECT_FIELD_LABEL_DEFAULT;\n  private _fieldValue?: string = PO_SELECT_FIELD_VALUE_DEFAULT;\n  private _options: Array<PoSelectOption> | Array<any>;\n\n  /**\n   * Nesta propriedade deve ser definido uma coleção de objetos que implementam a interface `PoSelectOption`.\n   *\n   * Caso esta lista estiver vazia, o model será `undefined`.\n   *\n   * > Essa propriedade é imutável, ou seja, sempre que quiser atualizar a lista de opções disponíveis\n   * atualize a referência do objeto:\n   *\n   * ```\n   * // atualiza a referência do objeto garantindo a atualização do template\n   * this.options = [...this.options, { value: 'x', label: 'Nova opção' }];\n   *\n   * // evite, pois não atualiza a referência do objeto podendo gerar atrasos na atualização do template\n   * this.options.push({ value: 'x', label: 'Nova opção' });\n   * ```\n   */\n  @Input('p-options') set options(options: Array<any>) {\n    if (this.fieldLabel && this.fieldValue) {\n      options.map(option => {\n        option.label = option[this.fieldLabel];\n        option.value = option[this.fieldValue];\n      });\n    }\n\n    this.validateOptions([...options]);\n    this.onUpdateOptions();\n    this._options = [...options];\n  }\n\n  get options() {\n    return this._options;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   * Deve ser informado o nome da propriedade do objeto que será utilizado para a conversão dos itens apresentados na lista do componente\n   * (`p-options`), esta propriedade será responsável pelo texto de apresentação de cada item da lista.\n   *\n   * @default `label`\n   */\n  @Input('p-field-label') set fieldLabel(value: string) {\n    this._fieldLabel = value || PO_SELECT_FIELD_LABEL_DEFAULT;\n    if (this.options && this.options.length > 0) {\n      this.options = [...this.options];\n    }\n  }\n\n  get fieldLabel() {\n    return this._fieldLabel;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   * Deve ser informado o nome da propriedade do objeto que será utilizado para a conversão dos itens apresentados na lista do componente\n   * (`p-options`), esta propriedade será responsável pelo valor de cada item da lista.\n   *\n   * @default `value`\n   */\n  @Input('p-field-value') set fieldValue(value: string) {\n    this._fieldValue = value || PO_SELECT_FIELD_VALUE_DEFAULT;\n    if (this.options && this.options.length > 0) {\n      this.options = [...this.options];\n    }\n  }\n\n  get fieldValue() {\n    return this._fieldValue;\n  }\n\n  /* istanbul ignore next */\n  constructor(private changeDetector: ChangeDetectorRef, differs: IterableDiffers, public renderer: Renderer2) {\n    super();\n    this.differ = differs.find([]).create(null);\n  }\n\n  ngDoCheck() {\n    const change = this.differ.diff(this.options);\n\n    if (change) {\n      this.validateOptions(this.options);\n    }\n  }\n\n  /**\n   * Função que atribui foco ao componente.\n   *\n   * Para utilizá-la é necessário ter a instância do componente no DOM, podendo ser utilizado o ViewChild da seguinte forma:\n   *\n   * ```\n   * import { PoSelectComponent } from '@po-ui/ng-components';\n   *\n   * ...\n   *\n   * @ViewChild(PoSelectComponent, { static: true }) select: PoSelectComponent;\n   *\n   * focusSelect() {\n   *   this.select.focus();\n   * }\n   * ```\n   */\n  focus(): void {\n    if (!this.disabled) {\n      this.selectElement.nativeElement.focus();\n    }\n  }\n\n  onBlur() {\n    this.onModelTouched?.();\n  }\n\n  // Altera o valor ao selecionar um item.\n  onSelectChange(value: any) {\n    if (value && this.options && this.options.length) {\n      const optionFound: any = this.findOptionValue(value);\n\n      if (optionFound) {\n        this.updateValues(optionFound);\n      }\n    }\n  }\n\n  onUpdateOptions() {\n    if (this.modelValue) {\n      this.onSelectChange(this.modelValue);\n    }\n  }\n\n  // Atualiza valores\n  updateValues(option: any): void {\n    if (this.selectedValue !== option[this.fieldValue]) {\n      this.selectedValue = option[this.fieldValue];\n      this.selectElement.nativeElement.value = option[this.fieldValue];\n      this.updateModel(option[this.fieldValue]);\n      this.displayValue = option[this.fieldLabel];\n      this.emitChange(option[this.fieldValue]);\n    }\n  }\n\n  // Recebe as alterações do model\n  onWriteValue(value: any) {\n    const optionFound: any = this.findOptionValue(value);\n\n    if (optionFound) {\n      this.selectElement.nativeElement.value = optionFound.value;\n      this.selectedValue = optionFound[this.fieldValue];\n      this.displayValue = optionFound[this.fieldLabel];\n    } else if (validValue(this.selectedValue)) {\n      this.selectElement.nativeElement.value = undefined;\n      this.updateModel(undefined);\n      this.selectedValue = undefined;\n      this.displayValue = undefined;\n    }\n\n    this.modelValue = value;\n    this.changeDetector.detectChanges();\n  }\n\n  extraValidation(c: AbstractControl): { [key: string]: any } {\n    return null;\n  }\n\n  private isEqual(value: any, inputValue: any): boolean {\n    if ((value || value === 0) && inputValue) {\n      return value.toString() === inputValue.toString();\n    }\n\n    if ((value === null && inputValue !== null) || (value === undefined && inputValue !== undefined)) {\n      value = `${value}`; // Transformando em string\n    }\n\n    return value === inputValue;\n  }\n\n  private findOptionValue(value: any) {\n    return this.options.find(option => this.isEqual(option.value, value));\n  }\n\n  private validateOptions(options: Array<any>) {\n    removeDuplicatedOptions(options);\n    removeUndefinedAndNullOptions(options);\n    removeDuplicatedOptionsWithFieldValue(options, this.fieldValue);\n    removeUndefinedAndNullOptionsWithFieldValue(options, this.fieldValue);\n  }\n}\n","<po-field-container [p-label]=\"label\" [p-help]=\"help\" [p-optional]=\"!required && optional\">\n  <div class=\"po-field-container-content\">\n    <select\n      #select\n      class=\"po-select\"\n      [attr.aria-label]=\"label\"\n      [attr.name]=\"name\"\n      [class.po-select-placeholder]=\"!selectedValue && !!placeholder\"\n      [disabled]=\"disabled\"\n      [required]=\"required\"\n      (blur)=\"onBlur()\"\n      (change)=\"onSelectChange($event.target.value)\"\n    >\n      <option\n        *ngIf=\"!selectedValue || !!placeholder\"\n        [disabled]=\"!!placeholder\"\n        [hidden]=\"!selectedValue && !placeholder\"\n        [selected]=\"!selectedValue\"\n        [value]=\"placeholder ?? ''\"\n      >\n        {{ placeholder }}\n      </option>\n      <option *ngFor=\"let option of options\" [disabled]=\"readonly\" [value]=\"option?.[this.fieldValue]\">\n        {{ option?.[this.fieldLabel] }}\n      </option>\n    </select>\n  </div>\n\n  <po-field-container-bottom></po-field-container-bottom>\n</po-field-container>\n"]}
|