@po-ui/ng-components 14.4.0 → 14.6.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 (69) hide show
  1. package/esm2020/lib/components/po-button-group/po-button-group-base.component.mjs +2 -2
  2. package/esm2020/lib/components/po-field/po-combo/po-combo.component.mjs +6 -6
  3. package/esm2020/lib/components/po-field/po-datepicker/po-datepicker.component.mjs +5 -5
  4. package/esm2020/lib/components/po-field/po-datepicker-range/po-datepicker-range.component.mjs +7 -3
  5. package/esm2020/lib/components/po-field/po-decimal/po-decimal.component.mjs +5 -5
  6. package/esm2020/lib/components/po-field/po-email/po-email.component.mjs +9 -7
  7. package/esm2020/lib/components/po-field/po-input/po-input.component.mjs +9 -7
  8. package/esm2020/lib/components/po-field/po-login/po-login.component.mjs +12 -11
  9. package/esm2020/lib/components/po-field/po-lookup/po-lookup-modal/po-lookup-modal.component.mjs +3 -3
  10. package/esm2020/lib/components/po-field/po-lookup/po-lookup.component.mjs +6 -5
  11. package/esm2020/lib/components/po-field/po-multiselect/po-multiselect-base.component.mjs +31 -20
  12. package/esm2020/lib/components/po-field/po-multiselect/po-multiselect-dropdown/po-multiselect-dropdown.component.mjs +19 -13
  13. package/esm2020/lib/components/po-field/po-multiselect/po-multiselect-filter.interface.mjs +1 -1
  14. package/esm2020/lib/components/po-field/po-multiselect/po-multiselect-filter.service.mjs +2 -2
  15. package/esm2020/lib/components/po-field/po-multiselect/po-multiselect-search/po-multiselect-search.component.mjs +7 -4
  16. package/esm2020/lib/components/po-field/po-multiselect/po-multiselect.component.mjs +24 -17
  17. package/esm2020/lib/components/po-field/po-number/po-number.component.mjs +5 -5
  18. package/esm2020/lib/components/po-field/po-password/po-password.component.mjs +14 -13
  19. package/esm2020/lib/components/po-field/po-radio/po-radio-size.enum.mjs +10 -3
  20. package/esm2020/lib/components/po-field/po-radio/po-radio.component.mjs +98 -34
  21. package/esm2020/lib/components/po-field/po-radio-group/po-radio-group-base.component.mjs +16 -2
  22. package/esm2020/lib/components/po-field/po-radio-group/po-radio-group.component.mjs +18 -25
  23. package/esm2020/lib/components/po-field/po-select/po-select.component.mjs +38 -250
  24. package/esm2020/lib/components/po-field/po-textarea/po-textarea-base.component.mjs +11 -1
  25. package/esm2020/lib/components/po-field/po-textarea/po-textarea.component.mjs +6 -7
  26. package/esm2020/lib/components/po-field/po-url/po-url.component.mjs +9 -7
  27. package/esm2020/lib/components/po-page/po-page-list/po-page-list.component.mjs +3 -3
  28. package/esm2020/lib/components/po-table/po-table-column-manager/po-table-column-manager.component.mjs +26 -73
  29. package/esm2020/lib/components/po-table/po-table-detail/po-table-detail.component.mjs +27 -8
  30. package/esm2020/lib/components/po-table/po-table-list-manager/po-table-list-manager.component.mjs +111 -0
  31. package/esm2020/lib/components/po-table/po-table.component.mjs +355 -356
  32. package/esm2020/lib/components/po-table/po-table.module.mjs +4 -1
  33. package/esm2020/lib/components/po-tag/po-tag-base.component.mjs +11 -3
  34. package/esm2020/lib/components/po-tag/po-tag.component.mjs +16 -9
  35. package/esm2020/lib/components/po-tree-view/po-tree-view-base.component.mjs +6 -4
  36. package/fesm2015/po-ui-ng-components.mjs +1228 -1323
  37. package/fesm2015/po-ui-ng-components.mjs.map +1 -1
  38. package/fesm2020/po-ui-ng-components.mjs +1210 -1301
  39. package/fesm2020/po-ui-ng-components.mjs.map +1 -1
  40. package/lib/components/po-button-group/po-button-group-base.component.d.ts +1 -1
  41. package/lib/components/po-field/po-multiselect/po-multiselect-base.component.d.ts +26 -15
  42. package/lib/components/po-field/po-multiselect/po-multiselect-dropdown/po-multiselect-dropdown.component.d.ts +5 -3
  43. package/lib/components/po-field/po-multiselect/po-multiselect-filter.interface.d.ts +2 -2
  44. package/lib/components/po-field/po-multiselect/po-multiselect-filter.service.d.ts +2 -2
  45. package/lib/components/po-field/po-multiselect/po-multiselect-search/po-multiselect-search.component.d.ts +2 -1
  46. package/lib/components/po-field/po-multiselect/po-multiselect.component.d.ts +7 -1
  47. package/lib/components/po-field/po-radio/po-radio-size.enum.d.ts +9 -2
  48. package/lib/components/po-field/po-radio/po-radio.component.d.ts +27 -10
  49. package/lib/components/po-field/po-radio-group/po-radio-group-base.component.d.ts +21 -1
  50. package/lib/components/po-field/po-select/po-select.component.d.ts +1 -32
  51. package/lib/components/po-field/po-textarea/po-textarea-base.component.d.ts +10 -0
  52. package/lib/components/po-modal/po-modal.component.d.ts +1 -1
  53. package/lib/components/po-table/po-table-column-manager/po-table-column-manager.component.d.ts +4 -12
  54. package/lib/components/po-table/po-table-detail/po-table-detail.component.d.ts +1 -0
  55. package/lib/components/po-table/po-table-list-manager/po-table-list-manager.component.d.ts +35 -0
  56. package/lib/components/po-table/po-table.module.d.ts +25 -24
  57. package/lib/components/po-tag/po-tag-base.component.d.ts +8 -2
  58. package/package.json +4 -4
  59. package/po-ui-ng-components-14.6.0.tgz +0 -0
  60. package/schematics/ng-add/index.js +1 -1
  61. package/schematics/ng-update/v14/index.js +1 -1
  62. package/schematics/ng-update/v2/index.js +1 -1
  63. package/schematics/ng-update/v3/index.js +1 -1
  64. package/schematics/ng-update/v4/index.js +1 -1
  65. package/schematics/ng-update/v5/index.js +1 -1
  66. package/schematics/ng-update/v6/index.js +1 -1
  67. package/esm2020/lib/components/po-field/po-radio/po-radio-base.component.mjs +0 -104
  68. package/lib/components/po-field/po-radio/po-radio-base.component.d.ts +0 -58
  69. package/po-ui-ng-components-14.4.0.tgz +0 -0
@@ -9,7 +9,7 @@ import * as i3 from "../po-field-container/po-field-container-bottom/po-field-co
9
9
  import * as i4 from "../po-field-container/po-field-container.component";
