@po-ui/ng-components 14.7.0 → 14.8.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 (99) hide show
  1. package/esm2020/lib/components/components.module.mjs +14 -7
  2. package/esm2020/lib/components/index.mjs +2 -1
  3. package/esm2020/lib/components/po-field/po-checkbox-group/po-checkbox-group-base.component.mjs +12 -2
  4. package/esm2020/lib/components/po-field/po-checkbox-group/po-checkbox-group.component.mjs +4 -4
  5. package/esm2020/lib/components/po-field/po-combo/po-combo-base.component.mjs +13 -3
  6. package/esm2020/lib/components/po-field/po-combo/po-combo.component.mjs +8 -6
  7. package/esm2020/lib/components/po-field/po-datepicker/po-datepicker-base.component.mjs +21 -3
  8. package/esm2020/lib/components/po-field/po-datepicker/po-datepicker.component.mjs +8 -7
  9. package/esm2020/lib/components/po-field/po-datepicker-range/po-datepicker-range-base.component.mjs +13 -3
  10. package/esm2020/lib/components/po-field/po-datepicker-range/po-datepicker-range.component.mjs +4 -4
  11. package/esm2020/lib/components/po-field/po-decimal/po-decimal.component.mjs +8 -7
  12. package/esm2020/lib/components/po-field/po-email/po-email.component.mjs +8 -6
  13. package/esm2020/lib/components/po-field/po-field-container/po-field-container-literals.mjs +9 -5
  14. package/esm2020/lib/components/po-field/po-field-container/po-field-container.component.mjs +60 -23
  15. package/esm2020/lib/components/po-field/po-field-container/po-field-container.module.mjs +5 -4
  16. package/esm2020/lib/components/po-field/po-field-validate.model.mjs +13 -3
  17. package/esm2020/lib/components/po-field/po-input/po-input-base.component.mjs +15 -4
  18. package/esm2020/lib/components/po-field/po-input/po-input.component.mjs +8 -6
  19. package/esm2020/lib/components/po-field/po-login/po-login.component.mjs +8 -6
  20. package/esm2020/lib/components/po-field/po-lookup/po-lookup-base.component.mjs +24 -6
  21. package/esm2020/lib/components/po-field/po-lookup/po-lookup.component.mjs +8 -8
  22. package/esm2020/lib/components/po-field/po-lookup/services/po-lookup-modal.service.mjs +7 -1
  23. package/esm2020/lib/components/po-field/po-multiselect/po-multiselect-base.component.mjs +15 -3
  24. package/esm2020/lib/components/po-field/po-multiselect/po-multiselect.component.mjs +4 -4
  25. package/esm2020/lib/components/po-field/po-number/po-number.component.mjs +8 -6
  26. package/esm2020/lib/components/po-field/po-password/po-password.component.mjs +8 -7
  27. package/esm2020/lib/components/po-field/po-radio/po-radio.component.mjs +39 -26
  28. package/esm2020/lib/components/po-field/po-radio-group/po-radio-group-base.component.mjs +13 -3
  29. package/esm2020/lib/components/po-field/po-radio-group/po-radio-group.component.mjs +4 -4
  30. package/esm2020/lib/components/po-field/po-rich-text/po-rich-text-base.component.mjs +13 -3
  31. package/esm2020/lib/components/po-field/po-rich-text/po-rich-text-body/po-rich-text-body.component.mjs +7 -4
  32. package/esm2020/lib/components/po-field/po-rich-text/po-rich-text.component.mjs +5 -5
  33. package/esm2020/lib/components/po-field/po-select/po-select.component.mjs +8 -7
  34. package/esm2020/lib/components/po-field/po-switch/po-switch.component.mjs +11 -7
  35. package/esm2020/lib/components/po-field/po-textarea/po-textarea-base.component.mjs +14 -5
  36. package/esm2020/lib/components/po-field/po-textarea/po-textarea.component.mjs +8 -6
  37. package/esm2020/lib/components/po-field/po-upload/po-upload-base.component.mjs +13 -3
  38. package/esm2020/lib/components/po-field/po-upload/po-upload.component.mjs +33 -32
  39. package/esm2020/lib/components/po-field/po-url/po-url.component.mjs +8 -6
  40. package/esm2020/lib/components/po-label/index.mjs +3 -0
  41. package/esm2020/lib/components/po-label/po-label.component.mjs +94 -0
  42. package/esm2020/lib/components/po-label/po-label.module.mjs +19 -0
  43. package/esm2020/lib/components/po-table/po-table-icon/po-table-icon.component.mjs +4 -4
  44. package/esm2020/lib/components/po-table/po-table.component.mjs +7 -7
  45. package/esm2020/lib/components/po-widget/po-widget-base.component.mjs +11 -2
  46. package/esm2020/lib/components/po-widget/po-widget.component.mjs +12 -4
  47. package/fesm2015/po-ui-ng-components.mjs +1482 -1128
  48. package/fesm2015/po-ui-ng-components.mjs.map +1 -1
  49. package/fesm2020/po-ui-ng-components.mjs +1469 -1129
  50. package/fesm2020/po-ui-ng-components.mjs.map +1 -1
  51. package/lib/components/components.module.d.ts +2 -1
  52. package/lib/components/index.d.ts +1 -0
  53. package/lib/components/po-field/po-checkbox-group/po-checkbox-group-base.component.d.ts +8 -1
  54. package/lib/components/po-field/po-combo/po-combo-base.component.d.ts +9 -2
  55. package/lib/components/po-field/po-combo/po-combo.component.d.ts +1 -0
  56. package/lib/components/po-field/po-datepicker/po-datepicker-base.component.d.ts +17 -2
  57. package/lib/components/po-field/po-datepicker/po-datepicker.component.d.ts +1 -0
  58. package/lib/components/po-field/po-datepicker-range/po-datepicker-range-base.component.d.ts +9 -2
  59. package/lib/components/po-field/po-decimal/po-decimal.component.d.ts +1 -0
  60. package/lib/components/po-field/po-email/po-email.component.d.ts +1 -0
  61. package/lib/components/po-field/po-field-container/po-field-container-literals.d.ts +4 -0
  62. package/lib/components/po-field/po-field-container/po-field-container.component.d.ts +18 -3
  63. package/lib/components/po-field/po-field-container/po-field-container.module.d.ts +2 -1
  64. package/lib/components/po-field/po-field-validate.model.d.ts +9 -2
  65. package/lib/components/po-field/po-input/po-input-base.component.d.ts +11 -3
  66. package/lib/components/po-field/po-input/po-input.component.d.ts +1 -0
  67. package/lib/components/po-field/po-login/po-login.component.d.ts +1 -0
  68. package/lib/components/po-field/po-lookup/po-lookup-base.component.d.ts +14 -3
  69. package/lib/components/po-field/po-lookup/po-lookup.component.d.ts +1 -1
  70. package/lib/components/po-field/po-lookup/services/po-lookup-modal.service.d.ts +1 -0
  71. package/lib/components/po-field/po-multiselect/po-multiselect-base.component.d.ts +11 -2
  72. package/lib/components/po-field/po-number/po-number.component.d.ts +1 -0
  73. package/lib/components/po-field/po-password/po-password.component.d.ts +1 -0
  74. package/lib/components/po-field/po-radio/po-radio.component.d.ts +7 -4
  75. package/lib/components/po-field/po-radio-group/po-radio-group-base.component.d.ts +9 -2
  76. package/lib/components/po-field/po-rich-text/po-rich-text-base.component.d.ts +9 -2
  77. package/lib/components/po-field/po-rich-text/po-rich-text-body/po-rich-text-body.component.d.ts +2 -1
  78. package/lib/components/po-field/po-select/po-select.component.d.ts +1 -0
  79. package/lib/components/po-field/po-switch/po-switch.component.d.ts +1 -0
  80. package/lib/components/po-field/po-textarea/po-textarea-base.component.d.ts +10 -4
  81. package/lib/components/po-field/po-textarea/po-textarea.component.d.ts +1 -0
  82. package/lib/components/po-field/po-upload/po-upload-base.component.d.ts +9 -2
  83. package/lib/components/po-field/po-upload/po-upload.component.d.ts +1 -0
  84. package/lib/components/po-field/po-url/po-url.component.d.ts +1 -0
  85. package/lib/components/po-label/index.d.ts +2 -0
  86. package/lib/components/po-label/po-label.component.d.ts +40 -0
  87. package/lib/components/po-label/po-label.module.d.ts +8 -0
  88. package/lib/components/po-widget/po-widget-base.component.d.ts +11 -2
  89. package/lib/components/po-widget/po-widget.component.d.ts +1 -0
  90. package/package.json +4 -4
  91. package/po-ui-ng-components-14.8.0.tgz +0 -0
  92. package/schematics/ng-add/index.js +1 -1
  93. package/schematics/ng-update/v14/index.js +1 -1
  94. package/schematics/ng-update/v2/index.js +1 -1
  95. package/schematics/ng-update/v3/index.js +1 -1
  96. package/schematics/ng-update/v4/index.js +1 -1
  97. package/schematics/ng-update/v5/index.js +1 -1
  98. package/schematics/ng-update/v6/index.js +1 -1
  99. package/po-ui-ng-components-14.7.0.tgz +0 -0
