@po-ui/ng-components 14.2.1 → 14.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (70) hide show
  1. package/esm2020/lib/components/po-accordion/po-accordion-item/po-accordion-item.component.mjs +30 -3
  2. package/esm2020/lib/components/po-accordion/po-accordion.component.mjs +2 -2
  3. package/esm2020/lib/components/po-accordion/services/po-accordion.service.mjs +1 -1
  4. package/esm2020/lib/components/po-breadcrumb/po-breadcrumb-dropdown/po-breadcrumb-dropdown.component.mjs +5 -3
  5. package/esm2020/lib/components/po-button/po-button-base.component.mjs +58 -8
  6. package/esm2020/lib/components/po-button/po-button-size.enum.mjs +6 -0
  7. package/esm2020/lib/components/po-button/po-button.component.mjs +4 -4
  8. package/esm2020/lib/components/po-button-group/po-button-group-base.component.mjs +8 -1
  9. package/esm2020/lib/components/po-button-group/po-button-group.component.mjs +3 -3
  10. package/esm2020/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-field.interface.mjs +1 -1
  11. package/esm2020/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-fields/po-dynamic-form-fields.component.mjs +12 -12
  12. package/esm2020/lib/components/po-field/po-checkbox/po-checkbox-base.component.mjs +11 -2
  13. package/esm2020/lib/components/po-field/po-checkbox/po-checkbox.component.mjs +24 -12
  14. package/esm2020/lib/components/po-field/po-checkbox-group/po-checkbox-group.component.mjs +14 -20
  15. package/esm2020/lib/components/po-field/po-checkbox-group/po-checkbox-group.module.mjs +5 -4
  16. package/esm2020/lib/components/po-field/po-combo/po-combo-base.component.mjs +74 -43
  17. package/esm2020/lib/components/po-field/po-combo/po-combo.component.mjs +16 -14
  18. package/esm2020/lib/components/po-field/po-datepicker/po-datepicker.component.mjs +2 -1
  19. package/esm2020/lib/components/po-field/po-datepicker-range/po-datepicker-range-base.component.mjs +25 -2
  20. package/esm2020/lib/components/po-field/po-datepicker-range/po-datepicker-range.component.mjs +5 -5
  21. package/esm2020/lib/components/po-field/po-lookup/po-lookup-base.component.mjs +28 -2
  22. package/esm2020/lib/components/po-field/po-lookup/po-lookup-modal/po-lookup-modal-base.component.mjs +28 -2
  23. package/esm2020/lib/components/po-field/po-lookup/po-lookup-modal/po-lookup-modal.component.mjs +4 -4
  24. package/esm2020/lib/components/po-field/po-lookup/po-lookup.component.mjs +5 -3
  25. package/esm2020/lib/components/po-field/po-lookup/services/po-lookup-modal.service.mjs +6 -2
  26. package/esm2020/lib/components/po-field/po-rich-text/po-rich-text-toolbar/po-rich-text-toolbar.component.mjs +9 -9
  27. package/esm2020/lib/components/po-field/po-select/po-select.component.mjs +90 -25
  28. package/esm2020/lib/components/po-field/po-switch/po-switch.component.mjs +38 -34
  29. package/esm2020/lib/components/po-field/po-upload/po-upload-base.service.mjs +4 -2
  30. package/esm2020/lib/components/po-list-view/po-list-view.component.mjs +3 -3
  31. package/esm2020/lib/components/po-loading/po-loading-overlay/po-loading-overlay-base.component.mjs +2 -2
  32. package/esm2020/lib/components/po-table/po-table-base.component.mjs +23 -4
  33. package/esm2020/lib/components/po-table/po-table-column-manager/po-table-column-manager.component.mjs +3 -3
  34. package/esm2020/lib/components/po-table/po-table.component.mjs +6 -5
  35. package/esm2020/lib/components/po-widget/po-widget-base.component.mjs +3 -2
  36. package/esm2020/lib/components/po-widget/po-widget.component.mjs +24 -12
  37. package/esm2020/lib/utils/util.mjs +20 -1
  38. package/fesm2015/po-ui-ng-components.mjs +849 -503
  39. package/fesm2015/po-ui-ng-components.mjs.map +1 -1
  40. package/fesm2020/po-ui-ng-components.mjs +828 -490
  41. package/fesm2020/po-ui-ng-components.mjs.map +1 -1
  42. package/lib/components/po-accordion/po-accordion-item/po-accordion-item.component.d.ts +10 -3
  43. package/lib/components/po-accordion/services/po-accordion.service.d.ts +3 -2
  44. package/lib/components/po-button/po-button-base.component.d.ts +29 -4
  45. package/lib/components/po-button/po-button-size.enum.d.ts +4 -0
  46. package/lib/components/po-button-group/po-button-group-base.component.d.ts +7 -0
  47. package/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-field.interface.d.ts +18 -0
  48. package/lib/components/po-field/po-checkbox/po-checkbox-base.component.d.ts +2 -1
  49. package/lib/components/po-field/po-checkbox-group/po-checkbox-group.module.d.ts +2 -1
  50. package/lib/components/po-field/po-combo/po-combo-base.component.d.ts +27 -22
  51. package/lib/components/po-field/po-datepicker-range/po-datepicker-range-base.component.d.ts +13 -1
  52. package/lib/components/po-field/po-lookup/po-lookup-base.component.d.ts +21 -1
  53. package/lib/components/po-field/po-lookup/po-lookup-modal/po-lookup-modal-base.component.d.ts +21 -1
  54. package/lib/components/po-field/po-lookup/services/po-lookup-modal.service.d.ts +4 -0
  55. package/lib/components/po-field/po-select/po-select.component.d.ts +36 -7
  56. package/lib/components/po-field/po-switch/po-switch.component.d.ts +12 -2
  57. package/lib/components/po-table/po-table-base.component.d.ts +12 -1
  58. package/lib/components/po-table/po-table.component.d.ts +1 -0
  59. package/lib/components/po-widget/po-widget-base.component.d.ts +1 -0
  60. package/lib/utils/util.d.ts +2 -0
  61. package/package.json +4 -4
  62. package/po-ui-ng-components-14.4.0.tgz +0 -0
  63. package/schematics/ng-add/index.js +1 -1
  64. package/schematics/ng-update/v14/index.js +1 -1
  65. package/schematics/ng-update/v2/index.js +1 -1
  66. package/schematics/ng-update/v3/index.js +1 -1
  67. package/schematics/ng-update/v4/index.js +1 -1
  68. package/schematics/ng-update/v5/index.js +1 -1
  69. package/schematics/ng-update/v6/index.js +1 -1
  70. package/po-ui-ng-components-14.2.1.tgz +0 -0
@@ -1,11 +1,11 @@
1
1
  import { __decorate } from "tslib";