10
10
  function PoPasswordComponent_po_clean_7_Template(rf, ctx) { if (rf & 1) {
11
11
  const _r4 = i0.ɵɵgetCurrentView();
12
- i0.ɵɵelementStart(0, "po-clean", 10);
12
+ i0.ɵɵelementStart(0, "po-clean", 9);
13
13
  i0.ɵɵlistener("p-change-event", function PoPasswordComponent_po_clean_7_Template_po_clean_p_change_event_0_listener($event) { i0.ɵɵrestoreView(_r4); const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.clear($event)); });
14
14
  i0.ɵɵelementEnd();
15
15
  } if (rf & 2) {
@@ -18,7 +18,7 @@ function PoPasswordComponent_po_clean_7_Template(rf, ctx) { if (rf & 1) {
18
18
  } }
19
19
  function PoPasswordComponent_span_8_Template(rf, ctx) { if (rf & 1) {
20
20
  const _r6 = i0.ɵɵgetCurrentView();
21
- i0.ɵɵelementStart(0, "span", 11);
21
+ i0.ɵɵelementStart(0, "span", 10);
22
22
  i0.ɵɵlistener("click", function PoPasswordComponent_span_8_Template_span_click_0_listener() { i0.ɵɵrestoreView(_r6); const ctx_r5 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r5.showPassword()); });
23
23
  i0.ɵɵelementEnd();
24
24
  } if (rf & 2) {
@@ -98,28 +98,29 @@ PoPasswordComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoPassw
98
98
  useExisting: forwardRef(() => PoPasswordComponent),
99
99
  multi: true
100
100
  }
101
- ]), i0.ɵɵInheritDefinitionFeature], decls: 10, vars: 19, consts: [[3, "p-label", "p-help", "p-optional"], [1, "po-field-container-content"], [1, "po-field-icon-container-left"], [1, "po-icon", "po-field-icon", "po-icon-lock"], [1, "po-input", "po-input-icon-left", 3, "autocomplete", "disabled", "placeholder", "readonly", "required", "type", "blur", "click", "focus", "input"], ["inp", ""], [1, "po-field-icon-container-right"], [3, "p-element-ref", "p-change-event", 4, "ngIf"], ["class", "po-icon po-field-icon", 3, "ngClass", "click", 4, "ngIf"], [3, "p-error-pattern"], [3, "p-element-ref", "p-change-event"], [1, "po-icon", "po-field-icon", 3, "ngClass", "click"]], template: function PoPasswordComponent_Template(rf, ctx) { if (rf & 1) {
101
+ ]), i0.ɵɵInheritDefinitionFeature], decls: 10, vars: 23, consts: [[3, "p-label", "p-help", "p-optional"], [1, "po-field-container-content"], [1, "po-field-icon-container-left"], [1, "po-input", "po-input-icon-left", 3, "autocomplete", "disabled", "placeholder", "readonly", "required", "type", "blur", "click", "focus", "input"], ["inp", ""], [1, "po-field-icon-container-right"], ["class", "po-icon-input", 3, "p-element-ref", "p-change-event", 4, "ngIf"], ["class", "po-icon po-field-icon po-icon-input", 3, "ngClass", "click", 4, "ngIf"], [3, "p-error-pattern"], [1, "po-icon-input", 3, "p-element-ref", "p-change-event"], [1, "po-icon", "po-field-icon", "po-icon-input", 3, "ngClass", "click"]], template: function PoPasswordComponent_Template(rf, ctx) { if (rf & 1) {
102
102
  i0.ɵɵelementStart(0, "po-field-container", 0)(1, "div", 1)(2, "div", 2);
103
- i0.ɵɵelement(3, "span", 3);
103
+ i0.ɵɵelement(3, "span");
104
104
  i0.ɵɵelementEnd();
105
- i0.ɵɵelementStart(4, "input", 4, 5);
105
+ i0.ɵɵelementStart(4, "input", 3, 4);
106
106
  i0.ɵɵlistener("blur", function PoPasswordComponent_Template_input_blur_4_listener($event) { return ctx.eventOnBlur($event); })("click", function PoPasswordComponent_Template_input_click_4_listener($event) { return ctx.eventOnClick($event); })("focus", function PoPasswordComponent_Template_input_focus_4_listener($event) { return ctx.eventOnFocus($event); })("input", function PoPasswordComponent_Template_input_input_4_listener($event) { return ctx.eventOnInput($event); });
107
107
  i0.ɵɵelementEnd();
108
- i0.ɵɵelementStart(6, "div", 6);
109
- i0.ɵɵtemplate(7, PoPasswordComponent_po_clean_7_Template, 1, 1, "po-clean", 7);
110
- i0.ɵɵtemplate(8, PoPasswordComponent_span_8_Template, 1, 1, "span", 8);
108
+ i0.ɵɵelementStart(6, "div", 5);
109
+ i0.ɵɵtemplate(7, PoPasswordComponent_po_clean_7_Template, 1, 1, "po-clean", 6);
110
+ i0.ɵɵtemplate(8, PoPasswordComponent_span_8_Template, 1, 1, "span", 7);
111
111
  i0.ɵɵelementEnd()();
112
- i0.ɵɵelement(9, "po-field-container-bottom", 9);
112
+ i0.ɵɵelement(9, "po-field-container-bottom", 8);
113
113
  i0.ɵɵelementEnd();
114
114
  } if (rf & 2) {
115
115
  const _r0 = i0.ɵɵreference(5);
116
116
  i0.ɵɵproperty("p-label", ctx.label)("p-help", ctx.help)("p-optional", !ctx.required && ctx.optional);
117
117
  i0.ɵɵadvance(3);
118
+ i0.ɵɵclassMapInterpolate1("po-icon po-field-icon po-icon-lock ", ctx.disabled ? "po-icon-input-disabled" : "po-icon-input", "");
118
119
  i0.ɵɵclassProp("po-field-icon-disabled", ctx.disabled);
119
120
  i0.ɵɵadvance(1);
120
121
  i0.ɵɵclassProp("po-input-double-icon-right", ctx.clean && _r0.value && !ctx.hidePasswordPeek)("po-input-icon-right", ctx.clean || !ctx.hidePasswordPeek);
121
- i0.ɵɵproperty("autocomplete", ctx.autocomplete)("disabled", ctx.disabled)("placeholder", ctx.placeholder)("readonly", ctx.readonly)("required", ctx.required)("type", ctx.disabled ? "password" : ctx.type);
122
- i0.ɵɵattribute("name", ctx.name);
122
+ i0.ɵɵproperty("autocomplete", ctx.autocomplete)("disabled", ctx.disabled)("placeholder", ctx.disabled ? "" : ctx.placeholder)("readonly", ctx.readonly)("required", ctx.required)("type", ctx.disabled ? "password" : ctx.type);
123
+ i0.ɵɵattribute("name", ctx.name)("aria-label", ctx.label);
123
124
  i0.ɵɵadvance(3);
124
125
  i0.ɵɵproperty("ngIf", ctx.clean && !ctx.disabled && !ctx.readonly);
125
126
  i0.ɵɵadvance(1);
@@ -140,9 +141,9 @@ PoPasswordComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoPassw
140
141
  useExisting: forwardRef(() => PoPasswordComponent),
141
142
  multi: true
142
143
  }
143
- ], template: "<po-field-container [p-label]=\"label\" [p-help]=\"help\" [p-optional]=\"!required && optional\">\n <div class=\"po-field-container-content\">\n <div class=\"po-field-icon-container-left\">\n <span class=\"po-icon po-field-icon po-icon-lock\" [class.po-field-icon-disabled]=\"disabled\"> </span>\n </div>\n\n <input\n #inp\n class=\"po-input po-input-icon-left\"\n [attr.name]=\"name\"\n [autocomplete]=\"autocomplete\"\n [class.po-input-double-icon-right]=\"clean && inp.value && !hidePasswordPeek\"\n [class.po-input-icon-right]=\"clean || !hidePasswordPeek\"\n [disabled]=\"disabled\"\n [placeholder]=\"placeholder\"\n [readonly]=\"readonly\"\n [required]=\"required\"\n [type]=\"disabled ? 'password' : type\"\n (blur)=\"eventOnBlur($event)\"\n (click)=\"eventOnClick($event)\"\n (focus)=\"eventOnFocus($event)\"\n (input)=\"eventOnInput($event)\"\n />\n\n <div class=\"po-field-icon-container-right\">\n <po-clean *ngIf=\"clean && !disabled && !readonly\" [p-element-ref]=\"inputEl\" (p-change-event)=\"clear($event)\">\n </po-clean>\n\n <span\n *ngIf=\"!hidePasswordPeek && !disabled\"\n class=\"po-icon po-field-icon\"\n [ngClass]=\"visiblePassword ? 'po-icon-eye' : 'po-icon-eye-off po-field-icon-disabled'\"\n (click)=\"showPassword()\"\n >\n </span>\n </div>\n </div>\n\n <po-field-container-bottom [p-error-pattern]=\"getErrorPattern()\"> </po-field-container-bottom>\n</po-field-container>\n" }]
144
+ ], template: "<po-field-container [p-label]=\"label\" [p-help]=\"help\" [p-optional]=\"!required && optional\">\n <div class=\"po-field-container-content\">\n <div class=\"po-field-icon-container-left\">\n <span\n class=\"po-icon po-field-icon po-icon-lock {{ disabled ? 'po-icon-input-disabled' : 'po-icon-input' }}\"\n [class.po-field-icon-disabled]=\"disabled\"\n >\n </span>\n </div>\n\n <input\n #inp\n class=\"po-input po-input-icon-left\"\n [attr.name]=\"name\"\n [attr.aria-label]=\"label\"\n [autocomplete]=\"autocomplete\"\n [class.po-input-double-icon-right]=\"clean && inp.value && !hidePasswordPeek\"\n [class.po-input-icon-right]=\"clean || !hidePasswordPeek\"\n [disabled]=\"disabled\"\n [placeholder]=\"disabled ? '' : placeholder\"\n [readonly]=\"readonly\"\n [required]=\"required\"\n [type]=\"disabled ? 'password' : type\"\n (blur)=\"eventOnBlur($event)\"\n (click)=\"eventOnClick($event)\"\n (focus)=\"eventOnFocus($event)\"\n (input)=\"eventOnInput($event)\"\n />\n\n <div class=\"po-field-icon-container-right\">\n <po-clean\n class=\"po-icon-input\"\n *ngIf=\"clean && !disabled && !readonly\"\n [p-element-ref]=\"inputEl\"\n (p-change-event)=\"clear($event)\"\n >\n </po-clean>\n\n <span\n *ngIf=\"!hidePasswordPeek && !disabled\"\n class=\"po-icon po-field-icon po-icon-input\"\n [ngClass]=\"visiblePassword ? 'po-icon-eye' : 'po-icon-eye-off po-field-icon-disabled'\"\n (click)=\"showPassword()\"\n >\n </span>\n </div>\n </div>\n\n <po-field-container-bottom [p-error-pattern]=\"getErrorPattern()\"> </po-field-container-bottom>\n</po-field-container>\n" }]
144
145
  }], function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, { hidePasswordPeek: [{
145
146
  type: Input,
146
147
  args: ['p-hide-password-peek']
147
148
  }] }); })();