@@ -1,7 +1,7 @@
1
1
  import { __decorate } from "tslib";
2
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 { removeDuplicatedOptions, removeDuplicatedOptionsWithFieldValue, removeUndefinedAndNullOptions, removeUndefinedAndNullOptionsWithFieldValue, validValue } from '../../../utils/util';
4
+ import { removeDuplicatedOptions, removeDuplicatedOptionsWithFieldValue, removeUndefinedAndNullOptions, removeUndefinedAndNullOptionsWithFieldValue, uuid, validValue } from '../../../utils/util';
5
5
  import { InputBoolean } from '../../../decorators';
6
6
  import { PoFieldValidateModel } from '../po-field-validate.model';
7
7
  import * as i0 from "@angular/core";
@@ -107,6 +107,7 @@ export class PoSelectComponent extends PoFieldValidateModel {
107
107
  * @default `false`
108
108
  */
109
109
  this.readonly = false;
110
+ this.id = `po-select[${uuid()}]`;
110
111
  this._fieldLabel = PO_SELECT_FIELD_LABEL_DEFAULT;
111
112
  this._fieldValue = PO_SELECT_FIELD_VALUE_DEFAULT;
112
113
  this.differ = differs.find([]).create(null);
@@ -292,7 +293,7 @@ PoSelectComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoSelectC
292
293
  useExisting: forwardRef(() => PoSelectComponent),
293
294
  multi: true
294
295
  }
295
- ]), 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) {
296
+ ]), i0.ɵɵInheritDefinitionFeature], decls: 7, vars: 15, consts: [[3, "p-disabled", "p-help", "p-id", "p-label", "p-optional", "p-required", "p-show-required"], [1, "po-field-container-content"], [1, "po-select", 3, "disabled", "id", "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) {
296
297
  i0.ɵɵelementStart(0, "po-field-container", 0)(1, "div", 1)(2, "select", 2, 3);
297
298
  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); });
298
299
  i0.ɵɵtemplate(4, PoSelectComponent_option_4_Template, 2, 5, "option", 4);
@@ -301,11 +302,11 @@ PoSelectComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoSelectC
301
302
  i0.ɵɵelement(6, "po-field-container-bottom");
302
303
  i0.ɵɵelementEnd();
303
304
  } if (rf & 2) {
304
- i0.ɵɵproperty("p-label", ctx.label)("p-help", ctx.help)("p-optional", !ctx.required && ctx.optional);
305
+ i0.ɵɵproperty("p-disabled", ctx.disabled)("p-help", ctx.help)("p-id", ctx.id)("p-label", ctx.label)("p-optional", ctx.optional)("p-required", ctx.required)("p-show-required", ctx.showRequired);
305
306
  i0.ɵɵadvance(2);
306
307
  i0.ɵɵclassProp("po-select-placeholder", !ctx.selectedValue && !!ctx.placeholder);
307
- i0.ɵɵproperty("disabled", ctx.disabled)("required", ctx.required);
308
- i0.ɵɵattribute("aria-label", ctx.label)("name", ctx.name);
308
+ i0.ɵɵproperty("disabled", ctx.disabled)("id", ctx.id)("required", ctx.required);
309
+ i0.ɵɵattribute("name", ctx.name);
309
310
  i0.ɵɵadvance(2);
310
311
  i0.ɵɵproperty("ngIf", !ctx.selectedValue || !!ctx.placeholder);
311
312
  i0.ɵɵadvance(1);
@@ -327,7 +328,7 @@ __decorate([
327
328
  useExisting: forwardRef(() => PoSelectComponent),
328
329
  multi: true
329
330
  }
330
- ], 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" }]
331
+ ], template: "<po-field-container\n [p-disabled]=\"disabled\"\n [p-help]=\"help\"\n [p-id]=\"id\"\n [p-label]=\"label\"\n [p-optional]=\"optional\"\n [p-required]=\"required\"\n [p-show-required]=\"showRequired\"\n>\n <div class=\"po-field-container-content\">\n <select\n #select\n class=\"po-select\"\n [attr.name]=\"name\"\n [class.po-select-placeholder]=\"!selectedValue && !!placeholder\"\n [disabled]=\"disabled\"\n [id]=\"id\"\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" }]
331
332
  }], function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.IterableDiffers }, { type: i0.Renderer2 }]; }, { selectElement: [{
332
333
  type: ViewChild,
333
334
  args: ['select', { read: ElementRef, static: true }]
@@ -350,4 +351,4 @@ __decorate([
350
351
  type: Input,
351
352
  args: ['p-field-value']
352
353
  }] }); })();