2
- import { ChangeDetectionStrategy, Component, ElementRef, forwardRef, HostListener, ViewChild, Input, Output, EventEmitter } from '@angular/core';
3
- import { NG_VALUE_ACCESSOR, NG_VALIDATORS } from '@angular/forms';
4
- import { isMobile, removeDuplicatedOptions, removeUndefinedAndNullOptions, validValue } from '../../../utils/util';
5
- import { PoControlPositionService } from './../../../services/po-control-position/po-control-position.service';
2
+ import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, forwardRef, HostListener, Input, Output, ViewChild } from '@angular/core';
3
+ import { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';
4
+ import { isMobile, removeDuplicatedOptions, removeDuplicatedOptionsWithFieldValue, removeUndefinedAndNullOptions, removeUndefinedAndNullOptionsWithFieldValue, validValue } from '../../../utils/util';
6
5
  import { PoKeyCodeEnum } from './../../../enums/po-key-code.enum';
7
- import { PoFieldValidateModel } from '../po-field-validate.model';
6
+ import { PoControlPositionService } from './../../../services/po-control-position/po-control-position.service';
8
7
  import { InputBoolean } from '../../../decorators';
8
+ import { PoFieldValidateModel } from '../po-field-validate.model';
9
9
  import * as i0 from "@angular/core";
10
10
  import * as i1 from "./../../../services/po-control-position/po-control-position.service";
11
11
  import * as i2 from "@angular/common";
@@ -28,9 +28,9 @@ function PoSelectComponent_option_4_Template(rf, ctx) { if (rf & 1) {
28
28
  } if (rf & 2) {
29
29
  const option_r7 = ctx.$implicit;
30
30
  const ctx_r2 = i0.ɵɵnextContext();
31
- i0.ɵɵproperty("disabled", ctx_r2.readonly)("value", option_r7.value);
31
+ i0.ɵɵproperty("disabled", ctx_r2.readonly)("value", option_r7 == null ? null : option_r7[ctx_r2.fieldValue]);
32
32
  i0.ɵɵadvance(1);
33
- i0.ɵɵtextInterpolate1(" ", option_r7 == null ? null : option_r7.label, " ");
33
+ i0.ɵɵtextInterpolate1(" ", option_r7 == null ? null : option_r7[ctx_r2.fieldLabel], " ");
34
34
  } }
35
35
  function PoSelectComponent_li_15_ng_container_2_Template(rf, ctx) { if (rf & 1) {
36
36
  i0.ɵɵelementContainer(0);
@@ -41,8 +41,9 @@ function PoSelectComponent_li_15_ng_template_3_Template(rf, ctx) { if (rf & 1) {
41
41
  i0.ɵɵelementEnd();
42
42
  } if (rf & 2) {
43
43
  const option_r10 = i0.ɵɵnextContext().$implicit;
44
+ const ctx_r13 = i0.ɵɵnextContext();
44
45
  i0.ɵɵadvance(1);
45
- i0.ɵɵtextInterpolate(option_r10 == null ? null : option_r10.label);
46
+ i0.ɵɵtextInterpolate(option_r10 == null ? null : option_r10[ctx_r13.fieldLabel]);
46
47
  } }
47
48
  function PoSelectComponent_li_15_ng_template_5_Template(rf, ctx) { }
48
49
  const _c4 = function (a0) { return { $implicit: a0 }; };
@@ -60,8 +61,8 @@ function PoSelectComponent_li_15_Template(rf, ctx) { if (rf & 1) {
60
61
  const _r12 = i0.ɵɵreference(4);
61
62
  const _r14 = i0.ɵɵreference(6);
62
63
  const ctx_r6 = i0.ɵɵnextContext();
63
- i0.ɵɵclassProp("po-select-item-selected", ctx_r6.selectedValue === option_r10.value);
64
- i0.ɵɵproperty("value", option_r10.value);
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]);
65
66
  i0.ɵɵadvance(2);
66
67
  i0.ɵɵproperty("ngIf", ctx_r6.selectOptionTemplate)("ngIfThen", _r14)("ngIfElse", _r12);
67
68
  i0.ɵɵadvance(3);
@@ -73,6 +74,8 @@ const _c7 = function (a0, a1) { return { "po-field-icon-disabled": a0, "po-field
73
74
  const _c8 = function (a0) { return { "po-invisible": a0 }; };
74
75
  const poSelectContentOffset = 8;
75
76
  const poSelectContentPositionDefault = 'bottom';
77
+ const PO_SELECT_FIELD_LABEL_DEFAULT = 'label';
78
+ const PO_SELECT_FIELD_VALUE_DEFAULT = 'value';
76
79
  /**
77
80
  * @docsExtends PoFieldValidateModel
78
81
  *
@@ -96,6 +99,11 @@ const poSelectContentPositionDefault = 'bottom';
96
99
  * <file name='sample-po-select-customer-registration/sample-po-select-customer-registration.component.po.ts'> </file>
97
100
  * </example>
98
101
  *
102
+ * <example name="po-select-companies" title="PO Select Companies">
103
+ * <file name="sample-po-select-companies/sample-po-select-companies.component.html"> </file>
104
+ * <file name="sample-po-select-companies/sample-po-select-companies.component.ts"> </file>
105
+ * </example>
106
+ *
99
107
  * @description
100
108
  *
101
109
  * O componente po-select exibe uma lista de valores e permite que o usuário selecione um desses valores.
@@ -146,6 +154,8 @@ export class PoSelectComponent extends PoFieldValidateModel {
146
154
  this.isMobile = isMobile();
147
155
  this.open = false;
148
156
  this.selectIcon = 'po-icon-arrow-down';
157
+ this._fieldLabel = PO_SELECT_FIELD_LABEL_DEFAULT;
158
+ this._fieldValue = PO_SELECT_FIELD_VALUE_DEFAULT;
149
159
  this.onScroll = () => {
150
160
  this.controlPosition.adjustPosition(poSelectContentPositionDefault);
151
161
  };
@@ -168,14 +178,55 @@ export class PoSelectComponent extends PoFieldValidateModel {
168
178
  * ```
169
179
  */
170
180
  set options(options) {
171
- this._options = options;
172
- removeDuplicatedOptions(this._options);
173
- removeUndefinedAndNullOptions(this._options);
181
+ if (this.fieldLabel && this.fieldValue) {
182
+ options.map(option => {
183
+ option.label = option[this.fieldLabel];
184
+ option.value = option[this.fieldValue];
185
+ });
186
+ }
187
+ this.validateOptions([...options]);
174
188
  this.onUpdateOptions();
189
+ this._options = [...options];
175
190
  }
176
191
  get options() {
177
192
  return this._options;
178
193
  }
194
+ /**
195
+ * @optional
196
+ *
197
+ * @description
198
+ * Deve ser informado o nome da propriedade do objeto que será utilizado para a conversão dos itens apresentados na lista do componente
199
+ * (`p-options`), esta propriedade será responsável pelo texto de apresentação de cada item da lista.
200
+ *
201
+ * @default `label`
202
+ */
203
+ set fieldLabel(value) {
204
+ this._fieldLabel = value || PO_SELECT_FIELD_LABEL_DEFAULT;
205
+ if (this.options && this.options.length > 0) {
206
+ this.options = [...this.options];
207
+ }
208
+ }
209
+ get fieldLabel() {
210
+ return this._fieldLabel;
211
+ }
212
+ /**
213
+ * @optional
214
+ *
215
+ * @description
216
+ * Deve ser informado o nome da propriedade do objeto que será utilizado para a conversão dos itens apresentados na lista do componente
217
+ * (`p-options`), esta propriedade será responsável pelo valor de cada item da lista.
218
+ *
219
+ * @default `value`
220
+ */
221
+ set fieldValue(value) {
222
+ this._fieldValue = value || PO_SELECT_FIELD_VALUE_DEFAULT;
223
+ if (this.options && this.options.length > 0) {
224
+ this.options = [...this.options];
225
+ }
226
+ }
227
+ get fieldValue() {
228
+ return this._fieldValue;
229
+ }
179
230
  get isInvisibleSelectNative() {
180
231
  return this.readonly && this.isMobile;
181
232
  }
@@ -209,6 +260,8 @@ export class PoSelectComponent extends PoFieldValidateModel {
209
260
  if (change) {
210
261
  removeDuplicatedOptions(this.options);
211
262
  removeUndefinedAndNullOptions(this.options);
263
+ removeDuplicatedOptionsWithFieldValue(this.options, this.fieldValue);
264
+ removeUndefinedAndNullOptionsWithFieldValue(this.options, this.fieldValue);
212
265
  }
213
266
  }
214
267
  /**
@@ -275,12 +328,12 @@ export class PoSelectComponent extends PoFieldValidateModel {
275
328
  }
276
329
  // Atualiza valores
277
330
  updateValues(option) {
278
- if (this.selectedValue !== option.value) {
279
- this.selectedValue = option.value;
280
- this.selectElement.nativeElement.value = option.value;
281
- this.updateModel(option.value);
282
- this.displayValue = option.label;
283
- this.emitChange(option.value);
331
+ if (this.selectedValue !== option[this.fieldValue]) {
332
+ this.selectedValue = option[this.fieldValue];
333
+ this.selectElement.nativeElement.value = option[this.fieldValue];
334
+ this.updateModel(option[this.fieldValue]);
335
+ this.displayValue = option[this.fieldLabel];
336
+ this.emitChange(option[this.fieldValue]);
284
337
  }
285
338
  }
286
339
  // Esconde Content do Select quando for clicado fora
@@ -295,9 +348,9 @@ export class PoSelectComponent extends PoFieldValidateModel {
295
348
  const optionFound = this.findOptionValue(value);
296
349
  if (optionFound) {
297
350
  this.selectElement.nativeElement.value = optionFound.value;
298
- this.selectedValue = optionFound.value;
299
- this.displayValue = optionFound.label;
300
- this.setScrollPosition(optionFound.value);
351
+ this.selectedValue = optionFound[this.fieldValue];
352
+ this.displayValue = optionFound[this.fieldLabel];
353
+ this.setScrollPosition(optionFound[this.fieldValue]);
301
354
  }
302
355
  else if (validValue(this.selectedValue)) {
303
356
  this.selectElement.nativeElement.value = undefined;
@@ -380,6 +433,12 @@ export class PoSelectComponent extends PoFieldValidateModel {
380
433
  }
381
434
  }
382
435
  }
436
+ validateOptions(options) {
437
+ removeDuplicatedOptions(options);
438
+ removeUndefinedAndNullOptions(options);
439
+ removeDuplicatedOptionsWithFieldValue(options, this.fieldValue);
440
+ removeUndefinedAndNullOptionsWithFieldValue(options, this.fieldValue);
441
+ }
383
442
  }
384
443
  PoSelectComponent.ɵfac = function PoSelectComponent_Factory(t) { return new (t || PoSelectComponent)(i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i0.IterableDiffers), i0.ɵɵdirectiveInject(i0.Renderer2), i0.ɵɵdirectiveInject(i1.PoControlPositionService)); };
385
444
  PoSelectComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoSelectComponent, selectors: [["po-select"]], viewQuery: function PoSelectComponent_Query(rf, ctx) { if (rf & 1) {
@@ -395,7 +454,7 @@ PoSelectComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoSelectC
395
454
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.selectButtonElement = _t.first);
396
455
  } }, hostBindings: function PoSelectComponent_HostBindings(rf, ctx) { if (rf & 1) {
397
456
  i0.ɵɵlistener("keydown", function PoSelectComponent_keydown_HostBindingHandler($event) { return ctx.onKeydown($event); });
398
- } }, inputs: { readonly: ["p-readonly", "readonly"], placeholder: ["p-placeholder", "placeholder"], options: ["p-options", "options"] }, outputs: { ngModelChange: "ngModelChange" }, features: [i0.ɵɵProvidersFeature([
457
+ } }, 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([
399
458
  {
400
459
  provide: NG_VALUE_ACCESSOR,
401
460
  useExisting: forwardRef(() => PoSelectComponent),
@@ -464,7 +523,7 @@ __decorate([
464
523
  multi: true
465
524
  },
466
525
  PoControlPositionService
467
- ], template: "<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 *ngFor=\"let option of options\" [disabled]=\"readonly\" [value]=\"option.value\" (click)=\"onOptionClick(option)\">\n {{ option?.label }}\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.value\"\n [value]=\"option.value\"\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?.label }}</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" }]
526
+ ], template: "<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" }]
468
527
  }], function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i0.IterableDiffers }, { type: i0.Renderer2 }, { type: i1.PoControlPositionService }]; }, { contentList: [{
469
528
  type: ViewChild,
470
529
  args: ['contentList', { read: ElementRef, static: true }]
@@ -489,8 +548,14 @@ __decorate([
489
548
  }], options: [{
490
549
  type: Input,
491
550
  args: ['p-options']
551
+ }], fieldLabel: [{
552
+ type: Input,
553
+ args: ['p-field-label']
554
+ }], fieldValue: [{
555
+ type: Input,
556
+ args: ['p-field-value']
492
557
  }], onKeydown: [{
493
558
  type: HostListener,
494
559
  args: ['keydown', ['$event']]
495
560
  }] }); })();
496
- //# 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  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  ContentChild,\n  Component,\n  DoCheck,\n  ElementRef,\n  forwardRef,\n  HostListener,\n  IterableDiffers,\n  Renderer2,\n  ViewChild,\n  Input,\n  Output,\n  EventEmitter\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, NG_VALIDATORS, AbstractControl } from '@angular/forms';\n\nimport { isMobile, removeDuplicatedOptions, removeUndefinedAndNullOptions, validValue } from '../../../utils/util';\nimport { PoControlPositionService } from './../../../services/po-control-position/po-control-position.service';\nimport { PoKeyCodeEnum } from './../../../enums/po-key-code.enum';\n\nimport { PoSelectOption } from './po-select-option.interface';\nimport { PoFieldValidateModel } from '../po-field-validate.model';\nimport { InputBoolean } from '../../../decorators';\n\nconst poSelectContentOffset = 8;\nconst poSelectContentPositionDefault = 'bottom';\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 * @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 _options: Array<PoSelectOption>;\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<PoSelectOption>) {\n    this._options = options;\n    removeDuplicatedOptions(this._options);\n    removeUndefinedAndNullOptions(this._options);\n    this.onUpdateOptions();\n  }\n\n  get options() {\n    return this._options;\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    }\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: PoSelectOption) {\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: PoSelectOption = 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: PoSelectOption): void {\n    if (this.selectedValue !== option.value) {\n      this.selectedValue = option.value;\n      this.selectElement.nativeElement.value = option.value;\n      this.updateModel(option.value);\n      this.displayValue = option.label;\n      this.emitChange(option.value);\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: PoSelectOption = this.findOptionValue(value);\n\n    if (optionFound) {\n      this.selectElement.nativeElement.value = optionFound.value;\n      this.selectedValue = optionFound.value;\n      this.displayValue = optionFound.label;\n      this.setScrollPosition(optionFound.value);\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: PoSelectOption = 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","<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 *ngFor=\"let option of options\" [disabled]=\"readonly\" [value]=\"option.value\" (click)=\"onOptionClick(option)\">\n      {{ option?.label }}\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.value\"\n        [value]=\"option.value\"\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?.label }}</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"]}
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"]}
@@ -4,9 +4,14 @@ import { PoFieldModel } from '../po-field.model';
4
4
  import { PoKeyCodeEnum } from './../../../enums/po-key-code.enum';
5
5
  import { PoSwitchLabelPosition } from './po-switch-label-position.enum';
6
6
  import * as i0 from "@angular/core";
7
- import * as i1 from "../po-field-container/po-field-container-bottom/po-field-container-bottom.component";
8
- import * as i2 from "../po-field-container/po-field-container.component";
7
+ import * as i1 from "@angular/common";
8
+ import * as i2 from "../po-field-container/po-field-container-bottom/po-field-container-bottom.component";
9
+ import * as i3 from "../po-field-container/po-field-container.component";
10
+ import * as i4 from "../../po-icon/po-icon.component";
9
11
  const _c0 = ["switchContainer"];
12
+ function PoSwitchComponent_po_icon_7_Template(rf, ctx) { if (rf & 1) {
13
+ i0.ɵɵelement(0, "po-icon", 9);
14
+ } }
10
15
  /**
11
16
  * @docsExtends PoFieldModel
12
17
  *
@@ -15,13 +20,24 @@ const _c0 = ["switchContainer"];
15
20
  * O componente `po-switch` é um [checkbox](/documentation/po-checkbox-group) mais intuitivo, pois faz analogia a um interruptor.
16
21
  * Deve ser usado quando deseja-se transmitir a ideia de ligar / desligar uma funcionalidade específica.
17
22
  *
18
- * Pode-se ligar ou deligar o botão utilizando a tecla de espaço ou o clique do mouse.
23
+ * Pode-se ligar ou desligar o switch utilizando a tecla de espaço ou o clique do mouse.
19
24
  *
20
25
  * O texto exibido pode ser alterado de acordo com o valor setado aumentando as possibilidades de uso do componente,
21
26
  * portanto, recomenda-se informar textos que contextualizem seu uso para que facilite a compreensão do usuário.
22
27
  *
23
28
  * > O componente não altera o valor incial informado no *model*, portanto indica-se inicializa-lo caso ter necessidade.
24
29
  *
30
+ * #### Boas práticas
31
+ *
32
+ * - Evite `labels` extensos que quebram o layout do `po-switch`, use `labels` diretos, curtos e intuitivos.
33
+ *
34
+ * #### Acessibilidade tratada no componente
35
+ *
36
+ * Algumas diretrizes de acessibilidade já são tratadas no componente, internamente, e não podem ser alteradas pelo proprietário do conteúdo. São elas:
37
+ *
38
+ * - Quando em foco, o switch é ativado usando a tecla de Espaço. [W3C WAI-ARIA 3.5 Switch - Keyboard Interaction](https://www.w3.org/WAI/ARIA/apg/patterns/switch/#keyboard-interaction-19)
39
+ * - A área do foco precisar ter uma espessura de pelo menos 2 pixels CSS e o foco não pode ficar escondido por outros elementos da tela. [WCAG 2.4.12: Focus Appearance](https://www.w3.org/WAI/WCAG22/Understanding/focus-appearance-enhanced)
40
+ *
25
41
  * @example
26
42
  *
27
43
  * <example name="po-switch-basic" title="PO Switch Basic">
@@ -127,16 +143,6 @@ export class PoSwitchComponent extends PoFieldModel {
127
143
  return 'right';
128
144
  }
129
145
  }
130
- getSwitchPosition() {
131
- switch (this.labelPosition) {
132
- case PoSwitchLabelPosition.Left:
133
- return 'right';
134
- case PoSwitchLabelPosition.Right:
135
- return 'left';
136
- default:
137
- return 'left';
138
- }
139
- }
140
146
  onKeyDown(event) {
141
147
  if (event.which === PoKeyCodeEnum.space || event.keyCode === PoKeyCodeEnum.space) {
142
148
  event.preventDefault();
@@ -174,34 +180,32 @@ PoSwitchComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoSwitchC
174
180
  useExisting: forwardRef(() => PoSwitchComponent),
175
181
  multi: true
176
182
  }
177
- ]), i0.ɵɵInheritDefinitionFeature], decls: 9, vars: 25, consts: [[3, "p-label", "p-help"], [1, "po-field-container-content", "po-switch-content"], [1, "po-switch-container", "po-clickable", 3, "tabindex", "click", "keydown", "blur"], ["switchContainer", ""], [1, "po-switch-button"], [3, "click"]], template: function PoSwitchComponent_Template(rf, ctx) { if (rf & 1) {
178
- i0.ɵɵelementStart(0, "po-field-container", 0)(1, "div", 1)(2, "div", 2, 3);
179
- i0.ɵɵlistener("click", function PoSwitchComponent_Template_div_click_2_listener() { return ctx.eventClick(); })("keydown", function PoSwitchComponent_Template_div_keydown_2_listener($event) { return ctx.onKeyDown($event); })("blur", function PoSwitchComponent_Template_div_blur_2_listener() { return ctx.onBlur(); });
180
- i0.ɵɵelementStart(4, "div", 4);
181
- i0.ɵɵelement(5, "span");
182
- i0.ɵɵelementEnd()();
183
- i0.ɵɵelementStart(6, "span", 5);
184
- i0.ɵɵlistener("click", function PoSwitchComponent_Template_span_click_6_listener() { return ctx.eventClick(); });
185
- i0.ɵɵtext(7);
186
- i0.ɵɵelementEnd()();
187
- i0.ɵɵelement(8, "po-field-container-bottom");
183
+ ]), i0.ɵɵInheritDefinitionFeature], decls: 11, vars: 10, consts: [[3, "p-label", "p-help"], [1, "po-field-container-content"], [1, "po-switch"], ["role", "switch", 1, "po-switch-container", 3, "tabindex", "blur", "click", "keydown"], ["switchContainer", ""], [1, "po-switch-track"], [1, "po-switch-toggle"], ["class", "po-switch-icon", "p-icon", "po-icon-ok", 4, "ngIf"], [1, "po-switch-label", 3, "click"], ["p-icon", "po-icon-ok", 1, "po-switch-icon"]], template: function PoSwitchComponent_Template(rf, ctx) { if (rf & 1) {
184
+ i0.ɵɵelementStart(0, "po-field-container", 0)(1, "div", 1)(2, "div", 2)(3, "div", 3, 4);
185
+ i0.ɵɵlistener("blur", function PoSwitchComponent_Template_div_blur_3_listener() { return ctx.onBlur(); })("click", function PoSwitchComponent_Template_div_click_3_listener() { return ctx.eventClick(); })("keydown", function PoSwitchComponent_Template_div_keydown_3_listener($event) { return ctx.onKeyDown($event); });
186
+ i0.ɵɵelementStart(5, "div", 5)(6, "div", 6);
187
+ i0.ɵɵtemplate(7, PoSwitchComponent_po_icon_7_Template, 1, 0, "po-icon", 7);
188
+ i0.ɵɵelementEnd()()();
189
+ i0.ɵɵelementStart(8, "span", 8);
190
+ i0.ɵɵlistener("click", function PoSwitchComponent_Template_span_click_8_listener() { return ctx.eventClick(); });
191
+ i0.ɵɵtext(9);
192
+ i0.ɵɵelementEnd()()();
193
+ i0.ɵɵelement(10, "po-field-container-bottom");
188
194
  i0.ɵɵelementEnd();
189
195
  } if (rf & 2) {
190
196
  i0.ɵɵproperty("p-label", ctx.label)("p-help", ctx.help);
191
197
  i0.ɵɵadvance(1);
192
198
  i0.ɵɵattribute("name", ctx.name);
193
199
  i0.ɵɵadvance(1);
194
- i0.ɵɵclassProp("po-switch-container-disabled", ctx.disabled)("po-switch-container-off", ctx.value === false && !ctx.disabled)("po-switch-container-on", ctx.value === true && !ctx.disabled)("po-switch-container-right", ctx.getSwitchPosition() === "right");
200
+ i0.ɵɵattribute("data-label-position", ctx.getLabelPosition());
201
+ i0.ɵɵadvance(1);
195
202
  i0.ɵɵproperty("tabindex", ctx.disabled ? -1 : 0);
203
+ i0.ɵɵattribute("aria-checked", ctx.value)("aria-disabled", ctx.disabled)("aria-label", ctx.value === true ? ctx.labelOn : ctx.labelOff);
204
+ i0.ɵɵadvance(4);
205
+ i0.ɵɵproperty("ngIf", ctx.value === true);
196
206
  i0.ɵɵadvance(2);
197
- i0.ɵɵclassProp("po-switch-button-on", ctx.value === true)("po-switch-button-off", ctx.value === false)("po-switch-button-disabled", ctx.disabled);
198
- i0.ɵɵadvance(1);
199
- i0.ɵɵclassMapInterpolate1("po-icon po-icon-", ctx.value === true ? "ok" : "close", "");
200
- i0.ɵɵadvance(1);
201
- i0.ɵɵclassMapInterpolate1("po-switch-label po-clickable po-switch-label-", ctx.getLabelPosition(), "");
202
- i0.ɵɵadvance(1);
203
207
  i0.ɵɵtextInterpolate1(" ", ctx.value === true ? ctx.labelOn : ctx.labelOff, " ");
204
- } }, dependencies: [i1.PoFieldContainerBottomComponent, i2.PoFieldContainerComponent], encapsulation: 2, changeDetection: 0 });
208
+ } }, dependencies: [i1.NgIf, i2.PoFieldContainerBottomComponent, i3.PoFieldContainerComponent, i4.PoIconComponent], encapsulation: 2, changeDetection: 0 });
205
209
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoSwitchComponent, [{
206
210
  type: Component,
207
211
  args: [{ selector: 'po-switch', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
@@ -210,7 +214,7 @@ PoSwitchComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoSwitchC
210
214
  useExisting: forwardRef(() => PoSwitchComponent),
211
215
  multi: true
212
216
  }
213
- ], template: "<po-field-container [p-label]=\"label\" [p-help]=\"help\">\n <div class=\"po-field-container-content po-switch-content\" [attr.name]=\"name\">\n <div\n class=\"po-switch-container po-clickable\"\n #switchContainer\n [class.po-switch-container-disabled]=\"disabled\"\n [class.po-switch-container-off]=\"value === false && !disabled\"\n [class.po-switch-container-on]=\"value === true && !disabled\"\n [class.po-switch-container-right]=\"getSwitchPosition() === 'right'\"\n [tabindex]=\"disabled ? -1 : 0\"\n (click)=\"eventClick()\"\n (keydown)=\"onKeyDown($event)\"\n (blur)=\"onBlur()\"\n >\n <div\n class=\"po-switch-button\"\n [class.po-switch-button-on]=\"value === true\"\n [class.po-switch-button-off]=\"value === false\"\n [class.po-switch-button-disabled]=\"disabled\"\n >\n <span class=\"po-icon po-icon-{{ value === true ? 'ok' : 'close' }}\"></span>\n </div>\n </div>\n\n <span class=\"po-switch-label po-clickable po-switch-label-{{ getLabelPosition() }}\" (click)=\"eventClick()\">\n {{ value === true ? labelOn : labelOff }}\n </span>\n </div>\n\n <po-field-container-bottom></po-field-container-bottom>\n</po-field-container>\n" }]
217
+ ], template: "<po-field-container [p-label]=\"label\" [p-help]=\"help\">\n <div class=\"po-field-container-content\" [attr.name]=\"name\">\n <div class=\"po-switch\" [attr.data-label-position]=\"getLabelPosition()\">\n <div\n #switchContainer\n class=\"po-switch-container\"\n role=\"switch\"\n [attr.aria-checked]=\"value\"\n [attr.aria-disabled]=\"disabled\"\n [attr.aria-label]=\"value === true ? labelOn : labelOff\"\n [tabindex]=\"disabled ? -1 : 0\"\n (blur)=\"onBlur()\"\n (click)=\"eventClick()\"\n (keydown)=\"onKeyDown($event)\"\n >\n <div class=\"po-switch-track\">\n <div class=\"po-switch-toggle\">\n <po-icon *ngIf=\"value === true\" class=\"po-switch-icon\" p-icon=\"po-icon-ok\"></po-icon>\n </div>\n </div>\n </div>\n\n <span class=\"po-switch-label\" (click)=\"eventClick()\">\n {{ value === true ? labelOn : labelOff }}\n </span>\n </div>\n </div>\n\n <po-field-container-bottom></po-field-container-bottom>\n</po-field-container>\n" }]
214
218
  }], function () { return [{ type: i0.ChangeDetectorRef }]; }, { switchContainer: [{
215
219
  type: ViewChild,
216
220
  args: ['switchContainer', { static: true }]
@@ -224,4 +228,4 @@ PoSwitchComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoSwitchC
224
228
  type: Input,
225
229
  args: ['p-label-on']
226
230
  }] }); })();
227
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-switch.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-switch/po-switch.component.ts","../../../../../../../projects/ui/src/lib/components/po-field/po-switch/po-switch.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,uBAAuB,EAEvB,SAAS,EAET,UAAU,EACV,KAAK,EACL,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAEnD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAElE,OAAO,EAAE,qBAAqB,EAAE,MAAM,iCAAiC,CAAC;;;;;AAExE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsCG;AAaH,MAAM,OAAO,iBAAkB,SAAQ,YAAqB;IAoD1D,YAAoB,cAAiC;QACnD,KAAK,EAAE,CAAC;QADU,mBAAc,GAAd,cAAc,CAAmB;QAjDrD,UAAK,GAAG,KAAK,CAAC;QAEN,cAAS,GAAW,OAAO,CAAC;QAC5B,aAAQ,GAAW,MAAM,CAAC;QAC1B,mBAAc,GAA0B,qBAAqB,CAAC,KAAK,CAAC;IA+C5E,CAAC;IA7CD;;;;;;;;OAQG;IACH,IAA+B,aAAa,CAAC,QAA+B;QAC1E,IAAI,CAAC,cAAc,GAAG,QAAQ,IAAI,qBAAqB,CAAC,CAAC,CAAC,QAAQ,CAAM,QAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,qBAAqB,CAAC,KAAK,CAAC;IACtH,CAAC;IAED,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IAED;;;;OAIG;IACH,IAA0B,QAAQ,CAAC,KAAa;QAC9C,IAAI,CAAC,SAAS,GAAG,KAAK,IAAI,OAAO,CAAC;IACpC,CAAC;IAED,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAED;;;;OAIG;IACH,IAAyB,OAAO,CAAC,KAAa;QAC5C,IAAI,CAAC,QAAQ,GAAG,KAAK,IAAI,MAAM,CAAC;IAClC,CAAC;IAED,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAMD;;;;;;;;;;;;;;;;OAgBG;IACH,KAAK;QACH,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;SAC5C;IACH,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,SAAS,EAAE,EAAE,CAAC;IACrB,CAAC;IAED,gBAAgB;QACd,QAAQ,IAAI,CAAC,aAAa,EAAE;YAC1B,KAAK,qBAAqB,CAAC,IAAI;gBAC7B,OAAO,MAAM,CAAC;YAChB,KAAK,qBAAqB,CAAC,KAAK;gBAC9B,OAAO,OAAO,CAAC;YACjB;gBACE,OAAO,OAAO,CAAC;SAClB;IACH,CAAC;IAED,iBAAiB;QACf,QAAQ,IAAI,CAAC,aAAa,EAAE;YAC1B,KAAK,qBAAqB,CAAC,IAAI;gBAC7B,OAAO,OAAO,CAAC;YACjB,KAAK,qBAAqB,CAAC,KAAK;gBAC9B,OAAO,MAAM,CAAC;YAChB;gBACE,OAAO,MAAM,CAAC;SACjB;IACH,CAAC;IAED,SAAS,CAAC,KAAK;QACb,IAAI,KAAK,CAAC,KAAK,KAAK,aAAa,CAAC,KAAK,IAAI,KAAK,CAAC,OAAO,KAAK,aAAa,CAAC,KAAK,EAAE;YAChF,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,IAAI,CAAC,UAAU,EAAE,CAAC;SACnB;IACH,CAAC;IAED,WAAW,CAAC,KAAU;QACpB,IAAI,IAAI,CAAC,KAAK,KAAK,KAAK,EAAE;YACxB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;YACnB,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;YACxB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SAC7B;IACH,CAAC;IAED,UAAU;QACR,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SAC/B;IACH,CAAC;IAED,YAAY,CAAC,KAAU;QACrB,IAAI,KAAK,KAAK,IAAI,CAAC,KAAK,EAAE;YACxB,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC;YAErB,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;SACpC;IACH,CAAC;;kFApIU,iBAAiB;oEAAjB,iBAAiB;;;;;uLARjB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC;gBAChD,KAAK,EAAE,IAAI;aACZ;SACF;QClEH,6CAAsD,aAAA,gBAAA;QAUhD,2FAAS,gBAAY,IAAC,wFACX,qBAAiB,IADN,4EAEd,YAAQ,IAFM;QAItB,8BAKC;QACC,uBAA2E;QAC7E,iBAAM,EAAA;QAGR,+BAA2G;QAAvB,4FAAS,gBAAY,IAAC;QACxG,YACF;QAAA,iBAAO,EAAA;QAGT,4CAAuD;QACzD,iBAAqB;;QA9BD,mCAAiB,oBAAA;QACuB,eAAkB;QAAlB,gCAAkB;QAIxE,eAA+C;QAA/C,4DAA+C,iEAAA,+DAAA,kEAAA;QAI/C,gDAA8B;QAO5B,eAA4C;QAA5C,yDAA4C,6CAAA,2CAAA;QAItC,eAA6D;QAA7D,sFAA6D;QAIjE,eAA6E;QAA7E,sGAA6E;QACjF,eACF;QADE,gFACF;;uFD0CS,iBAAiB;cAZ7B,SAAS;2BACE,WAAW,mBAEJ,uBAAuB,CAAC,MAAM,aACpC;oBACT;wBACE,OAAO,EAAE,iBAAiB;wBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,kBAAkB,CAAC;wBAChD,KAAK,EAAE,IAAI;qBACZ;iBACF;oEAG+C,eAAe;kBAA9D,SAAS;mBAAC,iBAAiB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;YAiBf,aAAa;kBAA3C,KAAK;mBAAC,kBAAkB;YAaC,QAAQ;kBAAjC,KAAK;mBAAC,aAAa;YAaK,OAAO;kBAA/B,KAAK;mBAAC,YAAY","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  forwardRef,\n  Input,\n  ViewChild\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { PoFieldModel } from '../po-field.model';\nimport { PoKeyCodeEnum } from './../../../enums/po-key-code.enum';\n\nimport { PoSwitchLabelPosition } from './po-switch-label-position.enum';\n\n/**\n * @docsExtends PoFieldModel\n *\n * @description\n *\n * O componente `po-switch` é um [checkbox](/documentation/po-checkbox-group) mais intuitivo, pois faz analogia a um interruptor.\n * Deve ser usado quando deseja-se transmitir a ideia de ligar / desligar uma funcionalidade específica.\n *\n * Pode-se ligar ou deligar o botão utilizando a tecla de espaço ou o clique do mouse.\n *\n * O texto exibido pode ser alterado de acordo com o valor setado aumentando as possibilidades de uso do componente,\n * portanto, recomenda-se informar textos que contextualizem seu uso para que facilite a compreensão do usuário.\n *\n * > O componente não altera o valor incial informado no *model*, portanto indica-se inicializa-lo caso ter necessidade.\n *\n * @example\n *\n * <example name=\"po-switch-basic\" title=\"PO Switch Basic\">\n *   <file name=\"sample-po-switch-basic/sample-po-switch-basic.component.html\"> </file>\n *   <file name=\"sample-po-switch-basic/sample-po-switch-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-switch-labs\" title=\"PO Switch Labs\">\n *   <file name=\"sample-po-switch-labs/sample-po-switch-labs.component.html\"> </file>\n *   <file name=\"sample-po-switch-labs/sample-po-switch-labs.component.ts\"> </file>\n *   <file name=\"sample-po-switch-labs/sample-po-switch-labs.component.e2e-spec.ts\"> </file>\n *   <file name=\"sample-po-switch-labs/sample-po-switch-labs.component.po.ts\"> </file>\n * </example>\n *\n * <example name=\"po-switch-order\" title=\"PO Switch - Order Summary\">\n *   <file name=\"sample-po-switch-order/sample-po-switch-order.component.html\"> </file>\n *   <file name=\"sample-po-switch-order/sample-po-switch-order.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-switch-order-reactive-form\" title=\"PO Switch - Order Summary Reactive Form\">\n *   <file name=\"sample-po-switch-order-reactive-form/sample-po-switch-order-reactive-form.component.html\"> </file>\n *   <file name=\"sample-po-switch-order-reactive-form/sample-po-switch-order-reactive-form.component.ts\"> </file>\n * </example>\n */\n@Component({\n  selector: 'po-switch',\n  templateUrl: './po-switch.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PoSwitchComponent),\n      multi: true\n    }\n  ]\n})\nexport class PoSwitchComponent extends PoFieldModel<boolean> {\n  @ViewChild('switchContainer', { static: true }) switchContainer: ElementRef;\n\n  value = false;\n\n  private _labelOff: string = 'false';\n  private _labelOn: string = 'true';\n  private _labelPosition: PoSwitchLabelPosition = PoSwitchLabelPosition.Right;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Posição de exibição do rótulo.\n   *\n   * > Por padrão exibe à direita.\n   */\n  @Input('p-label-position') set labelPosition(position: PoSwitchLabelPosition) {\n    this._labelPosition = position in PoSwitchLabelPosition ? parseInt(<any>position, 10) : PoSwitchLabelPosition.Right;\n  }\n\n  get labelPosition() {\n    return this._labelPosition;\n  }\n\n  /**\n   * Texto exibido quando o valor do componente for `false`.\n   *\n   * @default `false`\n   */\n  @Input('p-label-off') set labelOff(label: string) {\n    this._labelOff = label || 'false';\n  }\n\n  get labelOff() {\n    return this._labelOff;\n  }\n\n  /**\n   * Texto exibido quando o valor do componente for `true`.\n   *\n   * @default `true`\n   */\n  @Input('p-label-on') set labelOn(label: string) {\n    this._labelOn = label || 'true';\n  }\n\n  get labelOn() {\n    return this._labelOn;\n  }\n\n  constructor(private changeDetector: ChangeDetectorRef) {\n    super();\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 { PoSwitchComponent } from '@po-ui/ng-components';\n   *\n   * ...\n   *\n   * @ViewChild(PoSwitchComponent, { static: true }) switch: PoSwitchComponent;\n   *\n   * focusSwitch() {\n   *   this.switch.focus();\n   * }\n   * ```\n   */\n  focus() {\n    if (!this.disabled) {\n      this.switchContainer.nativeElement.focus();\n    }\n  }\n\n  onBlur() {\n    this.onTouched?.();\n  }\n\n  getLabelPosition() {\n    switch (this.labelPosition) {\n      case PoSwitchLabelPosition.Left:\n        return 'left';\n      case PoSwitchLabelPosition.Right:\n        return 'right';\n      default:\n        return 'right';\n    }\n  }\n\n  getSwitchPosition() {\n    switch (this.labelPosition) {\n      case PoSwitchLabelPosition.Left:\n        return 'right';\n      case PoSwitchLabelPosition.Right:\n        return 'left';\n      default:\n        return 'left';\n    }\n  }\n\n  onKeyDown(event) {\n    if (event.which === PoKeyCodeEnum.space || event.keyCode === PoKeyCodeEnum.space) {\n      event.preventDefault();\n      this.eventClick();\n    }\n  }\n\n  changeValue(value: any) {\n    if (this.value !== value) {\n      this.value = value;\n      this.updateModel(value);\n      this.emitChange(this.value);\n    }\n  }\n\n  eventClick() {\n    if (!this.disabled) {\n      this.changeValue(!this.value);\n    }\n  }\n\n  onWriteValue(value: any): void {\n    if (value !== this.value) {\n      this.value = !!value;\n\n      this.changeDetector.markForCheck();\n    }\n  }\n}\n","<po-field-container [p-label]=\"label\" [p-help]=\"help\">\n  <div class=\"po-field-container-content po-switch-content\" [attr.name]=\"name\">\n    <div\n      class=\"po-switch-container po-clickable\"\n      #switchContainer\n      [class.po-switch-container-disabled]=\"disabled\"\n      [class.po-switch-container-off]=\"value === false && !disabled\"\n      [class.po-switch-container-on]=\"value === true && !disabled\"\n      [class.po-switch-container-right]=\"getSwitchPosition() === 'right'\"\n      [tabindex]=\"disabled ? -1 : 0\"\n      (click)=\"eventClick()\"\n      (keydown)=\"onKeyDown($event)\"\n      (blur)=\"onBlur()\"\n    >\n      <div\n        class=\"po-switch-button\"\n        [class.po-switch-button-on]=\"value === true\"\n        [class.po-switch-button-off]=\"value === false\"\n        [class.po-switch-button-disabled]=\"disabled\"\n      >\n        <span class=\"po-icon po-icon-{{ value === true ? 'ok' : 'close' }}\"></span>\n      </div>\n    </div>\n\n    <span class=\"po-switch-label po-clickable po-switch-label-{{ getLabelPosition() }}\" (click)=\"eventClick()\">\n      {{ value === true ? labelOn : labelOff }}\n    </span>\n  </div>\n\n  <po-field-container-bottom></po-field-container-bottom>\n</po-field-container>\n"]}
231
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-switch.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-switch/po-switch.component.ts","../../../../../../../projects/ui/src/lib/components/po-field/po-switch/po-switch.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EAEvB,SAAS,EAET,UAAU,EACV,KAAK,EACL,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAEnD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAElE,OAAO,EAAE,qBAAqB,EAAE,MAAM,iCAAiC,CAAC;;;;;;;;ICG5D,6BAAqF;;ADDjG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAiDG;AAaH,MAAM,OAAO,iBAAkB,SAAQ,YAAqB;IAoD1D,YAAoB,cAAiC;QACnD,KAAK,EAAE,CAAC;QADU,mBAAc,GAAd,cAAc,CAAmB;QAjDrD,UAAK,GAAG,KAAK,CAAC;QAEN,cAAS,GAAW,OAAO,CAAC;QAC5B,aAAQ,GAAW,MAAM,CAAC;QAC1B,mBAAc,GAA0B,qBAAqB,CAAC,KAAK,CAAC;IA+C5E,CAAC;IA7CD;;;;;;;;OAQG;IACH,IAA+B,aAAa,CAAC,QAA+B;QAC1E,IAAI,CAAC,cAAc,GAAG,QAAQ,IAAI,qBAAqB,CAAC,CAAC,CAAC,QAAQ,CAAM,QAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,qBAAqB,CAAC,KAAK,CAAC;IACtH,CAAC;IAED,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IAED;;;;OAIG;IACH,IAA0B,QAAQ,CAAC,KAAa;QAC9C,IAAI,CAAC,SAAS,GAAG,KAAK,IAAI,OAAO,CAAC;IACpC,CAAC;IAED,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAED;;;;OAIG;IACH,IAAyB,OAAO,CAAC,KAAa;QAC5C,IAAI,CAAC,QAAQ,GAAG,KAAK,IAAI,MAAM,CAAC;IAClC,CAAC;IAED,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAMD;;;;;;;;;;;;;;;;OAgBG;IACH,KAAK;QACH,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;SAC5C;IACH,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,SAAS,EAAE,EAAE,CAAC;IACrB,CAAC;IAED,gBAAgB;QACd,QAAQ,IAAI,CAAC,aAAa,EAAE;YAC1B,KAAK,qBAAqB,CAAC,IAAI;gBAC7B,OAAO,MAAM,CAAC;YAChB,KAAK,qBAAqB,CAAC,KAAK;gBAC9B,OAAO,OAAO,CAAC;YACjB;gBACE,OAAO,OAAO,CAAC;SAClB;IACH,CAAC;IAED,SAAS,CAAC,KAAK;QACb,IAAI,KAAK,CAAC,KAAK,KAAK,aAAa,CAAC,KAAK,IAAI,KAAK,CAAC,OAAO,KAAK,aAAa,CAAC,KAAK,EAAE;YAChF,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,IAAI,CAAC,UAAU,EAAE,CAAC;SACnB;IACH,CAAC;IAED,WAAW,CAAC,KAAU;QACpB,IAAI,IAAI,CAAC,KAAK,KAAK,KAAK,EAAE;YACxB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;YACnB,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;YACxB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SAC7B;IACH,CAAC;IAED,UAAU;QACR,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SAC/B;IACH,CAAC;IAED,YAAY,CAAC,KAAU;QACrB,IAAI,KAAK,KAAK,IAAI,CAAC,KAAK,EAAE;YACxB,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC;YAErB,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;SACpC;IACH,CAAC;;kFAzHU,iBAAiB;oEAAjB,iBAAiB;;;;;uLARjB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC;gBAChD,KAAK,EAAE,IAAI;aACZ;SACF;QC5EH,6CAAsD,aAAA,aAAA,gBAAA;QAW9C,yFAAQ,YAAQ,IAAC,8EACR,gBAAY,IADJ,wFAEN,qBAAiB,IAFX;QAIjB,8BAA6B,aAAA;QAEzB,0EAAqF;QACvF,iBAAM,EAAA,EAAA;QAIV,+BAAqD;QAAvB,4FAAS,gBAAY,IAAC;QAClD,YACF;QAAA,iBAAO,EAAA,EAAA;QAIX,6CAAuD;QACzD,iBAAqB;;QA7BD,mCAAiB,oBAAA;QACK,eAAkB;QAAlB,gCAAkB;QACjC,eAA+C;QAA/C,6DAA+C;QAQlE,eAA8B;QAA9B,gDAA8B;QAH9B,yCAA2B,+BAAA,+DAAA;QAUb,eAAoB;QAApB,yCAAoB;QAMlC,eACF;QADE,gFACF;;uFDsDO,iBAAiB;cAZ7B,SAAS;2BACE,WAAW,mBAEJ,uBAAuB,CAAC,MAAM,aACpC;oBACT;wBACE,OAAO,EAAE,iBAAiB;wBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,kBAAkB,CAAC;wBAChD,KAAK,EAAE,IAAI;qBACZ;iBACF;oEAG+C,eAAe;kBAA9D,SAAS;mBAAC,iBAAiB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;YAiBf,aAAa;kBAA3C,KAAK;mBAAC,kBAAkB;YAaC,QAAQ;kBAAjC,KAAK;mBAAC,aAAa;YAaK,OAAO;kBAA/B,KAAK;mBAAC,YAAY","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  forwardRef,\n  Input,\n  ViewChild\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { PoFieldModel } from '../po-field.model';\nimport { PoKeyCodeEnum } from './../../../enums/po-key-code.enum';\n\nimport { PoSwitchLabelPosition } from './po-switch-label-position.enum';\n\n/**\n * @docsExtends PoFieldModel\n *\n * @description\n *\n * O componente `po-switch` é um [checkbox](/documentation/po-checkbox-group) mais intuitivo, pois faz analogia a um interruptor.\n * Deve ser usado quando deseja-se transmitir a ideia de ligar / desligar uma funcionalidade específica.\n *\n * Pode-se ligar ou desligar o switch utilizando a tecla de espaço ou o clique do mouse.\n *\n * O texto exibido pode ser alterado de acordo com o valor setado aumentando as possibilidades de uso do componente,\n * portanto, recomenda-se informar textos que contextualizem seu uso para que facilite a compreensão do usuário.\n *\n * > O componente não altera o valor incial informado no *model*, portanto indica-se inicializa-lo caso ter necessidade.\n *\n * #### Boas práticas\n *\n * - Evite `labels` extensos que quebram o layout do `po-switch`, use `labels` diretos, curtos e intuitivos.\n *\n * #### Acessibilidade tratada no componente\n *\n * Algumas diretrizes de acessibilidade já são tratadas no componente, internamente, e não podem ser alteradas pelo proprietário do conteúdo. São elas:\n *\n * - Quando em foco, o switch é ativado usando a tecla de Espaço. [W3C WAI-ARIA 3.5 Switch - Keyboard Interaction](https://www.w3.org/WAI/ARIA/apg/patterns/switch/#keyboard-interaction-19)\n * - A área do foco precisar ter uma espessura de pelo menos 2 pixels CSS e o foco não pode ficar escondido por outros elementos da tela. [WCAG 2.4.12: Focus Appearance](https://www.w3.org/WAI/WCAG22/Understanding/focus-appearance-enhanced)\n *\n * @example\n *\n * <example name=\"po-switch-basic\" title=\"PO Switch Basic\">\n *   <file name=\"sample-po-switch-basic/sample-po-switch-basic.component.html\"> </file>\n *   <file name=\"sample-po-switch-basic/sample-po-switch-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-switch-labs\" title=\"PO Switch Labs\">\n *   <file name=\"sample-po-switch-labs/sample-po-switch-labs.component.html\"> </file>\n *   <file name=\"sample-po-switch-labs/sample-po-switch-labs.component.ts\"> </file>\n *   <file name=\"sample-po-switch-labs/sample-po-switch-labs.component.e2e-spec.ts\"> </file>\n *   <file name=\"sample-po-switch-labs/sample-po-switch-labs.component.po.ts\"> </file>\n * </example>\n *\n * <example name=\"po-switch-order\" title=\"PO Switch - Order Summary\">\n *   <file name=\"sample-po-switch-order/sample-po-switch-order.component.html\"> </file>\n *   <file name=\"sample-po-switch-order/sample-po-switch-order.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-switch-order-reactive-form\" title=\"PO Switch - Order Summary Reactive Form\">\n *   <file name=\"sample-po-switch-order-reactive-form/sample-po-switch-order-reactive-form.component.html\"> </file>\n *   <file name=\"sample-po-switch-order-reactive-form/sample-po-switch-order-reactive-form.component.ts\"> </file>\n * </example>\n */\n@Component({\n  selector: 'po-switch',\n  templateUrl: './po-switch.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PoSwitchComponent),\n      multi: true\n    }\n  ]\n})\nexport class PoSwitchComponent extends PoFieldModel<boolean> {\n  @ViewChild('switchContainer', { static: true }) switchContainer: ElementRef;\n\n  value = false;\n\n  private _labelOff: string = 'false';\n  private _labelOn: string = 'true';\n  private _labelPosition: PoSwitchLabelPosition = PoSwitchLabelPosition.Right;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Posição de exibição do rótulo.\n   *\n   * > Por padrão exibe à direita.\n   */\n  @Input('p-label-position') set labelPosition(position: PoSwitchLabelPosition) {\n    this._labelPosition = position in PoSwitchLabelPosition ? parseInt(<any>position, 10) : PoSwitchLabelPosition.Right;\n  }\n\n  get labelPosition() {\n    return this._labelPosition;\n  }\n\n  /**\n   * Texto exibido quando o valor do componente for `false`.\n   *\n   * @default `false`\n   */\n  @Input('p-label-off') set labelOff(label: string) {\n    this._labelOff = label || 'false';\n  }\n\n  get labelOff() {\n    return this._labelOff;\n  }\n\n  /**\n   * Texto exibido quando o valor do componente for `true`.\n   *\n   * @default `true`\n   */\n  @Input('p-label-on') set labelOn(label: string) {\n    this._labelOn = label || 'true';\n  }\n\n  get labelOn() {\n    return this._labelOn;\n  }\n\n  constructor(private changeDetector: ChangeDetectorRef) {\n    super();\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 { PoSwitchComponent } from '@po-ui/ng-components';\n   *\n   * ...\n   *\n   * @ViewChild(PoSwitchComponent, { static: true }) switch: PoSwitchComponent;\n   *\n   * focusSwitch() {\n   *   this.switch.focus();\n   * }\n   * ```\n   */\n  focus() {\n    if (!this.disabled) {\n      this.switchContainer.nativeElement.focus();\n    }\n  }\n\n  onBlur() {\n    this.onTouched?.();\n  }\n\n  getLabelPosition() {\n    switch (this.labelPosition) {\n      case PoSwitchLabelPosition.Left:\n        return 'left';\n      case PoSwitchLabelPosition.Right:\n        return 'right';\n      default:\n        return 'right';\n    }\n  }\n\n  onKeyDown(event) {\n    if (event.which === PoKeyCodeEnum.space || event.keyCode === PoKeyCodeEnum.space) {\n      event.preventDefault();\n      this.eventClick();\n    }\n  }\n\n  changeValue(value: any) {\n    if (this.value !== value) {\n      this.value = value;\n      this.updateModel(value);\n      this.emitChange(this.value);\n    }\n  }\n\n  eventClick() {\n    if (!this.disabled) {\n      this.changeValue(!this.value);\n    }\n  }\n\n  onWriteValue(value: any): void {\n    if (value !== this.value) {\n      this.value = !!value;\n\n      this.changeDetector.markForCheck();\n    }\n  }\n}\n","<po-field-container [p-label]=\"label\" [p-help]=\"help\">\n  <div class=\"po-field-container-content\" [attr.name]=\"name\">\n    <div class=\"po-switch\" [attr.data-label-position]=\"getLabelPosition()\">\n      <div\n        #switchContainer\n        class=\"po-switch-container\"\n        role=\"switch\"\n        [attr.aria-checked]=\"value\"\n        [attr.aria-disabled]=\"disabled\"\n        [attr.aria-label]=\"value === true ? labelOn : labelOff\"\n        [tabindex]=\"disabled ? -1 : 0\"\n        (blur)=\"onBlur()\"\n        (click)=\"eventClick()\"\n        (keydown)=\"onKeyDown($event)\"\n      >\n        <div class=\"po-switch-track\">\n          <div class=\"po-switch-toggle\">\n            <po-icon *ngIf=\"value === true\" class=\"po-switch-icon\" p-icon=\"po-icon-ok\"></po-icon>\n          </div>\n        </div>\n      </div>\n\n      <span class=\"po-switch-label\" (click)=\"eventClick()\">\n        {{ value === true ? labelOn : labelOff }}\n      </span>\n    </div>\n  </div>\n\n  <po-field-container-bottom></po-field-container-bottom>\n</po-field-container>\n"]}