148
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-password.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-password/po-password.component.ts","../../../../../../../projects/ui/src/lib/components/po-field/po-password/po-password.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl, NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, forwardRef, Input } from '@angular/core';\n\nimport { convertToBoolean } from '../../../utils/util';\nimport { PoInputGeneric } from '../po-input-generic/po-input-generic';\n\n/**\n * @docsExtends PoInputBaseComponent\n *\n * @description\n * O po-password é um input específico para senhas. Já possui tipo, estilo e ícone predefinidos.\n *\n * @example\n *\n * <example name=\"po-password-basic\" title=\"PO Password Basic\">\n *   <file name=\"sample-po-password-basic/sample-po-password-basic.component.html\"> </file>\n *   <file name=\"sample-po-password-basic/sample-po-password-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-password-labs\" title=\"PO Password Labs\">\n *   <file name=\"sample-po-password-labs/sample-po-password-labs.component.html\"> </file>\n *   <file name=\"sample-po-password-labs/sample-po-password-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-password-reset\" title=\"PO Password - Reset\">\n *   <file name=\"sample-po-password-reset/sample-po-password-reset.component.html\"> </file>\n *   <file name=\"sample-po-password-reset/sample-po-password-reset.component.ts\"> </file>\n * </example>\n */\n@Component({\n  selector: 'po-password',\n  templateUrl: './po-password.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PoPasswordComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => PoPasswordComponent),\n      multi: true\n    }\n  ]\n})\nexport class PoPasswordComponent extends PoInputGeneric {\n  type = 'password';\n  visiblePassword = false;\n\n  private _hidePasswordPeek?: boolean = false;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Permite esconder a função de espiar a senha digitada.\n   *\n   * @default `false`\n   */\n  @Input('p-hide-password-peek') set hidePasswordPeek(value: boolean) {\n    this._hidePasswordPeek = convertToBoolean(value);\n    if (value) {\n      this.visiblePassword = false;\n      this.type = 'password';\n    }\n  }\n\n  get hidePasswordPeek(): boolean {\n    return this._hidePasswordPeek;\n  }\n\n  get autocomplete(): string {\n    return this.noAutocomplete ? 'new-password' : 'on';\n  }\n\n  /* istanbul ignore next */\n  constructor(el: ElementRef, cd: ChangeDetectorRef) {\n    super(el, cd);\n  }\n\n  extraValidation(c: AbstractControl): { [key: string]: any } {\n    return null;\n  }\n\n  showPassword() {\n    this.visiblePassword = !this.visiblePassword;\n    this.type = this.type === 'password' ? 'text' : 'password';\n  }\n}\n","<po-field-container [p-label]=\"label\" [p-help]=\"help\" [p-optional]=\"!required && optional\">\n  <div class=\"po-field-container-content\">\n    <div class=\"po-field-icon-container-left\">\n      <span class=\"po-icon po-field-icon po-icon-lock\" [class.po-field-icon-disabled]=\"disabled\"> </span>\n    </div>\n\n    <input\n      #inp\n      class=\"po-input po-input-icon-left\"\n      [attr.name]=\"name\"\n      [autocomplete]=\"autocomplete\"\n      [class.po-input-double-icon-right]=\"clean && inp.value && !hidePasswordPeek\"\n      [class.po-input-icon-right]=\"clean || !hidePasswordPeek\"\n      [disabled]=\"disabled\"\n      [placeholder]=\"placeholder\"\n      [readonly]=\"readonly\"\n      [required]=\"required\"\n      [type]=\"disabled ? 'password' : type\"\n      (blur)=\"eventOnBlur($event)\"\n      (click)=\"eventOnClick($event)\"\n      (focus)=\"eventOnFocus($event)\"\n      (input)=\"eventOnInput($event)\"\n    />\n\n    <div class=\"po-field-icon-container-right\">\n      <po-clean *ngIf=\"clean && !disabled && !readonly\" [p-element-ref]=\"inputEl\" (p-change-event)=\"clear($event)\">\n      </po-clean>\n\n      <span\n        *ngIf=\"!hidePasswordPeek && !disabled\"\n        class=\"po-icon po-field-icon\"\n        [ngClass]=\"visiblePassword ? 'po-icon-eye' : 'po-icon-eye-off po-field-icon-disabled'\"\n        (click)=\"showPassword()\"\n      >\n      </span>\n    </div>\n  </div>\n\n  <po-field-container-bottom [p-error-pattern]=\"getErrorPattern()\"> </po-field-container-bottom>\n</po-field-container>\n"]}
149
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-password.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-password/po-password.component.ts","../../../../../../../projects/ui/src/lib/components/po-field/po-password/po-password.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl, NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, forwardRef, Input } from '@angular/core';\n\nimport { convertToBoolean } from '../../../utils/util';\nimport { PoInputGeneric } from '../po-input-generic/po-input-generic';\n\n/**\n * @docsExtends PoInputBaseComponent\n *\n * @description\n * O po-password é um input específico para senhas. Já possui tipo, estilo e ícone predefinidos.\n *\n * @example\n *\n * <example name=\"po-password-basic\" title=\"PO Password Basic\">\n *   <file name=\"sample-po-password-basic/sample-po-password-basic.component.html\"> </file>\n *   <file name=\"sample-po-password-basic/sample-po-password-basic.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-password-labs\" title=\"PO Password Labs\">\n *   <file name=\"sample-po-password-labs/sample-po-password-labs.component.html\"> </file>\n *   <file name=\"sample-po-password-labs/sample-po-password-labs.component.ts\"> </file>\n * </example>\n *\n * <example name=\"po-password-reset\" title=\"PO Password - Reset\">\n *   <file name=\"sample-po-password-reset/sample-po-password-reset.component.html\"> </file>\n *   <file name=\"sample-po-password-reset/sample-po-password-reset.component.ts\"> </file>\n * </example>\n */\n@Component({\n  selector: 'po-password',\n  templateUrl: './po-password.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PoPasswordComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => PoPasswordComponent),\n      multi: true\n    }\n  ]\n})\nexport class PoPasswordComponent extends PoInputGeneric {\n  type = 'password';\n  visiblePassword = false;\n\n  private _hidePasswordPeek?: boolean = false;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Permite esconder a função de espiar a senha digitada.\n   *\n   * @default `false`\n   */\n  @Input('p-hide-password-peek') set hidePasswordPeek(value: boolean) {\n    this._hidePasswordPeek = convertToBoolean(value);\n    if (value) {\n      this.visiblePassword = false;\n      this.type = 'password';\n    }\n  }\n\n  get hidePasswordPeek(): boolean {\n    return this._hidePasswordPeek;\n  }\n\n  get autocomplete(): string {\n    return this.noAutocomplete ? 'new-password' : 'on';\n  }\n\n  /* istanbul ignore next */\n  constructor(el: ElementRef, cd: ChangeDetectorRef) {\n    super(el, cd);\n  }\n\n  extraValidation(c: AbstractControl): { [key: string]: any } {\n    return null;\n  }\n\n  showPassword() {\n    this.visiblePassword = !this.visiblePassword;\n    this.type = this.type === 'password' ? 'text' : 'password';\n  }\n}\n","<po-field-container [p-label]=\"label\" [p-help]=\"help\" [p-optional]=\"!required && optional\">\n  <div class=\"po-field-container-content\">\n    <div class=\"po-field-icon-container-left\">\n      <span\n        class=\"po-icon po-field-icon po-icon-lock {{ disabled ? 'po-icon-input-disabled' : 'po-icon-input' }}\"\n        [class.po-field-icon-disabled]=\"disabled\"\n      >\n      </span>\n    </div>\n\n    <input\n      #inp\n      class=\"po-input po-input-icon-left\"\n      [attr.name]=\"name\"\n      [attr.aria-label]=\"label\"\n      [autocomplete]=\"autocomplete\"\n      [class.po-input-double-icon-right]=\"clean && inp.value && !hidePasswordPeek\"\n      [class.po-input-icon-right]=\"clean || !hidePasswordPeek\"\n      [disabled]=\"disabled\"\n      [placeholder]=\"disabled ? '' : placeholder\"\n      [readonly]=\"readonly\"\n      [required]=\"required\"\n      [type]=\"disabled ? 'password' : type\"\n      (blur)=\"eventOnBlur($event)\"\n      (click)=\"eventOnClick($event)\"\n      (focus)=\"eventOnFocus($event)\"\n      (input)=\"eventOnInput($event)\"\n    />\n\n    <div class=\"po-field-icon-container-right\">\n      <po-clean\n        class=\"po-icon-input\"\n        *ngIf=\"clean && !disabled && !readonly\"\n        [p-element-ref]=\"inputEl\"\n        (p-change-event)=\"clear($event)\"\n      >\n      </po-clean>\n\n      <span\n        *ngIf=\"!hidePasswordPeek && !disabled\"\n        class=\"po-icon po-field-icon po-icon-input\"\n        [ngClass]=\"visiblePassword ? 'po-icon-eye' : 'po-icon-eye-off po-field-icon-disabled'\"\n        (click)=\"showPassword()\"\n      >\n      </span>\n    </div>\n  </div>\n\n  <po-field-container-bottom [p-error-pattern]=\"getErrorPattern()\"> </po-field-container-bottom>\n</po-field-container>\n"]}
@@ -1,6 +1,13 @@
1
+ /**
2
+ * @usedBy PoRadioComponent
3
+ *
4
+ * @description
5
+ *
6
+ * Enum para definir o tamanho do po-radio.
7
+ */
1
8
  export var PoRadioSize;
2
9
  (function (PoRadioSize) {
3
- PoRadioSize["medium"] = "medium";
4
- PoRadioSize["large"] = "large";
10
+ PoRadioSize["Medium"] = "medium";
11
+ PoRadioSize["Large"] = "large";
5
12
  })(PoRadioSize || (PoRadioSize = {}));
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8tcmFkaW8tc2l6ZS5lbnVtLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkvc3JjL2xpYi9jb21wb25lbnRzL3BvLWZpZWxkL3BvLXJhZGlvL3BvLXJhZGlvLXNpemUuZW51bS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQU4sSUFBWSxXQUdYO0FBSEQsV0FBWSxXQUFXO0lBQ3JCLGdDQUFpQixDQUFBO0lBQ2pCLDhCQUFlLENBQUE7QUFDakIsQ0FBQyxFQUhXLFdBQVcsS0FBWCxXQUFXLFFBR3RCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gUG9SYWRpb1NpemUge1xuICBtZWRpdW0gPSAnbWVkaXVtJyxcbiAgbGFyZ2UgPSAnbGFyZ2UnXG59XG4iXX0=
13
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8tcmFkaW8tc2l6ZS5lbnVtLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkvc3JjL2xpYi9jb21wb25lbnRzL3BvLWZpZWxkL3BvLXJhZGlvL3BvLXJhZGlvLXNpemUuZW51bS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFDSCxNQUFNLENBQU4sSUFBWSxXQUdYO0FBSEQsV0FBWSxXQUFXO0lBQ3JCLGdDQUFpQixDQUFBO0lBQ2pCLDhCQUFlLENBQUE7QUFDakIsQ0FBQyxFQUhXLFdBQVcsS0FBWCxXQUFXLFFBR3RCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAdXNlZEJ5IFBvUmFkaW9Db21wb25lbnRcbiAqXG4gKiBAZGVzY3JpcHRpb25cbiAqXG4gKiBFbnVtIHBhcmEgZGVmaW5pciBvIHRhbWFuaG8gZG8gcG8tcmFkaW8uXG4gKi9cbmV4cG9ydCBlbnVtIFBvUmFkaW9TaXplIHtcbiAgTWVkaXVtID0gJ21lZGl1bScsXG4gIExhcmdlID0gJ2xhcmdlJ1xufVxuIl19
@@ -1,21 +1,44 @@
1
- import { ChangeDetectionStrategy, Component, forwardRef, ViewChild } from '@angular/core';
1
+ import { __decorate } from "tslib";
2
+ import { ChangeDetectionStrategy, Component, forwardRef, HostListener, Input, ViewChild } from '@angular/core';
2
3
  import { NG_VALUE_ACCESSOR } from '@angular/forms';
4
+ import { InputBoolean } from '../../../decorators';
5
+ import { PoFieldModel } from '../po-field.model';
3
6
  import { PoKeyCodeEnum } from './../../../enums/po-key-code.enum';
4
- import { PoRadioBaseComponent } from './po-radio-base.component';
7
+ import { PoRadioSize } from './po-radio-size.enum';
5
8
  import * as i0 from "@angular/core";
6
9
  import * as i1 from "@angular/common";
7
10
  const _c0 = ["radioLabel"];
8
- const _c1 = function (a0) { return { "po-radio-large": a0 }; };
9
- const _c2 = function (a0) { return { "po-radio-label-disabled": a0 }; };
10
- /**
11
- * @docsPrivate
12
- *
13
- * @docsExtends PoRadioBaseComponent
14
- */
15
- export class PoRadioComponent extends PoRadioBaseComponent {
11
+ function PoRadioComponent_span_4_Template(rf, ctx) { if (rf & 1) {
12
+ i0.ɵɵelementStart(0, "span");
13
+ i0.ɵɵtext(1);
14
+ i0.ɵɵelementEnd();
15
+ } if (rf & 2) {
16
+ const ctx_r1 = i0.ɵɵnextContext();
17
+ i0.ɵɵadvance(1);
18
+ i0.ɵɵtextInterpolate(ctx_r1.label);
19
+ } }
20
+ export class PoRadioComponent extends PoFieldModel {
16
21
  constructor(changeDetector) {
17
22
  super();
18
23
  this.changeDetector = changeDetector;
24
+ this.value = false;
25
+ this._size = PoRadioSize.Medium;
26
+ /** Define o status do *radio* */
27
+ this.checked = false;
28
+ }
29
+ /**
30
+ * @optional
31
+ *
32
+ * @description
33
+ *
34
+ * Define o tamanho do *radio*
35
+ * @default `medium`
36
+ */
37
+ set size(value) {
38
+ this._size = Object.values(PoRadioSize).includes(value) ? value : PoRadioSize.Medium;
39
+ }
40
+ get size() {
41
+ return this._size;
19
42
  }
20
43
  /**
21
44
  * Função que atribui foco ao *radio*.
@@ -37,22 +60,42 @@ export class PoRadioComponent extends PoRadioBaseComponent {
37
60
  *
38
61
  */
39
62
  focus() {
40
- if (this.radioLabel && !this.disabled) {
63
+ if (!this.disabled) {
41
64
  this.radioLabel.nativeElement.focus();
42
65
  }
43
66
  }
44
67
  onBlur() {
45
68
  this.onTouched?.();
46
69
  }
47
- onKeyDown(event, value) {
70
+ onKeyDown(event) {
48
71
  if (event.which === PoKeyCodeEnum.space || event.keyCode === PoKeyCodeEnum.space) {
49
- this.checkOption(value);
50
- event.preventDefault();
72
+ this.eventClick();
73
+ }
74
+ }
75
+ changeValue(value) {
76
+ if (value) {
77
+ this.value = value;
78
+ this.updateModel(value);
79
+ this.emitChange(this.value);
80
+ }
81
+ }
82
+ eventClick() {
83
+ if (!this.disabled) {
84
+ this.changeValue(!this.value);
85
+ this.changeDetector.detectChanges();
51
86
  }
52
87
  }
53
- changeModelValue(value) {
54
- this.radioValue = typeof value === 'boolean' ? value : false;
55
- this.changeDetector.detectChanges();
88
+ onWriteValue(value) {
89
+ if (value !== this.value) {
90
+ this.value = !!value;
91
+ this.changeDetector.markForCheck();
92
+ }
93
+ }
94
+ focusIn() {
95
+ this.radioLabel.nativeElement.setAttribute('focus', '');
96
+ }
97
+ focusOut() {
98
+ this.radioLabel.nativeElement.removeAttribute('focus');
56
99
  }
57
100
  }
58
101
  PoRadioComponent.ɵfac = function PoRadioComponent_Factory(t) { return new (t || PoRadioComponent)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef)); };
@@ -61,29 +104,32 @@ PoRadioComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoRadioCom
61
104
  } if (rf & 2) {
62
105
  let _t;
63
106
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.radioLabel = _t.first);
64
- } }, features: [i0.ɵɵProvidersFeature([
107
+ } }, hostBindings: function PoRadioComponent_HostBindings(rf, ctx) { if (rf & 1) {
108
+ i0.ɵɵlistener("focusin", function PoRadioComponent_focusin_HostBindingHandler($event) { return ctx.focusIn($event.target); })("focusout", function PoRadioComponent_focusout_HostBindingHandler($event) { return ctx.focusOut($event.target); });
109
+ } }, inputs: { radioValue: ["p-value", "radioValue"], size: ["p-size", "size"], required: ["p-required", "required"], checked: ["p-checked", "checked"] }, features: [i0.ɵɵProvidersFeature([
65
110
  {
66
111
  provide: NG_VALUE_ACCESSOR,
67
112
  useExisting: forwardRef(() => PoRadioComponent),
68
113
  multi: true
69
114
  }
70
- ]), i0.ɵɵInheritDefinitionFeature], decls: 5, vars: 15, consts: [[1, "po-radio-container", 3, "click", "keydown"], ["type", "radio", "role", "radio", 1, "po-radio", 3, "ngClass", "id", "tabindex", "disabled"], ["tabindex", "-1", 1, "po-radio-label", 3, "for", "ngClass"], ["radioLabel", ""]], template: function PoRadioComponent_Template(rf, ctx) { if (rf & 1) {
71
- i0.ɵɵelementStart(0, "div", 0);
72
- i0.ɵɵlistener("click", function PoRadioComponent_Template_div_click_0_listener() { return ctx.checkOption(ctx.radioValue); })("keydown", function PoRadioComponent_Template_div_keydown_0_listener($event) { return ctx.onKeyDown($event, ctx.radioValue); });
73
- i0.ɵɵelement(1, "input", 1);
74
- i0.ɵɵelementStart(2, "label", 2, 3);
75
- i0.ɵɵtext(4);
115
+ ]), i0.ɵɵInheritDefinitionFeature], decls: 5, vars: 7, consts: [[1, "po-radio"], [3, "click", "keydown"], ["radioLabel", ""], ["type", "radio", 3, "checked", "disabled", "name", "required", "value"], [4, "ngIf"]], template: function PoRadioComponent_Template(rf, ctx) { if (rf & 1) {
116
+ i0.ɵɵelementStart(0, "div", 0)(1, "label", 1, 2);
117
+ i0.ɵɵlistener("click", function PoRadioComponent_Template_label_click_1_listener() { return ctx.eventClick(); })("keydown", function PoRadioComponent_Template_label_keydown_1_listener($event) { return ctx.onKeyDown($event); });
118
+ i0.ɵɵelement(3, "input", 3);
119
+ i0.ɵɵtemplate(4, PoRadioComponent_span_4_Template, 2, 1, "span", 4);
76
120
  i0.ɵɵelementEnd()();
77
121
  } if (rf & 2) {
78
- i0.ɵɵattribute("checked", ctx.radioValue);
79
- i0.ɵɵadvance(1);
80
- i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(11, _c1, ctx.size === "large"))("id", ctx.id)("tabindex", ctx.disabled ? -1 : 0)("disabled", ctx.disabled);
81
- i0.ɵɵattribute("aria-checked", ctx.radioValue)("aria-label", ctx.label)("aria-disabled", ctx.disabled);
122
+ let tmp_2_0;
123
+ let tmp_4_0;
124
+ i0.ɵɵadvance(3);
125
+ i0.ɵɵproperty("checked", ctx.checked)("disabled", ctx.disabled)("name", (tmp_2_0 = ctx.name) !== null && tmp_2_0 !== undefined ? tmp_2_0 : "po-input-radio")("required", ctx.required)("value", (tmp_4_0 = ctx.radioValue) !== null && tmp_4_0 !== undefined ? tmp_4_0 : "");
126
+ i0.ɵɵattribute("p-size", ctx.size);
82
127
  i0.ɵɵadvance(1);
83
- i0.ɵɵproperty("for", ctx.id)("ngClass", i0.ɵɵpureFunction1(13, _c2, ctx.disabled));
84
- i0.ɵɵadvance(2);
85
- i0.ɵɵtextInterpolate1(" ", ctx.label, " ");
86
- } }, dependencies: [i1.NgClass], encapsulation: 2, changeDetection: 0 });
128
+ i0.ɵɵproperty("ngIf", ctx.label);
129
+ } }, dependencies: [i1.NgIf], encapsulation: 2, changeDetection: 0 });
130
+ __decorate([
131
+ InputBoolean()
132
+ ], PoRadioComponent.prototype, "required", void 0);
87
133
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoRadioComponent, [{
88
134
  type: Component,
89
135
  args: [{ selector: 'po-radio', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
@@ -92,9 +138,27 @@ PoRadioComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoRadioCom
92
138
  useExisting: forwardRef(() => PoRadioComponent),
93
139
  multi: true
94
140
  }
95
- ], template: "<div\n class=\"po-radio-container\"\n [attr.checked]=\"radioValue\"\n (click)=\"checkOption(radioValue)\"\n (keydown)=\"onKeyDown($event, radioValue)\"\n>\n <input\n type=\"radio\"\n [ngClass]=\"{ 'po-radio-large': size === 'large' }\"\n [attr.aria-checked]=\"radioValue\"\n [attr.aria-label]=\"label\"\n [id]=\"id\"\n class=\"po-radio\"\n role=\"radio\"\n [attr.aria-disabled]=\"disabled\"\n [tabindex]=\"disabled ? -1 : 0\"\n [disabled]=\"disabled\"\n />\n <label\n #radioLabel\n [for]=\"id\"\n class=\"po-radio-label\"\n [ngClass]=\"{ 'po-radio-label-disabled': disabled }\"\n tabindex=\"-1\"\n >\n {{ label }}\n </label>\n</div>\n" }]
141
+ ], template: "<div class=\"po-radio\">\n <label #radioLabel (click)=\"eventClick()\" (keydown)=\"onKeyDown($event)\">\n <input\n type=\"radio\"\n [attr.p-size]=\"size\"\n [checked]=\"checked\"\n [disabled]=\"disabled\"\n [name]=\"name ?? 'po-input-radio'\"\n [required]=\"required\"\n [value]=\"radioValue ?? ''\"\n />\n <span *ngIf=\"label\">{{ label }}</span>\n </label>\n</div>\n" }]
96
142
  }], function () { return [{ type: i0.ChangeDetectorRef }]; }, { radioLabel: [{
97
143
  type: ViewChild,
98
144
  args: ['radioLabel', { static: true }]
145
+ }], radioValue: [{
146
+ type: Input,
147
+ args: ['p-value']
148
+ }], size: [{
149
+ type: Input,
150
+ args: ['p-size']
151
+ }], required: [{
152
+ type: Input,
153
+ args: ['p-required']
154
+ }], checked: [{
155
+ type: Input,
156
+ args: ['p-checked']
157
+ }], focusIn: [{
158
+ type: HostListener,
159
+ args: ['focusin', ['$event.target']]
160
+ }], focusOut: [{
161
+ type: HostListener,
162
+ args: ['focusout', ['$event.target']]
99
163
  }] }); })();