353
- //# 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":";AAAA,OAAO,EACL,uBAAuB,EAEvB,SAAS,EAET,UAAU,EACV,YAAY,EACZ,UAAU,EACV,KAAK,EAEL,MAAM,EAEN,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAmB,aAAa,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAEnF,OAAO,EACL,uBAAuB,EACvB,qCAAqC,EACrC,6BAA6B,EAC7B,2CAA2C,EAC3C,UAAU,EACX,MAAM,qBAAqB,CAAC;AAE7B,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,EAAE,oBAAoB,EAAE,MAAM,4BAA4B,CAAC;;;;;;;;ICZ5D,iCAMC;IACC,YACF;IAAA,iBAAS;;;;IANP,+CAA0B,wDAAA,mCAAA,0FAAA;IAK1B,eACF;IADE,mDACF;;;IACA,iCAAiG;IAC/F,YACF;IAAA,iBAAS;;;;IAF8B,0CAAqB,kEAAA;IAC1D,eACF;IADE,wFACF;;ADIN,MAAM,6BAA6B,GAAG,OAAO,CAAC;AAC9C,MAAM,6BAA6B,GAAG,OAAO,CAAC;AAE9C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAyCG;AAkBH,MAAM,OAAO,iBAAkB,SAAQ,oBAAyB;IAoH9D,0BAA0B;IAC1B,YAAoB,cAAiC,EAAE,OAAwB,EAAS,QAAmB;QACzG,KAAK,EAAE,CAAC;QADU,mBAAc,GAAd,cAAc,CAAmB;QAAmC,aAAQ,GAAR,QAAQ,CAAW;QAlH3G;;;;;;;;;;;;;WAaG;QACsB,kBAAa,GAAsB,IAAI,YAAY,EAAO,CAAC;QAEpF;;;;;;;;WAQG;QACkC,aAAQ,GAAY,KAAK,CAAC;QAWvD,gBAAW,GAAY,6BAA6B,CAAC;QACrD,gBAAW,GAAY,6BAA6B,CAAC;QA+E3D,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAC9C,CAAC;IA7ED;;;;;;;;;;;;;;;OAeG;IACH,IAAwB,OAAO,CAAC,OAAmB;QACjD,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,EAAE;YACtC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE;gBACnB,MAAM,CAAC,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;gBACvC,MAAM,CAAC,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACzC,CAAC,CAAC,CAAC;SACJ;QAED,IAAI,CAAC,eAAe,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;QACnC,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,CAAC,QAAQ,GAAG,CAAC,GAAG,OAAO,CAAC,CAAC;IAC/B,CAAC;IAED,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAED;;;;;;;;OAQG;IACH,IAA4B,UAAU,CAAC,KAAa;QAClD,IAAI,CAAC,WAAW,GAAG,KAAK,IAAI,6BAA6B,CAAC;QAC1D,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE;YAC3C,IAAI,CAAC,OAAO,GAAG,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC;SAClC;IACH,CAAC;IAED,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED;;;;;;;;OAQG;IACH,IAA4B,UAAU,CAAC,KAAa;QAClD,IAAI,CAAC,WAAW,GAAG,KAAK,IAAI,6BAA6B,CAAC;QAC1D,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE;YAC3C,IAAI,CAAC,OAAO,GAAG,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC;SAClC;IACH,CAAC;IAED,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAQD,SAAS;QACP,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAE9C,IAAI,MAAM,EAAE;YACV,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;SACpC;IACH,CAAC;IAED;;;;;;;;;;;;;;;;OAgBG;IACH,KAAK;QACH,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;SAC1C;IACH,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,cAAc,EAAE,EAAE,CAAC;IAC1B,CAAC;IAED,wCAAwC;IACxC,cAAc,CAAC,KAAU;QACvB,IAAI,CAAC,cAAc,EAAE,EAAE,CAAC;QACxB,IAAI,KAAK,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE;YAChD,MAAM,WAAW,GAAQ,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;YAErD,IAAI,WAAW,EAAE;gBACf,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;aAChC;SACF;IACH,CAAC;IAED,eAAe;QACb,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SACtC;IACH,CAAC;IAED,mBAAmB;IACnB,YAAY,CAAC,MAAW;QACtB,IAAI,IAAI,CAAC,aAAa,KAAK,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;YAClD,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAC7C,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACjE,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;YAC1C,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAC5C,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;SAC1C;IACH,CAAC;IAED,gCAAgC;IAChC,YAAY,CAAC,KAAU;QACrB,MAAM,WAAW,GAAQ,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;QAErD,IAAI,WAAW,EAAE;YACf,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,KAAK,GAAG,WAAW,CAAC,KAAK,CAAC;YAC3D,IAAI,CAAC,aAAa,GAAG,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAClD,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SAClD;aAAM,IAAI,UAAU,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE;YACzC,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,KAAK,GAAG,SAAS,CAAC;YACnD,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;YAC5B,IAAI,CAAC,aAAa,GAAG,SAAS,CAAC;YAC/B,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC;SAC/B;QAED,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;IACtC,CAAC;IAED,eAAe,CAAC,CAAkB;QAChC,OAAO,IAAI,CAAC;IACd,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;IAC3B,CAAC;IAEO,OAAO,CAAC,KAAU,EAAE,UAAe;QACzC,IAAI,CAAC,KAAK,IAAI,KAAK,KAAK,CAAC,CAAC,IAAI,UAAU,EAAE;YACxC,OAAO,KAAK,CAAC,QAAQ,EAAE,KAAK,UAAU,CAAC,QAAQ,EAAE,CAAC;SACnD;QAED,IAAI,CAAC,KAAK,KAAK,IAAI,IAAI,UAAU,KAAK,IAAI,CAAC,IAAI,CAAC,KAAK,KAAK,SAAS,IAAI,UAAU,KAAK,SAAS,CAAC,EAAE;YAChG,KAAK,GAAG,GAAG,KAAK,EAAE,CAAC,CAAC,0BAA0B;SAC/C;QAED,OAAO,KAAK,KAAK,UAAU,CAAC;IAC9B,CAAC;IAEO,eAAe,CAAC,KAAU;QAChC,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC;IACxE,CAAC;IAEO,eAAe,CAAC,OAAmB;QACzC,uBAAuB,CAAC,OAAO,CAAC,CAAC;QACjC,6BAA6B,CAAC,OAAO,CAAC,CAAC;QACvC,qCAAqC,CAAC,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;QAChE,2CAA2C,CAAC,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;IACxE,CAAC;;kFA1OU,iBAAiB;oEAAjB,iBAAiB;+BACC,UAAU;;;;qTAd5B;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC;gBAChD,KAAK,EAAE,IAAI;aACZ;YACD;gBACE,OAAO,EAAE,aAAa;gBACtB,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC;gBAChD,KAAK,EAAE,IAAI;aACZ;SACF;QCxFH,6CAA2F,aAAA,mBAAA;QAUrF,4FAAQ,YAAQ,IAAC,yFACP,uCAAmC,IAD5B;QAGjB,wEAQS;QACT,wEAES;QACX,iBAAS,EAAA;QAGX,4CAAuD;QACzD,iBAAqB;;QA7BD,mCAAiB,oBAAA,6CAAA;QAO/B,eAA+D;QAA/D,gFAA+D;QAC/D,uCAAqB,0BAAA;QAHrB,uCAAyB,kBAAA;QAStB,eAAqC;QAArC,8DAAqC;QAQb,eAAU;QAAV,qCAAU;;ADgGJ;IAAf,YAAY,EAAE;mDAA2B;uFA5BpD,iBAAiB;cAjB7B,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;oBACD;wBACE,OAAO,EAAE,aAAa;wBACtB,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,kBAAkB,CAAC;wBAChD,KAAK,EAAE,IAAI;qBACZ;iBACF;0HAGwD,aAAa;kBAArE,SAAS;mBAAC,QAAQ,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,IAAI,EAAE;YAgB9B,aAAa;kBAArC,MAAM;mBAAC,eAAe;YAWc,QAAQ;kBAA5C,KAAK;mBAAC,YAAY;YAGK,WAAW;kBAAlC,KAAK;mBAAC,eAAe;YA4BE,OAAO;kBAA9B,KAAK;mBAAC,WAAW;YA0BU,UAAU;kBAArC,KAAK;mBAAC,eAAe;YAoBM,UAAU;kBAArC,KAAK;mBAAC,eAAe","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  protected 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    this.onModelTouched?.();\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  registerOnTouched(fn: any): void {\n    this.onModelTouched = fn;\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"]}
354
+ //# 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  uuid,\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  id = `po-select[${uuid()}]`;\n  modelValue: any;\n  selectedValue: any;\n  protected 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    this.onModelTouched?.();\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  registerOnTouched(fn: any): void {\n    this.onModelTouched = fn;\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\n  [p-disabled]=\"disabled\"\n  [p-help]=\"help\"\n  [p-id]=\"id\"\n  [p-label]=\"label\"\n  [p-optional]=\"optional\"\n  [p-required]=\"required\"\n  [p-show-required]=\"showRequired\"\n>\n  <div class=\"po-field-container-content\">\n    <select\n      #select\n      class=\"po-select\"\n      [attr.name]=\"name\"\n      [class.po-select-placeholder]=\"!selectedValue && !!placeholder\"\n      [disabled]=\"disabled\"\n      [id]=\"id\"\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"]}
@@ -1,5 +1,6 @@
1
1
  import { ChangeDetectionStrategy, Component, forwardRef, Input, ViewChild } from '@angular/core';
2
2
  import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import { uuid } from '../../../utils/util';
3
4
  import { PoFieldModel } from '../po-field.model';
4
5
  import { PoKeyCodeEnum } from './../../../enums/po-key-code.enum';
5
6
  import { PoSwitchLabelPosition } from './po-switch-label-position.enum';