100
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8tcmFkaW8uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkvc3JjL2xpYi9jb21wb25lbnRzL3BvLWZpZWxkL3BvLXJhZGlvL3BvLXJhZGlvLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL3NyYy9saWIvY29tcG9uZW50cy9wby1maWVsZC9wby1yYWRpby9wby1yYWRpby5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBRXZCLFNBQVMsRUFFVCxVQUFVLEVBQ1YsU0FBUyxFQUNWLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRW5ELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUNsRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQzs7Ozs7O0FBRWpFOzs7O0dBSUc7QUFhSCxNQUFNLE9BQU8sZ0JBQWlCLFNBQVEsb0JBQW9CO0lBR3hELFlBQW9CLGNBQWlDO1FBQ25ELEtBQUssRUFBRSxDQUFDO1FBRFUsbUJBQWMsR0FBZCxjQUFjLENBQW1CO0lBRXJELENBQUM7SUFFRDs7Ozs7Ozs7Ozs7Ozs7Ozs7O09Ba0JHO0lBQ0gsS0FBSztRQUNILElBQUksSUFBSSxDQUFDLFVBQVUsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUU7WUFDckMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsS0FBSyxFQUFFLENBQUM7U0FDdkM7SUFDSCxDQUFDO0lBRUQsTUFBTTtRQUNKLElBQUksQ0FBQyxTQUFTLEVBQUUsRUFBRSxDQUFDO0lBQ3JCLENBQUM7SUFFRCxTQUFTLENBQUMsS0FBb0IsRUFBRSxLQUFjO1FBQzVDLElBQUksS0FBSyxDQUFDLEtBQUssS0FBSyxhQUFhLENBQUMsS0FBSyxJQUFJLEtBQUssQ0FBQyxPQUFPLEtBQUssYUFBYSxDQUFDLEtBQUssRUFBRTtZQUNoRixJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBRXhCLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztTQUN4QjtJQUNILENBQUM7SUFFUyxnQkFBZ0IsQ0FBQyxLQUF1QjtRQUNoRCxJQUFJLENBQUMsVUFBVSxHQUFHLE9BQU8sS0FBSyxLQUFLLFNBQVMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUM7UUFDN0QsSUFBSSxDQUFDLGNBQWMsQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUN0QyxDQUFDOztnRkEvQ1UsZ0JBQWdCO21FQUFoQixnQkFBZ0I7Ozs7OzBDQVJoQjtZQUNUO2dCQUNFLE9BQU8sRUFBRSxpQkFBaUI7Z0JBQzFCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsZ0JBQWdCLENBQUM7Z0JBQy9DLEtBQUssRUFBRSxJQUFJO2FBQ1o7U0FDRjtRQzVCSCw4QkFLQztRQUZDLDBGQUFTLCtCQUF1QixJQUFDLHVGQUN0QixxQ0FBNkIsSUFEUDtRQUdqQywyQkFXRTtRQUNGLG1DQU1DO1FBQ0MsWUFDRjtRQUFBLGlCQUFRLEVBQUE7O1FBeEJSLHlDQUEyQjtRQU16QixlQUFrRDtRQUFsRCwyRUFBa0QsY0FBQSxtQ0FBQSwwQkFBQTtRQUNsRCw4Q0FBZ0MseUJBQUEsK0JBQUE7UUFXaEMsZUFBVTtRQUFWLDRCQUFVLHNEQUFBO1FBS1YsZUFDRjtRQURFLDBDQUNGOzt1RkRJVyxnQkFBZ0I7Y0FaNUIsU0FBUzsyQkFDRSxVQUFVLG1CQUVILHVCQUF1QixDQUFDLE1BQU0sYUFDcEM7b0JBQ1Q7d0JBQ0UsT0FBTyxFQUFFLGlCQUFpQjt3QkFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsaUJBQWlCLENBQUM7d0JBQy9DLEtBQUssRUFBRSxJQUFJO3FCQUNaO2lCQUNGO29FQUcwQyxVQUFVO2tCQUFwRCxTQUFTO21CQUFDLFlBQVksRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ2hhbmdlRGV0ZWN0b3JSZWYsXG4gIENvbXBvbmVudCxcbiAgRWxlbWVudFJlZixcbiAgZm9yd2FyZFJlZixcbiAgVmlld0NoaWxkXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTkdfVkFMVUVfQUNDRVNTT1IgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cbmltcG9ydCB7IFBvS2V5Q29kZUVudW0gfSBmcm9tICcuLy4uLy4uLy4uL2VudW1zL3BvLWtleS1jb2RlLmVudW0nO1xuaW1wb3J0IHsgUG9SYWRpb0Jhc2VDb21wb25lbnQgfSBmcm9tICcuL3BvLXJhZGlvLWJhc2UuY29tcG9uZW50JztcblxuLyoqXG4gKiBAZG9jc1ByaXZhdGVcbiAqXG4gKiBAZG9jc0V4dGVuZHMgUG9SYWRpb0Jhc2VDb21wb25lbnRcbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncG8tcmFkaW8nLFxuICB0ZW1wbGF0ZVVybDogJy4vcG8tcmFkaW8uY29tcG9uZW50Lmh0bWwnLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgcHJvdmlkZXJzOiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXG4gICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBQb1JhZGlvQ29tcG9uZW50KSxcbiAgICAgIG11bHRpOiB0cnVlXG4gICAgfVxuICBdXG59KVxuZXhwb3J0IGNsYXNzIFBvUmFkaW9Db21wb25lbnQgZXh0ZW5kcyBQb1JhZGlvQmFzZUNvbXBvbmVudCB7XG4gIEBWaWV3Q2hpbGQoJ3JhZGlvTGFiZWwnLCB7IHN0YXRpYzogdHJ1ZSB9KSByYWRpb0xhYmVsOiBFbGVtZW50UmVmO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgY2hhbmdlRGV0ZWN0b3I6IENoYW5nZURldGVjdG9yUmVmKSB7XG4gICAgc3VwZXIoKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBGdW7Dp8OjbyBxdWUgYXRyaWJ1aSBmb2NvIGFvICpyYWRpbyouXG4gICAqXG4gICAqIFBhcmEgdXRpbGl6w6EtbGEgw6kgbmVjZXNzw6FyaW8gY2FwdHVyYXIgYSByZWZlcsOqbmNpYSBkbyBjb21wb25lbnRlIG5vIERPTSBhdHJhdsOpcyBkbyBgVmlld0NoaWxkYCwgY29tbyBwb3IgZXhlbXBsbzpcbiAgICpcbiAgICogYGBgXG4gICAqIGltcG9ydCB7IFZpZXdDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuICAgKiBpbXBvcnQgeyBQb1JhZGlvQ29tcG9uZW50IH0gZnJvbSAnQHBvLXVpL25nLWNvbXBvbmVudHMnO1xuICAgKlxuICAgKiAuLi5cbiAgICpcbiAgICogQFZpZXdDaGlsZChQb1JhZGlvQ29tcG9uZW50LCB7IHN0YXRpYzogdHJ1ZSB9KSByYWRpbzogUG9SYWRpb0NvbXBvbmVudDtcbiAgICpcbiAgICogZm9jdXNSYWRpbygpIHtcbiAgICogdGhpcy5yYWRpby5mb2N1cygpO1xuICAgKiB9XG4gICAqIGBgYFxuICAgKlxuICAgKi9cbiAgZm9jdXMoKTogdm9pZCB7XG4gICAgaWYgKHRoaXMucmFkaW9MYWJlbCAmJiAhdGhpcy5kaXNhYmxlZCkge1xuICAgICAgdGhpcy5yYWRpb0xhYmVsLm5hdGl2ZUVsZW1lbnQuZm9jdXMoKTtcbiAgICB9XG4gIH1cblxuICBvbkJsdXIoKSB7XG4gICAgdGhpcy5vblRvdWNoZWQ/LigpO1xuICB9XG5cbiAgb25LZXlEb3duKGV2ZW50OiBLZXlib2FyZEV2ZW50LCB2YWx1ZTogYm9vbGVhbikge1xuICAgIGlmIChldmVudC53aGljaCA9PT0gUG9LZXlDb2RlRW51bS5zcGFjZSB8fCBldmVudC5rZXlDb2RlID09PSBQb0tleUNvZGVFbnVtLnNwYWNlKSB7XG4gICAgICB0aGlzLmNoZWNrT3B0aW9uKHZhbHVlKTtcblxuICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbiAgICB9XG4gIH1cblxuICBwcm90ZWN0ZWQgY2hhbmdlTW9kZWxWYWx1ZSh2YWx1ZTogYm9vbGVhbiB8IHN0cmluZykge1xuICAgIHRoaXMucmFkaW9WYWx1ZSA9IHR5cGVvZiB2YWx1ZSA9PT0gJ2Jvb2xlYW4nID8gdmFsdWUgOiBmYWxzZTtcbiAgICB0aGlzLmNoYW5nZURldGVjdG9yLmRldGVjdENoYW5nZXMoKTtcbiAgfVxufVxuIiwiPGRpdlxuICBjbGFzcz1cInBvLXJhZGlvLWNvbnRhaW5lclwiXG4gIFthdHRyLmNoZWNrZWRdPVwicmFkaW9WYWx1ZVwiXG4gIChjbGljayk9XCJjaGVja09wdGlvbihyYWRpb1ZhbHVlKVwiXG4gIChrZXlkb3duKT1cIm9uS2V5RG93bigkZXZlbnQsIHJhZGlvVmFsdWUpXCJcbj5cbiAgPGlucHV0XG4gICAgdHlwZT1cInJhZGlvXCJcbiAgICBbbmdDbGFzc109XCJ7ICdwby1yYWRpby1sYXJnZSc6IHNpemUgPT09ICdsYXJnZScgfVwiXG4gICAgW2F0dHIuYXJpYS1jaGVja2VkXT1cInJhZGlvVmFsdWVcIlxuICAgIFthdHRyLmFyaWEtbGFiZWxdPVwibGFiZWxcIlxuICAgIFtpZF09XCJpZFwiXG4gICAgY2xhc3M9XCJwby1yYWRpb1wiXG4gICAgcm9sZT1cInJhZGlvXCJcbiAgICBbYXR0ci5hcmlhLWRpc2FibGVkXT1cImRpc2FibGVkXCJcbiAgICBbdGFiaW5kZXhdPVwiZGlzYWJsZWQgPyAtMSA6IDBcIlxuICAgIFtkaXNhYmxlZF09XCJkaXNhYmxlZFwiXG4gIC8+XG4gIDxsYWJlbFxuICAgICNyYWRpb0xhYmVsXG4gICAgW2Zvcl09XCJpZFwiXG4gICAgY2xhc3M9XCJwby1yYWRpby1sYWJlbFwiXG4gICAgW25nQ2xhc3NdPVwieyAncG8tcmFkaW8tbGFiZWwtZGlzYWJsZWQnOiBkaXNhYmxlZCB9XCJcbiAgICB0YWJpbmRleD1cIi0xXCJcbiAgPlxuICAgIHt7IGxhYmVsIH19XG4gIDwvbGFiZWw+XG48L2Rpdj5cbiJdfQ==
164
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-radio.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-radio/po-radio.component.ts","../../../../../../../projects/ui/src/lib/components/po-field/po-radio/po-radio.component.html"],"names":[],"mappings":";AAAA,OAAO,EACL,uBAAuB,EAEvB,SAAS,EAET,UAAU,EACV,YAAY,EACZ,KAAK,EACL,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAEnD,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAElE,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;;;;;ICL/C,4BAAoB;IAAA,YAAW;IAAA,iBAAO;;;IAAlB,eAAW;IAAX,kCAAW;;ADmBnC,MAAM,OAAO,gBAAiB,SAAQ,YAAqB;IA+BzD,YAAoB,cAAiC;QACnD,KAAK,EAAE,CAAC;QADU,mBAAc,GAAd,cAAc,CAAmB;QA5BrD,UAAK,GAAG,KAAK,CAAC;QAEN,UAAK,GAAgB,WAAW,CAAC,MAAM,CAAC;QAuBhD,iCAAiC;QACb,YAAO,GAAY,KAAK,CAAC;IAI7C,CAAC;IAvBD;;;;;;;OAOG;IACH,IAAqB,IAAI,CAAC,KAAkB;QAC1C,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,WAAW,CAAC,MAAM,CAAC;IACvF,CAAC;IAED,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAWD;;;;;;;;;;;;;;;;;;OAkBG;IACH,KAAK;QACH,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;SACvC;IACH,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,SAAS,EAAE,EAAE,CAAC;IACrB,CAAC;IAED,SAAS,CAAC,KAAoB;QAC5B,IAAI,KAAK,CAAC,KAAK,KAAK,aAAa,CAAC,KAAK,IAAI,KAAK,CAAC,OAAO,KAAK,aAAa,CAAC,KAAK,EAAE;YAChF,IAAI,CAAC,UAAU,EAAE,CAAC;SACnB;IACH,CAAC;IAED,WAAW,CAAC,KAAU;QACpB,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;YACnB,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;YACxB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SAC7B;IACH,CAAC;IAED,UAAU;QACR,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC9B,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;SACrC;IACH,CAAC;IAED,YAAY,CAAC,KAAU;QACrB,IAAI,KAAK,KAAK,IAAI,CAAC,KAAK,EAAE;YACxB,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC;YAErB,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;SACpC;IACH,CAAC;IAGD,OAAO;QACL,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,YAAY,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;IAC1D,CAAC;IAGD,QAAQ;QACN,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;IACzD,CAAC;;gFArGU,gBAAgB;mEAAhB,gBAAgB;;;;;;uGAAhB,0BAAsB,wFAAtB,2BAAuB;gMARvB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,gBAAgB,CAAC;gBAC/C,KAAK,EAAE,IAAI;aACZ;SACF;QC5BH,8BAAsB,kBAAA;QACD,4FAAS,gBAAY,IAAC,yFAAY,qBAAiB,IAA7B;QACvC,2BAQE;QACF,mEAAsC;QACxC,iBAAQ,EAAA;;;;QAPJ,eAAmB;QAAnB,qCAAmB,0BAAA,6FAAA,0BAAA,sFAAA;QADnB,kCAAoB;QAOf,eAAW;QAAX,gCAAW;;AD6CiB;IAAf,YAAY,EAAE;kDAAmB;uFA1B5C,gBAAgB;cAZ5B,SAAS;2BACE,UAAU,mBAEH,uBAAuB,CAAC,MAAM,aACpC;oBACT;wBACE,OAAO,EAAE,iBAAiB;wBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,iBAAiB,CAAC;wBAC/C,KAAK,EAAE,IAAI;qBACZ;iBACF;oEAG0C,UAAU;kBAApD,SAAS;mBAAC,YAAY,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;YAOvB,UAAU;kBAA3B,KAAK;mBAAC,SAAS;YAUK,IAAI;kBAAxB,KAAK;mBAAC,QAAQ;YAQsB,QAAQ;kBAA5C,KAAK;mBAAC,YAAY;YAGC,OAAO;kBAA1B,KAAK;mBAAC,WAAW;YAiElB,OAAO;kBADN,YAAY;mBAAC,SAAS,EAAE,CAAC,eAAe,CAAC;YAM1C,QAAQ;kBADP,YAAY;mBAAC,UAAU,EAAE,CAAC,eAAe,CAAC","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  forwardRef,\n  HostListener,\n  Input,\n  ViewChild\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { InputBoolean } from '../../../decorators';\nimport { PoFieldModel } from '../po-field.model';\nimport { PoKeyCodeEnum } from './../../../enums/po-key-code.enum';\n\nimport { PoRadioSize } from './po-radio-size.enum';\n\n@Component({\n  selector: 'po-radio',\n  templateUrl: './po-radio.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PoRadioComponent),\n      multi: true\n    }\n  ]\n})\nexport class PoRadioComponent extends PoFieldModel<boolean> {\n  @ViewChild('radioLabel', { static: true }) radioLabel: ElementRef;\n\n  value = false;\n\n  private _size: PoRadioSize = PoRadioSize.Medium;\n\n  /** Define o valor do *radio* */\n  @Input('p-value') radioValue: string;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define o tamanho do *radio*\n   * @default `medium`\n   */\n  @Input('p-size') set size(value: PoRadioSize) {\n    this._size = Object.values(PoRadioSize).includes(value) ? value : PoRadioSize.Medium;\n  }\n\n  get size() {\n    return this._size;\n  }\n\n  @Input('p-required') @InputBoolean() required: boolean;\n\n  /** Define o status do *radio* */\n  @Input('p-checked') checked: boolean = false;\n\n  constructor(private changeDetector: ChangeDetectorRef) {\n    super();\n  }\n\n  /**\n   * Função que atribui foco ao *radio*.\n   *\n   * Para utilizá-la é necessário capturar a referência do componente no DOM através do `ViewChild`, como por exemplo:\n   *\n   * ```\n   * import { ViewChild } from '@angular/core';\n   * import { PoRadioComponent } from '@po-ui/ng-components';\n   *\n   * ...\n   *\n   * @ViewChild(PoRadioComponent, { static: true }) radio: PoRadioComponent;\n   *\n   * focusRadio() {\n   * this.radio.focus();\n   * }\n   * ```\n   *\n   */\n  focus(): void {\n    if (!this.disabled) {\n      this.radioLabel.nativeElement.focus();\n    }\n  }\n\n  onBlur() {\n    this.onTouched?.();\n  }\n\n  onKeyDown(event: KeyboardEvent) {\n    if (event.which === PoKeyCodeEnum.space || event.keyCode === PoKeyCodeEnum.space) {\n      this.eventClick();\n    }\n  }\n\n  changeValue(value: any) {\n    if (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      this.changeDetector.detectChanges();\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  @HostListener('focusin', ['$event.target'])\n  focusIn(): void {\n    this.radioLabel.nativeElement.setAttribute('focus', '');\n  }\n\n  @HostListener('focusout', ['$event.target'])\n  focusOut(): void {\n    this.radioLabel.nativeElement.removeAttribute('focus');\n  }\n}\n","<div class=\"po-radio\">\n  <label #radioLabel (click)=\"eventClick()\" (keydown)=\"onKeyDown($event)\">\n    <input\n      type=\"radio\"\n      [attr.p-size]=\"size\"\n      [checked]=\"checked\"\n      [disabled]=\"disabled\"\n      [name]=\"name ?? 'po-input-radio'\"\n      [required]=\"required\"\n      [value]=\"radioValue ?? ''\"\n    />\n    <span *ngIf=\"label\">{{ label }}</span>\n  </label>\n</div>\n"]}
@@ -17,6 +17,17 @@ const poRadioGroupColumnsTotalLength = 12;
17
17
  * [**po-checkbox-group**](/documentation/po-checkbox-group).
18
18
  *
19
19
  * > Ao passar um valor para o *model* que não esteja na lista de opções, o mesmo será definido como `undefined`.
20
+ *
21
+ * #### Acessibilidade tratada no componente interno `po-radio`:
22
+ *
23
+ * 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:
24
+ *
25
+ * - O componente foi desenvolvido utilizando controles padrões HTML para permitir a identificação do mesmo na interface por tecnologias assistivas. [WCAG 4.1.2: Name, Role, Value](https://www.w3.org/WAI/WCAG21/Understanding/name-role-value)
26
+ * - A cor não deve ser o único meio para diferenciar o radio button normal do selecionado, por isso deve-se manter uma diferença visual entre os estados. [WGAG 1.4.1: Use of Color, 3.2.4: Consistent Identification](https://www.w3.org/WAI/WCAG21/Understanding/use-of-color)
27
+ * - Quando em foco, o componente é ativado usando as teclas de Espaço e Enter do teclado. [W3C WAI-ARIA 3.5 Button - Keyboard Interaction](https://www.w3.org/TR/wai-aria-practices-1.1/#keyboard-interaction-3)
28
+ * - 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)
29
+ *
30
+ * Conforme documentação em: https://doc.animaliads.io/docs/components/radio
20
31
  */
21
32
  export class PoRadioGroupBaseComponent {
22
33
  constructor() {
@@ -170,7 +181,7 @@ export class PoRadioGroupBaseComponent {
170
181
  }
171
182
  }
172
183
  PoRadioGroupBaseComponent.ɵfac = function PoRadioGroupBaseComponent_Factory(t) { return new (t || PoRadioGroupBaseComponent)(); };
173
- PoRadioGroupBaseComponent.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: PoRadioGroupBaseComponent, inputs: { autoFocus: ["p-auto-focus", "autoFocus"], name: "name", optional: ["p-optional", "optional"], columns: ["p-columns", "columns"], disabled: ["p-disabled", "disabled"], required: ["p-required", "required"], options: ["p-options", "options"] }, outputs: { change: "p-change" } });
184
+ PoRadioGroupBaseComponent.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: PoRadioGroupBaseComponent, inputs: { autoFocus: ["p-auto-focus", "autoFocus"], name: "name", optional: ["p-optional", "optional"], columns: ["p-columns", "columns"], disabled: ["p-disabled", "disabled"], required: ["p-required", "required"], options: ["p-options", "options"], size: ["p-size", "size"] }, outputs: { change: "p-change" } });
174
185
  __decorate([
175
186
  InputBoolean()
176
187
  ], PoRadioGroupBaseComponent.prototype, "autoFocus", void 0);
@@ -200,5 +211,8 @@ __decorate([
200
211
  }], options: [{
201
212
  type: Input,
202
213
  args: ['p-options']
214
+ }], size: [{
215
+ type: Input,
216
+ args: ['p-size']
203
217
  }] }); })();
204
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-radio-group-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-radio-group/po-radio-group-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl, ControlValueAccessor, Validator } from '@angular/forms';\nimport { EventEmitter, Input, Output, Directive } from '@angular/core';\n\nimport { convertToBoolean, convertToInt, removeDuplicatedOptions } from '../../../utils/util';\nimport { InputBoolean } from '../../../decorators';\nimport { requiredFailed } from '../validators';\n\nimport { PoRadioGroupOption } from './po-radio-group-option.interface';\n\nconst poRadioGroupColumnsDefaultLength: number = 6;\nconst poRadioGroupColumnsTotalLength: number = 12;\n\n/**\n * @description\n *\n * O componente `po-radio-group` deve ser utilizado para disponibilizar múltiplas opções ao usuário, permitindo a ele que\n * selecione apenas uma delas. Seu uso é recomendado para um número pequeno de opções, caso contrário, recomenda-se o uso\n * do [**po-combo**](/documentation/po-combo) ou [**po-select**](/documentation/po-select).\n *\n * Este não é um componente de multiseleção, se for este o caso, deve-se utilizar o\n * [**po-checkbox-group**](/documentation/po-checkbox-group).\n *\n * > Ao passar um valor para o *model* que não esteja na lista de opções, o mesmo será definido como `undefined`.\n */\n@Directive()\nexport abstract class PoRadioGroupBaseComponent 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  /** Nome das opções. */\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 ao alterar valor do campo.\n   */\n  @Output('p-change') change: EventEmitter<any> = new EventEmitter<any>();\n\n  mdColumns: number = poRadioGroupColumnsDefaultLength;\n  value: any;\n\n  protected onTouched: any = null;\n\n  private _columns: number = poRadioGroupColumnsDefaultLength;\n  private _disabled?: boolean = false;\n  private _options: Array<PoRadioGroupOption>;\n  private _required?: boolean = false;\n\n  private onChangePropagate: any = null;\n  private validatorChange;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define a quantidade de colunas para exibição das opções.\n   *\n   * **Considerações:**\n   *  - É possível exibir as opções entre `1` e `4` colunas.\n   *  - O número máximo de colunas é invariável nas seguintes resoluções:\n   *    + `sm`: `1`\n   *    + `md`: `2`\n   *\n   * @default `2`\n   */\n  @Input('p-columns') set columns(value: number) {\n    const columns = convertToInt(value, poRadioGroupColumnsDefaultLength);\n\n    this._columns = this.getGridSystemColumns(columns, 4);\n    this.mdColumns = this.getGridSystemColumns(columns, 2);\n  }\n\n  get columns() {\n    return this._columns;\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    this.validateModel();\n  }\n\n  get disabled() {\n    return this._disabled;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica que o campo será obrigatório.\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() {\n    return this._required;\n  }\n\n  /**\n   * Lista de opções que serão exibidas.\n   * Nesta propriedade deve ser definido um array de objetos que implementam a interface PoRadioGroupOption.\n   */\n  @Input('p-options') set options(value: Array<PoRadioGroupOption>) {\n    this._options = value;\n    removeDuplicatedOptions(this.options);\n  }\n  get options() {\n    return this._options;\n  }\n\n  // Função que controla quando deve ser emitido onChange e atualiza o Model\n  changeValue(changedValue: any) {\n    if (this.onChangePropagate) {\n      this.onChangePropagate(changedValue);\n    }\n\n    if (this.value !== changedValue) {\n      this.change.emit(changedValue);\n    }\n\n    this.value = changedValue;\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  }\n\n  registerOnChange(fn: any) {\n    this.onChangePropagate = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  registerOnValidatorChange(fn: any) {\n    this.validatorChange = fn;\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\n  writeValue(modelValue: any) {\n    this.value = modelValue;\n\n    // Busca radio com o valor especificado\n    const element = this.getElementByValue(modelValue);\n    if (!element && this.onChangePropagate) {\n      this.value = undefined;\n      this.onChangePropagate(this.value);\n    }\n  }\n\n  private checkColumnsRange(columns, maxColumns): boolean {\n    const minColumns = 1;\n\n    return columns >= minColumns && columns <= maxColumns;\n  }\n\n  private getGridSystemColumns(columns: number, maxColumns: number): number {\n    const gridSystemColumns = poRadioGroupColumnsTotalLength / columns;\n\n    return this.checkColumnsRange(columns, maxColumns) ? gridSystemColumns : poRadioGroupColumnsDefaultLength;\n  }\n\n  private validateModel() {\n    if (this.validatorChange) {\n      this.validatorChange();\n    }\n  }\n\n  // Deve retornar o valor elemento que contém o valor passado por parâmetro\n  abstract getElementByValue(value: any): any;\n}\n"]}
218
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-radio-group-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-field/po-radio-group/po-radio-group-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl, ControlValueAccessor, Validator } from '@angular/forms';\nimport { EventEmitter, Input, Output, Directive } from '@angular/core';\n\nimport { convertToBoolean, convertToInt, removeDuplicatedOptions } from '../../../utils/util';\nimport { InputBoolean } from '../../../decorators';\nimport { requiredFailed } from '../validators';\n\nimport { PoRadioGroupOption } from './po-radio-group-option.interface';\n\nconst poRadioGroupColumnsDefaultLength: number = 6;\nconst poRadioGroupColumnsTotalLength: number = 12;\n\n/**\n * @description\n *\n * O componente `po-radio-group` deve ser utilizado para disponibilizar múltiplas opções ao usuário, permitindo a ele que\n * selecione apenas uma delas. Seu uso é recomendado para um número pequeno de opções, caso contrário, recomenda-se o uso\n * do [**po-combo**](/documentation/po-combo) ou [**po-select**](/documentation/po-select).\n *\n * Este não é um componente de multiseleção, se for este o caso, deve-se utilizar o\n * [**po-checkbox-group**](/documentation/po-checkbox-group).\n *\n * > Ao passar um valor para o *model* que não esteja na lista de opções, o mesmo será definido como `undefined`.\n *\n * #### Acessibilidade tratada no componente interno `po-radio`:\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 * - O componente foi desenvolvido utilizando controles padrões HTML para permitir a identificação do mesmo na interface por tecnologias assistivas. [WCAG 4.1.2: Name, Role, Value](https://www.w3.org/WAI/WCAG21/Understanding/name-role-value)\n * - A cor não deve ser o único meio para diferenciar o radio button normal do selecionado, por isso deve-se manter uma diferença visual entre os estados. [WGAG 1.4.1: Use of Color, 3.2.4: Consistent Identification](https://www.w3.org/WAI/WCAG21/Understanding/use-of-color)\n * - Quando em foco, o componente é ativado usando as teclas de Espaço e Enter do teclado. [W3C WAI-ARIA 3.5 Button - Keyboard Interaction](https://www.w3.org/TR/wai-aria-practices-1.1/#keyboard-interaction-3)\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 * Conforme documentação em: https://doc.animaliads.io/docs/components/radio\n */\n\n@Directive()\nexport abstract class PoRadioGroupBaseComponent 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  /** Nome das opções. */\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 ao alterar valor do campo.\n   */\n  @Output('p-change') change: EventEmitter<any> = new EventEmitter<any>();\n\n  mdColumns: number = poRadioGroupColumnsDefaultLength;\n  value: any;\n\n  protected onTouched: any = null;\n\n  private _columns: number = poRadioGroupColumnsDefaultLength;\n  private _disabled?: boolean = false;\n  private _options: Array<PoRadioGroupOption>;\n  private _required?: boolean = false;\n\n  private onChangePropagate: any = null;\n  private validatorChange;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define a quantidade de colunas para exibição das opções.\n   *\n   * **Considerações:**\n   *  - É possível exibir as opções entre `1` e `4` colunas.\n   *  - O número máximo de colunas é invariável nas seguintes resoluções:\n   *    + `sm`: `1`\n   *    + `md`: `2`\n   *\n   * @default `2`\n   */\n  @Input('p-columns') set columns(value: number) {\n    const columns = convertToInt(value, poRadioGroupColumnsDefaultLength);\n\n    this._columns = this.getGridSystemColumns(columns, 4);\n    this.mdColumns = this.getGridSystemColumns(columns, 2);\n  }\n\n  get columns() {\n    return this._columns;\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    this.validateModel();\n  }\n\n  get disabled() {\n    return this._disabled;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Indica que o campo será obrigatório.\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() {\n    return this._required;\n  }\n\n  /**\n   * Lista de opções que serão exibidas.\n   * Nesta propriedade deve ser definido um array de objetos que implementam a interface PoRadioGroupOption.\n   */\n  @Input('p-options') set options(value: Array<PoRadioGroupOption>) {\n    this._options = value;\n    removeDuplicatedOptions(this.options);\n  }\n  get options() {\n    return this._options;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Define o tamanho do *radio*\n   * @default `medium`\n   */\n  @Input('p-size') size: string;\n\n  // Função que controla quando deve ser emitido onChange e atualiza o Model\n  changeValue(changedValue: any) {\n    if (this.onChangePropagate) {\n      this.onChangePropagate(changedValue);\n    }\n\n    if (this.value !== changedValue) {\n      this.change.emit(changedValue);\n    }\n\n    this.value = changedValue;\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  }\n\n  registerOnChange(fn: any) {\n    this.onChangePropagate = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  registerOnValidatorChange(fn: any) {\n    this.validatorChange = fn;\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\n  writeValue(modelValue: any) {\n    this.value = modelValue;\n\n    // Busca radio com o valor especificado\n    const element = this.getElementByValue(modelValue);\n    if (!element && this.onChangePropagate) {\n      this.value = undefined;\n      this.onChangePropagate(this.value);\n    }\n  }\n\n  private checkColumnsRange(columns, maxColumns): boolean {\n    const minColumns = 1;\n\n    return columns >= minColumns && columns <= maxColumns;\n  }\n\n  private getGridSystemColumns(columns: number, maxColumns: number): number {\n    const gridSystemColumns = poRadioGroupColumnsTotalLength / columns;\n\n    return this.checkColumnsRange(columns, maxColumns) ? gridSystemColumns : poRadioGroupColumnsDefaultLength;\n  }\n\n  private validateModel() {\n    if (this.validatorChange) {\n      this.validatorChange();\n    }\n  }\n\n  // Deve retornar o valor elemento que contém o valor passado por parâmetro\n  abstract getElementByValue(value: any): any;\n}\n"]}