@@ -66,6 +67,7 @@ export class PoSwitchComponent extends PoFieldModel {
66
67
  constructor(changeDetector) {
67
68
  super();
68
69
  this.changeDetector = changeDetector;
70
+ this.id = `po-switch[${uuid()}]`;
69
71
  this.value = false;
70
72
  this._labelOff = 'false';
71
73
  this._labelOn = 'true';
@@ -180,7 +182,7 @@ PoSwitchComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoSwitchC
180
182
  useExisting: forwardRef(() => PoSwitchComponent),
181
183
  multi: true
182
184
  }
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) {
185
+ ]), i0.ɵɵInheritDefinitionFeature], decls: 11, vars: 13, consts: [[3, "p-disabled", "p-help", "p-id", "p-label"], [1, "po-field-container-content"], [1, "po-switch"], ["role", "switch", 1, "po-switch-container", 3, "id", "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
186
  i0.ɵɵelementStart(0, "po-field-container", 0)(1, "div", 1)(2, "div", 2)(3, "div", 3, 4);
185
187
  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
188
  i0.ɵɵelementStart(5, "div", 5)(6, "div", 6);
@@ -193,15 +195,17 @@ PoSwitchComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoSwitchC
193
195
  i0.ɵɵelement(10, "po-field-container-bottom");
194
196
  i0.ɵɵelementEnd();
195
197
  } if (rf & 2) {
196
- i0.ɵɵproperty("p-label", ctx.label)("p-help", ctx.help);
198
+ i0.ɵɵproperty("p-disabled", ctx.disabled)("p-help", ctx.help)("p-id", ctx.id)("p-label", ctx.label);
197
199
  i0.ɵɵadvance(1);
198
200
  i0.ɵɵattribute("name", ctx.name);
199
201
  i0.ɵɵadvance(1);
200
202
  i0.ɵɵattribute("data-label-position", ctx.getLabelPosition());
201
203
  i0.ɵɵadvance(1);
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);
204
+ i0.ɵɵproperty("id", ctx.id)("tabindex", ctx.disabled ? -1 : 0);
205
+ i0.ɵɵattribute("aria-checked", ctx.value)("aria-disabled", ctx.disabled);
206
+ i0.ɵɵadvance(3);
207
+ i0.ɵɵattribute("aria-label", ctx.value === true ? ctx.labelOn : ctx.labelOff);
208
+ i0.ɵɵadvance(1);
205
209
  i0.ɵɵproperty("ngIf", ctx.value === true);
206
210
  i0.ɵɵadvance(2);
207
211
  i0.ɵɵtextInterpolate1(" ", ctx.value === true ? ctx.labelOn : ctx.labelOff, " ");
@@ -214,7 +218,7 @@ PoSwitchComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoSwitchC
214
218
  useExisting: forwardRef(() => PoSwitchComponent),
215
219
  multi: true
216
220
  }
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" }]
221
+ ], template: "<po-field-container [p-disabled]=\"disabled\" [p-help]=\"help\" [p-id]=\"id\" [p-label]=\"label\">\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 [id]=\"id\"\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\" [attr.aria-label]=\"value === true ? labelOn : labelOff\">\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" }]
218
222
  }], function () { return [{ type: i0.ChangeDetectorRef }]; }, { switchContainer: [{
219
223
  type: ViewChild,
220
224
  args: ['switchContainer', { static: true }]
@@ -228,4 +232,4 @@ PoSwitchComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoSwitchC
228
232
  type: Input,
229
233
  args: ['p-label-on']
230
234
  }] }); })();
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":"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","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"]}
235
+ //# 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":"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","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 { uuid } from '../../../utils/util';\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  id = `po-switch[${uuid()}]`;\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-disabled]=\"disabled\" [p-help]=\"help\" [p-id]=\"id\" [p-label]=\"label\">\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        [id]=\"id\"\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\" [attr.aria-label]=\"value === true ? labelOn : labelOff\">\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"]}
@@ -87,6 +87,13 @@ export class PoTextareaBaseComponent {
87
87
  this.onChangePropagate = null;
88
88
  // eslint-disable-next-line
89
89
  this.onTouched = null;
90
+ /**
91
+ * Define se a indicação de campo obrigatório será exibida.
92
+ *
93
+ * > Não será exibida a indicação se:
94
+ * - Não possuir `p-help` e/ou `p-label`.
95
+ */
96
+ this.showRequired = false;
90
97
  }
91
98
  /** Placeholder, mensagem que aparecerá enquanto o campo não estiver preenchido. */
92
99
  set placeholder(value) {
@@ -130,9 +137,8 @@ export class PoTextareaBaseComponent {
130
137
  *
131
138
  * @description
132
139
  *
133
- * Indica que o campo será obrigatório.
134
- *
135
- * > Esta propriedade é desconsiderada quando o _input_ está desabilitado `(p-disabled)`.
140
+ * Define que o campo será obrigatório.
141
+ * > Esta propriedade é desconsiderada quando o input está desabilitado `(p-disabled)`.
136
142
  *
137
143
  * @default `false`
138
144
  */
@@ -251,7 +257,7 @@ export class PoTextareaBaseComponent {
251
257
  }
252
258
  }
253
259
  PoTextareaBaseComponent.ɵfac = function PoTextareaBaseComponent_Factory(t) { return new (t || PoTextareaBaseComponent)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef)); };
254
- PoTextareaBaseComponent.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: PoTextareaBaseComponent, inputs: { autoFocus: ["p-auto-focus", "autoFocus"], label: ["p-label", "label"], help: ["p-help", "help"], name: "name", optional: ["p-optional", "optional"], placeholder: ["p-placeholder", "placeholder"], disabled: ["p-disabled", "disabled"], readonly: ["p-readonly", "readonly"], required: ["p-required", "required"], minlength: ["p-minlength", "minlength"], maxlength: ["p-maxlength", "maxlength"], rows: ["p-rows", "rows"] }, outputs: { blur: "p-blur", enter: "p-enter", change: "p-change", changeModel: "p-change-model" } });
260
+ PoTextareaBaseComponent.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: PoTextareaBaseComponent, inputs: { autoFocus: ["p-auto-focus", "autoFocus"], label: ["p-label", "label"], help: ["p-help", "help"], name: "name", optional: ["p-optional", "optional"], placeholder: ["p-placeholder", "placeholder"], disabled: ["p-disabled", "disabled"], readonly: ["p-readonly", "readonly"], required: ["p-required", "required"], showRequired: ["p-show-required", "showRequired"], minlength: ["p-minlength", "minlength"], maxlength: ["p-maxlength", "maxlength"], rows: ["p-rows", "rows"] }, outputs: { blur: "p-blur", enter: "p-enter", change: "p-change", changeModel: "p-change-model" } });
255
261
  __decorate([
256
262
  InputBoolean()
257
263
  ], PoTextareaBaseComponent.prototype, "autoFocus", void 0);
@@ -296,6 +302,9 @@ __decorate([
296
302
  }], required: [{
297
303
  type: Input,
298
304
  args: ['p-required']
305
+ }], showRequired: [{
306
+ type: Input,
307
+ args: ['p-show-required']
299
308
  }], minlength: [{
300
309
  type: Input,
301
310
  args: ['p-minlength']
@@ -306,4 +315,4 @@ __decorate([
306
315
  type: Input,
307
316
  args: ['p-rows']
308
317
  }] }); })();
309
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-textarea-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-textarea/po-textarea-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl, ControlValueAccessor, Validator } from '@angular/forms';\nimport { EventEmitter, Input, Output, Directive, ChangeDetectorRef } from '@angular/core';\n\nimport { convertToBoolean, convertToInt } from '../../../utils/util';\nimport { maxlengpoailed, minlengpoailed, requiredFailed } from '../validators';\nimport { InputBoolean } from '../../../decorators';\n\n/**\n * @description\n *\n * Este é um componente de entrada de dados que possibilita o preechimento com múltiplas linhas.\n * É recomendado para observações, detalhamentos e outras situações onde o usuário deva preencher com um texto.\n *\n * Importante:\n *\n * - A propriedade `name` é obrigatória para que o formulário e o `model` funcionem corretamente. Do contrário, ocorrerá um erro de\n * _Angular_, onde será necessário informar o atributo `name` ou o atributo `[ngModelOptions]=\"{standalone: true}\"`, por exemplo:\n *\n * ```\n * <po-textarea\n *   [(ngModel)]=\"pessoa.nome\"\n *   [ngModelOptions]=\"{standalone: true}\">\n * </po-textarea>\n * ```\n *\n * #### Acessibilidade tratada no componente\n * Algumas diretrizes de acessibilidade já são tratadas no componente, internamente, e não podem ser alteradas. São elas:\n *\n * - O Text area foi desenvolvido com uso de controles padrões HTML, o que permite a identificação do mesmo na interface por tecnologias\n * assistivas. [WCAG 4.1.2: Name, Role, Value](https://www.w3.org/WAI/WCAG21/Understanding/name-role-value)\n * - O foco é visível e possui uma espessura superior a 2 pixels CSS, não ficando escondido por outros\n * elementos da tela. [WCAG 2.4.12: Focus Appearance)](https://www.w3.org/WAI/WCAG22/Understanding/focus-appearance-enhanced)\n * - A identificação do erro acontece também através da mudança de cor do campo, mas também de um ícone\n * junto da mensagem. [WGAG 1.4.1: Use of Color, 3.2.4: Consistent Identification](https://www.w3.org/WAI/WCAG21/Understanding/use-of-color)\n */\n@Directive()\nexport abstract class PoTextareaBaseComponent implements ControlValueAccessor, Validator {\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Aplica foco no elemento ao ser iniciado.\n   *\n   * > Caso mais de um elemento seja configurado com essa propriedade, apenas o último elemento declarado com ela terá o foco.\n   *\n   * @default `false`\n   */\n  @Input('p-auto-focus') @InputBoolean() autoFocus: boolean = false;\n\n  /** Label do campo. */\n  @Input('p-label') label?: string;\n\n  /** Texto de apoio do campo. */\n  @Input('p-help') help?: string;\n\n  /** Nome e Id do componente. */\n  @Input('name') name: string;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define se a indicação de campo opcional será exibida.\n   *\n   * > Não será exibida a indicação se:\n   * - O campo conter `p-required`;\n   * - Não possuir `p-help` e/ou `p-label`.\n   *\n   * @default `false`\n   */\n  @Input('p-optional') optional: boolean;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Evento disparado ao sair do campo.\n   */\n  @Output('p-blur') blur: EventEmitter<any> = new EventEmitter<any>();\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Evento disparado ao entrar do campo.\n   */\n  @Output('p-enter') enter: EventEmitter<any> = new EventEmitter<any>();\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Evento disparado ao alterar valor e deixar o campo.\n   */\n  @Output('p-change') change: EventEmitter<any> = new EventEmitter<any>();\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Evento disparado ao alterar valor do model.\n   */\n  @Output('p-change-model') changeModel: EventEmitter<any> = new EventEmitter<any>();\n\n  private _disabled: boolean = false;\n  private _maxlength: number;\n  private _minlength: number;\n  private _placeholder: string = '';\n  private _readonly: boolean = false;\n  private _required: boolean = false;\n  private _rows: number = 3;\n\n  private modelLastUpdate: any;\n  private onChangePropagate: any = null;\n  private validatorChange: any;\n  // eslint-disable-next-line\n  protected onTouched: any = null;\n\n  /** Placeholder, mensagem que aparecerá enquanto o campo não estiver preenchido. */\n  @Input('p-placeholder') set placeholder(value: string) {\n    this._placeholder = value || '';\n  }\n\n  get placeholder() {\n    return this._placeholder;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica que o campo será desabilitado.\n   *\n   * @default `false`\n   */\n  @Input('p-disabled') set disabled(disabled: boolean) {\n    this._disabled = convertToBoolean(disabled);\n  }\n\n  get disabled(): boolean {\n    return this._disabled;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica que o campo será somente leitura.\n   *\n   * @default `false`\n   */\n  @Input('p-readonly') set readonly(readonly: boolean) {\n    this._readonly = convertToBoolean(readonly);\n  }\n\n  get readonly(): boolean {\n    return this._readonly;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica que o campo será obrigatório.\n   *\n   * > Esta propriedade é desconsiderada quando o _input_ está desabilitado `(p-disabled)`.\n   *\n   * @default `false`\n   */\n  @Input('p-required') set required(required: boolean) {\n    this._required = convertToBoolean(required);\n\n    this.validateModel();\n  }\n\n  get required(): boolean {\n    return this._required;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica a quantidade mínima de caracteres que o campo aceita.\n   */\n  @Input('p-minlength') set minlength(minlength: number) {\n    this._minlength = convertToInt(minlength);\n    this.validateModel();\n  }\n\n  get minlength(): number {\n    return this._minlength;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica a quantidade máxima de caracteres que o campo aceita.\n   */\n  @Input('p-maxlength') set maxlength(maxlength: number) {\n    this._maxlength = convertToInt(maxlength);\n    this.validateModel();\n  }\n\n  get maxlength(): number {\n    return this._maxlength;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica a quantidade de linhas que serão exibidas.\n   *\n   * @default `3`\n   */\n  @Input('p-rows') set rows(value: number) {\n    this._rows = isNaN(parseInt(<any>value, 10)) || value < 3 ? 3 : parseInt(<any>value, 10);\n  }\n  get rows(): number {\n    return this._rows;\n  }\n\n  constructor(public cd: ChangeDetectorRef) {}\n\n  callOnChange(value: any) {\n    // Quando o input não possui um formulário, então esta função não é registrada\n    if (this.onChangePropagate) {\n      this.onChangePropagate(value);\n    }\n\n    this.controlChangeModelEmitter(value);\n  }\n\n  controlChangeModelEmitter(value: any) {\n    if (this.modelLastUpdate !== value) {\n      this.changeModel.emit(value);\n      this.modelLastUpdate = value;\n    }\n  }\n\n  // Função implementada do ControlValueAccessor\n  // Usada para interceptar os estados de habilitado via forms api\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n    this.cd.markForCheck();\n  }\n\n  // Funções `registerOnChange`, `registerOnTouched` e `registerOnValidatorChange` implementadas referentes ao ControlValueAccessor\n  // usadas para interceptar as mudanças e não atualizar automaticamente o Model\n  registerOnChange(func: any): void {\n    this.onChangePropagate = func;\n  }\n\n  registerOnTouched(func: any): void {\n    this.onTouched = func;\n  }\n\n  registerOnValidatorChange(func: any): void {\n    this.validatorChange = func;\n  }\n\n  validate(abstractControl: AbstractControl): { [key: string]: any } {\n    if (requiredFailed(this.required, this.disabled, abstractControl.value)) {\n      return {\n        required: {\n          valid: false\n        }\n      };\n    }\n\n    if (minlengpoailed(this.minlength, abstractControl.value)) {\n      return {\n        minlength: {\n          valid: false\n        }\n      };\n    }\n\n    if (maxlengpoailed(this.maxlength, abstractControl.value)) {\n      return {\n        maxlength: {\n          valid: false\n        }\n      };\n    }\n  }\n\n  // Função implementada do ControlValueAccessor\n  writeValue(value: any) {\n    this.writeValueModel(value);\n    this.cd.markForCheck();\n  }\n\n  protected validateModel() {\n    if (this.validatorChange) {\n      this.validatorChange();\n    }\n  }\n\n  abstract writeValueModel(value: any): void;\n}\n"]}
318
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-textarea-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-textarea/po-textarea-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl, ControlValueAccessor, Validator } from '@angular/forms';\nimport { EventEmitter, Input, Output, Directive, ChangeDetectorRef } from '@angular/core';\n\nimport { convertToBoolean, convertToInt } from '../../../utils/util';\nimport { maxlengpoailed, minlengpoailed, requiredFailed } from '../validators';\nimport { InputBoolean } from '../../../decorators';\n\n/**\n * @description\n *\n * Este é um componente de entrada de dados que possibilita o preechimento com múltiplas linhas.\n * É recomendado para observações, detalhamentos e outras situações onde o usuário deva preencher com um texto.\n *\n * Importante:\n *\n * - A propriedade `name` é obrigatória para que o formulário e o `model` funcionem corretamente. Do contrário, ocorrerá um erro de\n * _Angular_, onde será necessário informar o atributo `name` ou o atributo `[ngModelOptions]=\"{standalone: true}\"`, por exemplo:\n *\n * ```\n * <po-textarea\n *   [(ngModel)]=\"pessoa.nome\"\n *   [ngModelOptions]=\"{standalone: true}\">\n * </po-textarea>\n * ```\n *\n * #### Acessibilidade tratada no componente\n * Algumas diretrizes de acessibilidade já são tratadas no componente, internamente, e não podem ser alteradas. São elas:\n *\n * - O Text area foi desenvolvido com uso de controles padrões HTML, o que permite a identificação do mesmo na interface por tecnologias\n * assistivas. [WCAG 4.1.2: Name, Role, Value](https://www.w3.org/WAI/WCAG21/Understanding/name-role-value)\n * - O foco é visível e possui uma espessura superior a 2 pixels CSS, não ficando escondido por outros\n * elementos da tela. [WCAG 2.4.12: Focus Appearance)](https://www.w3.org/WAI/WCAG22/Understanding/focus-appearance-enhanced)\n * - A identificação do erro acontece também através da mudança de cor do campo, mas também de um ícone\n * junto da mensagem. [WGAG 1.4.1: Use of Color, 3.2.4: Consistent Identification](https://www.w3.org/WAI/WCAG21/Understanding/use-of-color)\n */\n@Directive()\nexport abstract class PoTextareaBaseComponent implements ControlValueAccessor, Validator {\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Aplica foco no elemento ao ser iniciado.\n   *\n   * > Caso mais de um elemento seja configurado com essa propriedade, apenas o último elemento declarado com ela terá o foco.\n   *\n   * @default `false`\n   */\n  @Input('p-auto-focus') @InputBoolean() autoFocus: boolean = false;\n\n  /** Label do campo. */\n  @Input('p-label') label?: string;\n\n  /** Texto de apoio do campo. */\n  @Input('p-help') help?: string;\n\n  /** Nome e Id do componente. */\n  @Input('name') name: string;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define se a indicação de campo opcional será exibida.\n   *\n   * > Não será exibida a indicação se:\n   * - O campo conter `p-required`;\n   * - Não possuir `p-help` e/ou `p-label`.\n   *\n   * @default `false`\n   */\n  @Input('p-optional') optional: boolean;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Evento disparado ao sair do campo.\n   */\n  @Output('p-blur') blur: EventEmitter<any> = new EventEmitter<any>();\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Evento disparado ao entrar do campo.\n   */\n  @Output('p-enter') enter: EventEmitter<any> = new EventEmitter<any>();\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Evento disparado ao alterar valor e deixar o campo.\n   */\n  @Output('p-change') change: EventEmitter<any> = new EventEmitter<any>();\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Evento disparado ao alterar valor do model.\n   */\n  @Output('p-change-model') changeModel: EventEmitter<any> = new EventEmitter<any>();\n\n  private _disabled: boolean = false;\n  private _maxlength: number;\n  private _minlength: number;\n  private _placeholder: string = '';\n  private _readonly: boolean = false;\n  private _required: boolean = false;\n  private _rows: number = 3;\n\n  private modelLastUpdate: any;\n  private onChangePropagate: any = null;\n  private validatorChange: any;\n  // eslint-disable-next-line\n  protected onTouched: any = null;\n\n  /** Placeholder, mensagem que aparecerá enquanto o campo não estiver preenchido. */\n  @Input('p-placeholder') set placeholder(value: string) {\n    this._placeholder = value || '';\n  }\n\n  get placeholder() {\n    return this._placeholder;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica que o campo será desabilitado.\n   *\n   * @default `false`\n   */\n  @Input('p-disabled') set disabled(disabled: boolean) {\n    this._disabled = convertToBoolean(disabled);\n  }\n\n  get disabled(): boolean {\n    return this._disabled;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica que o campo será somente leitura.\n   *\n   * @default `false`\n   */\n  @Input('p-readonly') set readonly(readonly: boolean) {\n    this._readonly = convertToBoolean(readonly);\n  }\n\n  get readonly(): boolean {\n    return this._readonly;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define que o campo será obrigatório.\n   * > Esta propriedade é desconsiderada quando o input está desabilitado `(p-disabled)`.\n   *\n   * @default `false`\n   */\n  @Input('p-required') set required(required: boolean) {\n    this._required = convertToBoolean(required);\n\n    this.validateModel();\n  }\n\n  get required(): boolean {\n    return this._required;\n  }\n\n  /**\n   * Define se a indicação de campo obrigatório será exibida.\n   *\n   * > Não será exibida a indicação se:\n   * - Não possuir `p-help` e/ou `p-label`.\n   */\n  @Input('p-show-required') showRequired: boolean = false;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica a quantidade mínima de caracteres que o campo aceita.\n   */\n  @Input('p-minlength') set minlength(minlength: number) {\n    this._minlength = convertToInt(minlength);\n    this.validateModel();\n  }\n\n  get minlength(): number {\n    return this._minlength;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica a quantidade máxima de caracteres que o campo aceita.\n   */\n  @Input('p-maxlength') set maxlength(maxlength: number) {\n    this._maxlength = convertToInt(maxlength);\n    this.validateModel();\n  }\n\n  get maxlength(): number {\n    return this._maxlength;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica a quantidade de linhas que serão exibidas.\n   *\n   * @default `3`\n   */\n  @Input('p-rows') set rows(value: number) {\n    this._rows = isNaN(parseInt(<any>value, 10)) || value < 3 ? 3 : parseInt(<any>value, 10);\n  }\n  get rows(): number {\n    return this._rows;\n  }\n\n  constructor(public cd: ChangeDetectorRef) {}\n\n  callOnChange(value: any) {\n    // Quando o input não possui um formulário, então esta função não é registrada\n    if (this.onChangePropagate) {\n      this.onChangePropagate(value);\n    }\n\n    this.controlChangeModelEmitter(value);\n  }\n\n  controlChangeModelEmitter(value: any) {\n    if (this.modelLastUpdate !== value) {\n      this.changeModel.emit(value);\n      this.modelLastUpdate = value;\n    }\n  }\n\n  // Função implementada do ControlValueAccessor\n  // Usada para interceptar os estados de habilitado via forms api\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n    this.cd.markForCheck();\n  }\n\n  // Funções `registerOnChange`, `registerOnTouched` e `registerOnValidatorChange` implementadas referentes ao ControlValueAccessor\n  // usadas para interceptar as mudanças e não atualizar automaticamente o Model\n  registerOnChange(func: any): void {\n    this.onChangePropagate = func;\n  }\n\n  registerOnTouched(func: any): void {\n    this.onTouched = func;\n  }\n\n  registerOnValidatorChange(func: any): void {\n    this.validatorChange = func;\n  }\n\n  validate(abstractControl: AbstractControl): { [key: string]: any } {\n    if (requiredFailed(this.required, this.disabled, abstractControl.value)) {\n      return {\n        required: {\n          valid: false\n        }\n      };\n    }\n\n    if (minlengpoailed(this.minlength, abstractControl.value)) {\n      return {\n        minlength: {\n          valid: false\n        }\n      };\n    }\n\n    if (maxlengpoailed(this.maxlength, abstractControl.value)) {\n      return {\n        maxlength: {\n          valid: false\n        }\n      };\n    }\n  }\n\n  // Função implementada do ControlValueAccessor\n  writeValue(value: any) {\n    this.writeValueModel(value);\n    this.cd.markForCheck();\n  }\n\n  protected validateModel() {\n    if (this.validatorChange) {\n      this.validatorChange();\n    }\n  }\n\n  abstract writeValueModel(value: any): void;\n}\n"]}
@@ -1,5 +1,6 @@
1
1
  import { Component, ElementRef, forwardRef, ViewChild, ChangeDetectionStrategy } from '@angular/core';
2
2
  import { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import { uuid } from '../../../utils/util';
3
4
  import { PoTextareaBaseComponent } from './po-textarea-base.component';
4
5
  import * as i0 from "@angular/core";
5
6
  import * as i1 from "../po-field-container/po-field-container-bottom/po-field-container-bottom.component";
@@ -34,6 +35,7 @@ const _c0 = ["inp"];
34
35
  export class PoTextareaComponent extends PoTextareaBaseComponent {
35
36
  constructor(cd) {
36
37
  super(cd);
38
+ this.id = `po-textarea[${uuid()}]`;
37
39
  this.fireChange = false;
38
40
  }
39
41
  /**
@@ -122,17 +124,17 @@ PoTextareaComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoTexta
122
124
  useExisting: forwardRef(() => PoTextareaComponent),
123
125
  multi: true
124
126
  }
125
- ]), i0.ɵɵInheritDefinitionFeature], decls: 5, vars: 10, consts: [[3, "p-help", "p-label", "p-optional"], [1, "po-field-container-content"], [1, "po-textarea", 3, "disabled", "placeholder", "readonly", "required", "rows", "blur", "focus", "input"], ["inp", ""]], template: function PoTextareaComponent_Template(rf, ctx) { if (rf & 1) {
127
+ ]), i0.ɵɵInheritDefinitionFeature], decls: 5, vars: 14, consts: [[3, "p-disabled", "p-help", "p-id", "p-label", "p-optional", "p-required", "p-show-required"], [1, "po-field-container-content"], [1, "po-textarea", 3, "disabled", "id", "placeholder", "readonly", "required", "rows", "blur", "focus", "input"], ["inp", ""]], template: function PoTextareaComponent_Template(rf, ctx) { if (rf & 1) {
126
128
  i0.ɵɵelementStart(0, "po-field-container", 0)(1, "div", 1)(2, "textarea", 2, 3);
127
129
  i0.ɵɵlistener("blur", function PoTextareaComponent_Template_textarea_blur_2_listener() { return ctx.eventOnBlur(); })("focus", function PoTextareaComponent_Template_textarea_focus_2_listener() { return ctx.eventOnFocus(); })("input", function PoTextareaComponent_Template_textarea_input_2_listener($event) { return ctx.eventOnInput($event); });
128
130
  i0.ɵɵelementEnd()();
129
131
  i0.ɵɵelement(4, "po-field-container-bottom");
130
132
  i0.ɵɵelementEnd();
131
133
  } if (rf & 2) {
132
- i0.ɵɵproperty("p-help", ctx.help)("p-label", ctx.label)("p-optional", !ctx.required && ctx.optional);
134
+ i0.ɵɵproperty("p-disabled", ctx.disabled)("p-help", ctx.help)("p-id", ctx.id)("p-label", ctx.label)("p-optional", ctx.optional)("p-required", ctx.required)("p-show-required", ctx.showRequired);
133
135
  i0.ɵɵadvance(2);
134
- i0.ɵɵproperty("disabled", ctx.disabled)("placeholder", ctx.disabled ? "" : ctx.placeholder)("readonly", ctx.readonly)("required", ctx.required)("rows", ctx.rows);
135
- i0.ɵɵattribute("name", ctx.name)("aria-label", ctx.label);
136
+ i0.ɵɵproperty("disabled", ctx.disabled)("id", ctx.id)("placeholder", ctx.disabled ? "" : ctx.placeholder)("readonly", ctx.readonly)("required", ctx.required)("rows", ctx.rows);
137
+ i0.ɵɵattribute("name", ctx.name);
136
138
  } }, dependencies: [i1.PoFieldContainerBottomComponent, i2.PoFieldContainerComponent], encapsulation: 2, changeDetection: 0 });
137
139
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoTextareaComponent, [{
138
140
  type: Component,
@@ -147,9 +149,9 @@ PoTextareaComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoTexta
147
149
  useExisting: forwardRef(() => PoTextareaComponent),
148
150
  multi: true
149
151
  }
150
- ], template: "<po-field-container [p-help]=\"help\" [p-label]=\"label\" [p-optional]=\"!required && optional\">\n <div class=\"po-field-container-content\">\n <textarea\n #inp\n class=\"po-textarea\"\n (blur)=\"eventOnBlur()\"\n (focus)=\"eventOnFocus()\"\n (input)=\"eventOnInput($event)\"\n [attr.name]=\"name\"\n [attr.aria-label]=\"label\"\n [disabled]=\"disabled\"\n [placeholder]=\"disabled ? '' : placeholder\"\n [readonly]=\"readonly\"\n [required]=\"required\"\n [rows]=\"rows\"\n ></textarea>\n </div>\n\n <po-field-container-bottom></po-field-container-bottom>\n</po-field-container>\n" }]
152
+ ], template: "<po-field-container\n [p-disabled]=\"disabled\"\n [p-help]=\"help\"\n [p-id]=\"id\"\n [p-label]=\"label\"\n [p-optional]=\"optional\"\n [p-required]=\"required\"\n [p-show-required]=\"showRequired\"\n>\n <div class=\"po-field-container-content\">\n <textarea\n #inp\n class=\"po-textarea\"\n (blur)=\"eventOnBlur()\"\n (focus)=\"eventOnFocus()\"\n (input)=\"eventOnInput($event)\"\n [attr.name]=\"name\"\n [disabled]=\"disabled\"\n [id]=\"id\"\n [placeholder]=\"disabled ? '' : placeholder\"\n [readonly]=\"readonly\"\n [required]=\"required\"\n [rows]=\"rows\"\n ></textarea>\n </div>\n\n <po-field-container-bottom></po-field-container-bottom>\n</po-field-container>\n" }]
151
153
  }], function () { return [{ type: i0.ChangeDetectorRef }]; }, { inputEl: [{
152
154
  type: ViewChild,
153
155
  args: ['inp', { read: ElementRef, static: true }]
154
156
  }] }); })();
155
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-textarea.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-textarea/po-textarea.component.ts","../../../../../../../projects/ui/src/lib/components/po-field/po-textarea/po-textarea.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  ChangeDetectorRef,\n  forwardRef,\n  ViewChild,\n  AfterViewInit,\n  ChangeDetectionStrategy\n} from '@angular/core';\nimport { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { PoTextareaBaseComponent } from './po-textarea-base.component';\n\n/**\n * @docsExtends PoTextareaBaseComponent\n *\n * @example\n *\n * <example name=\"po-textarea-basic\" title=\"PO Textarea Basic\" >\n *  <file name=\"sample-po-textarea-basic/sample-po-textarea-basic.component.html\"> </file>\n *  <file name=\"sample-po-textarea-basic/sample-po-textarea-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-textarea-labs\" title=\"PO Textarea Labs\" >\n *  <file name=\"sample-po-textarea-labs/sample-po-textarea-labs.component.html\"> </file>\n *  <file name=\"sample-po-textarea-labs/sample-po-textarea-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-textarea-email\" title=\"PO Textarea - Email\" >\n *  <file name=\"sample-po-textarea-email/sample-po-textarea-email.component.html\"> </file>\n *  <file name=\"sample-po-textarea-email/sample-po-textarea-email.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-textarea-email-reactive-form\" title=\"PO Textarea - Email Reactive Form\" >\n *  <file name=\"sample-po-textarea-email-reactive-form/sample-po-textarea-email-reactive-form.component.html\"> </file>\n *  <file name=\"sample-po-textarea-email-reactive-form/sample-po-textarea-email-reactive-form.component.ts\"> </file>\n * </example>\n *\n */\n@Component({\n  selector: 'po-textarea',\n  templateUrl: './po-textarea.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PoTextareaComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => PoTextareaComponent),\n      multi: true\n    }\n  ]\n})\nexport class PoTextareaComponent extends PoTextareaBaseComponent implements AfterViewInit {\n  @ViewChild('inp', { read: ElementRef, static: true }) inputEl: ElementRef;\n\n  valueBeforeChange: any;\n  fireChange: boolean = false;\n\n  constructor(cd: ChangeDetectorRef) {\n    super(cd);\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 { PoTextareaComponent } from '@po-ui/ng-components';\n   *\n   * ...\n   *\n   * @ViewChild(PoTextareaComponent, { static: true }) textarea: PoTextareaComponent;\n   *\n   * focusTextarea() {\n   *   this.textarea.focus();\n   * }\n   * ```\n   */\n  focus(): void {\n    if (!this.disabled) {\n      this.inputEl.nativeElement.focus();\n    }\n  }\n\n  ngAfterViewInit() {\n    if (this.autoFocus) {\n      this.focus();\n    }\n  }\n\n  writeValueModel(value: any): void {\n    if (this.inputEl) {\n      if (!value) {\n        // Se for o valor for undefined, deve limpar o campo\n        this.inputEl.nativeElement.value = '';\n      } else {\n        this.inputEl.nativeElement.value = value;\n      }\n    }\n\n    // Emite evento quando o model é atualizado, inclusive a primeira vez\n    if (value) {\n      this.change.emit(value);\n    }\n  }\n\n  validMaxLength(maxlength: number, value: string) {\n    return maxlength && value.length > maxlength ? value.toString().substring(0, maxlength) : value;\n  }\n\n  eventOnInput(event: any) {\n    const value = this.validMaxLength(this.maxlength, event.target.value);\n    this.callOnChange(value);\n    this.inputEl.nativeElement.value = value;\n  }\n\n  eventOnFocus() {\n    // Atualiza valor da variável que será usada para verificar se o campo teve alteração\n    this.valueBeforeChange = this.inputEl.nativeElement.value;\n\n    // Dispara evento quando o usuário entrar no campo\n    // Este evento também é disparado quando o campo inicia com foco.\n    this.enter.emit();\n  }\n\n  eventOnBlur() {\n    this.onTouched?.();\n    this.blur.emit();\n    this.controlChangeEmitter();\n  }\n\n  controlChangeEmitter() {\n    const elementValue = this.inputEl.nativeElement.value;\n\n    if (elementValue !== this.valueBeforeChange) {\n      this.change.emit(elementValue);\n    }\n  }\n}\n","<po-field-container [p-help]=\"help\" [p-label]=\"label\" [p-optional]=\"!required && optional\">\n  <div class=\"po-field-container-content\">\n    <textarea\n      #inp\n      class=\"po-textarea\"\n      (blur)=\"eventOnBlur()\"\n      (focus)=\"eventOnFocus()\"\n      (input)=\"eventOnInput($event)\"\n      [attr.name]=\"name\"\n      [attr.aria-label]=\"label\"\n      [disabled]=\"disabled\"\n      [placeholder]=\"disabled ? '' : placeholder\"\n      [readonly]=\"readonly\"\n      [required]=\"required\"\n      [rows]=\"rows\"\n    ></textarea>\n  </div>\n\n  <po-field-container-bottom></po-field-container-bottom>\n</po-field-container>\n"]}
157
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-textarea.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-textarea/po-textarea.component.ts","../../../../../../../projects/ui/src/lib/components/po-field/po-textarea/po-textarea.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  ChangeDetectorRef,\n  forwardRef,\n  ViewChild,\n  AfterViewInit,\n  ChangeDetectionStrategy\n} from '@angular/core';\nimport { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { uuid } from '../../../utils/util';\n\nimport { PoTextareaBaseComponent } from './po-textarea-base.component';\n\n/**\n * @docsExtends PoTextareaBaseComponent\n *\n * @example\n *\n * <example name=\"po-textarea-basic\" title=\"PO Textarea Basic\" >\n *  <file name=\"sample-po-textarea-basic/sample-po-textarea-basic.component.html\"> </file>\n *  <file name=\"sample-po-textarea-basic/sample-po-textarea-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-textarea-labs\" title=\"PO Textarea Labs\" >\n *  <file name=\"sample-po-textarea-labs/sample-po-textarea-labs.component.html\"> </file>\n *  <file name=\"sample-po-textarea-labs/sample-po-textarea-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-textarea-email\" title=\"PO Textarea - Email\" >\n *  <file name=\"sample-po-textarea-email/sample-po-textarea-email.component.html\"> </file>\n *  <file name=\"sample-po-textarea-email/sample-po-textarea-email.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-textarea-email-reactive-form\" title=\"PO Textarea - Email Reactive Form\" >\n *  <file name=\"sample-po-textarea-email-reactive-form/sample-po-textarea-email-reactive-form.component.html\"> </file>\n *  <file name=\"sample-po-textarea-email-reactive-form/sample-po-textarea-email-reactive-form.component.ts\"> </file>\n * </example>\n *\n */\n@Component({\n  selector: 'po-textarea',\n  templateUrl: './po-textarea.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PoTextareaComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => PoTextareaComponent),\n      multi: true\n    }\n  ]\n})\nexport class PoTextareaComponent extends PoTextareaBaseComponent implements AfterViewInit {\n  @ViewChild('inp', { read: ElementRef, static: true }) inputEl: ElementRef;\n\n  id = `po-textarea[${uuid()}]`;\n  valueBeforeChange: any;\n  fireChange: boolean = false;\n\n  constructor(cd: ChangeDetectorRef) {\n    super(cd);\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 { PoTextareaComponent } from '@po-ui/ng-components';\n   *\n   * ...\n   *\n   * @ViewChild(PoTextareaComponent, { static: true }) textarea: PoTextareaComponent;\n   *\n   * focusTextarea() {\n   *   this.textarea.focus();\n   * }\n   * ```\n   */\n  focus(): void {\n    if (!this.disabled) {\n      this.inputEl.nativeElement.focus();\n    }\n  }\n\n  ngAfterViewInit() {\n    if (this.autoFocus) {\n      this.focus();\n    }\n  }\n\n  writeValueModel(value: any): void {\n    if (this.inputEl) {\n      if (!value) {\n        // Se for o valor for undefined, deve limpar o campo\n        this.inputEl.nativeElement.value = '';\n      } else {\n        this.inputEl.nativeElement.value = value;\n      }\n    }\n\n    // Emite evento quando o model é atualizado, inclusive a primeira vez\n    if (value) {\n      this.change.emit(value);\n    }\n  }\n\n  validMaxLength(maxlength: number, value: string) {\n    return maxlength && value.length > maxlength ? value.toString().substring(0, maxlength) : value;\n  }\n\n  eventOnInput(event: any) {\n    const value = this.validMaxLength(this.maxlength, event.target.value);\n    this.callOnChange(value);\n    this.inputEl.nativeElement.value = value;\n  }\n\n  eventOnFocus() {\n    // Atualiza valor da variável que será usada para verificar se o campo teve alteração\n    this.valueBeforeChange = this.inputEl.nativeElement.value;\n\n    // Dispara evento quando o usuário entrar no campo\n    // Este evento também é disparado quando o campo inicia com foco.\n    this.enter.emit();\n  }\n\n  eventOnBlur() {\n    this.onTouched?.();\n    this.blur.emit();\n    this.controlChangeEmitter();\n  }\n\n  controlChangeEmitter() {\n    const elementValue = this.inputEl.nativeElement.value;\n\n    if (elementValue !== this.valueBeforeChange) {\n      this.change.emit(elementValue);\n    }\n  }\n}\n","<po-field-container\n  [p-disabled]=\"disabled\"\n  [p-help]=\"help\"\n  [p-id]=\"id\"\n  [p-label]=\"label\"\n  [p-optional]=\"optional\"\n  [p-required]=\"required\"\n  [p-show-required]=\"showRequired\"\n>\n  <div class=\"po-field-container-content\">\n    <textarea\n      #inp\n      class=\"po-textarea\"\n      (blur)=\"eventOnBlur()\"\n      (focus)=\"eventOnFocus()\"\n      (input)=\"eventOnInput($event)\"\n      [attr.name]=\"name\"\n      [disabled]=\"disabled\"\n      [id]=\"id\"\n      [placeholder]=\"disabled ? '' : placeholder\"\n      [readonly]=\"readonly\"\n      [required]=\"required\"\n      [rows]=\"rows\"\n    ></textarea>\n  </div>\n\n  <po-field-container-bottom></po-field-container-bottom>\n</po-field-container>\n"]}