@po-ui/ng-components 14.0.0-rc.0 → 14.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/components/po-button/po-button-base.component.mjs +18 -3
- package/esm2020/lib/components/po-button/po-button.component.mjs +5 -4
- package/esm2020/lib/components/po-dynamic/po-dynamic-field-force-component.enum.mjs +6 -0
- package/esm2020/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-base.component.mjs +29 -2
- package/esm2020/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-field.interface.mjs +1 -1
- package/esm2020/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-fields/po-dynamic-form-fields-base.component.mjs +17 -2
- package/esm2020/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-fields/po-dynamic-form-fields.component.mjs +34 -26
- package/esm2020/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form.component.mjs +5 -5
- package/esm2020/lib/components/po-table/po-table-base.component.mjs +1 -7
- package/esm2020/lib/components/po-table/po-table.component.mjs +202 -213
- package/fesm2015/po-ui-ng-components.mjs +304 -254
- package/fesm2015/po-ui-ng-components.mjs.map +1 -1
- package/fesm2020/po-ui-ng-components.mjs +301 -254
- package/fesm2020/po-ui-ng-components.mjs.map +1 -1
- package/lib/components/po-button/po-button-base.component.d.ts +7 -0
- package/lib/components/po-dynamic/po-dynamic-field-force-component.enum.d.ts +4 -0
- package/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-base.component.d.ts +20 -1
- package/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-field.interface.d.ts +11 -0
- package/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-fields/po-dynamic-form-fields-base.component.d.ts +3 -1
- package/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-fields/po-dynamic-form-fields.component.d.ts +1 -0
- package/lib/components/po-table/po-table-base.component.d.ts +0 -1
- package/lib/components/po-table/po-table.component.d.ts +3 -3
- package/package.json +4 -4
- package/po-ui-ng-components-14.0.0.tgz +0 -0
- package/schematics/migrations.json +1 -1
- package/schematics/ng-add/index.js +1 -1
- package/schematics/ng-update/v14/index.js +1 -1
- package/schematics/ng-update/v2/index.js +1 -1
- package/schematics/ng-update/v3/index.js +1 -1
- package/schematics/ng-update/v4/index.js +1 -1
- package/schematics/ng-update/v5/index.js +1 -1
- package/schematics/ng-update/v6/index.js +1 -1
- package/po-ui-ng-components-14.0.0-rc.0.tgz +0 -0
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
|
-
import { EventEmitter, Input, Output, Directive } from '@angular/core';
|
|
2
|
+
import { EventEmitter, Input, Output, Directive, HostBinding } from '@angular/core';
|
|
3
3
|
import { convertToBoolean } from '../../utils/util';
|
|
4
4
|
import { InputBoolean } from '../../decorators';
|
|
5
5
|
import { PoButtonKind } from './po-button-type.enum';
|
|
@@ -16,6 +16,13 @@ import * as i0 from "@angular/core";
|
|
|
16
16
|
* - Evite `labels` extensos que quebram o layout do `po-button`, use `labels` diretos, curtos e intuitivos.
|
|
17
17
|
* - Utilize apenas um `po-button` configurado como `primary` por página.
|
|
18
18
|
* - Para ações irreversíveis use sempre a propriedade `p-danger`.
|
|
19
|
+
*
|
|
20
|
+
* #### Acessibilidade tratada no componente
|
|
21
|
+
*
|
|
22
|
+
* 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:
|
|
23
|
+
*
|
|
24
|
+
* - Quando em foco, o botão é ativado usando as teclas de Espaço e Enter do teclado. [W3C WAI-ARIA 3.5 Button - Keyboard Interaction](https://www.w3.org/WAI/ARIA/apg/#keyboard-interaction-3)
|
|
25
|
+
* - 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)
|
|
19
26
|
*/
|
|
20
27
|
export class PoButtonBaseComponent {
|
|
21
28
|
constructor() {
|
|
@@ -136,7 +143,9 @@ export class PoButtonBaseComponent {
|
|
|
136
143
|
}
|
|
137
144
|
}
|
|
138
145
|
PoButtonBaseComponent.ɵfac = function PoButtonBaseComponent_Factory(t) { return new (t || PoButtonBaseComponent)(); };
|
|
139
|
-
PoButtonBaseComponent.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: PoButtonBaseComponent,
|
|
146
|
+
PoButtonBaseComponent.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: PoButtonBaseComponent, hostVars: 2, hostBindings: function PoButtonBaseComponent_HostBindings(rf, ctx) { if (rf & 2) {
|
|
147
|
+
i0.ɵɵattribute("p-danger", ctx.danger)("p-kind", ctx.kind);
|
|
148
|
+
} }, inputs: { label: ["p-label", "label"], icon: ["p-icon", "icon"], loading: ["p-loading", "loading"], small: ["p-small", "small"], type: ["p-type", "type"], danger: ["p-danger", "danger"], kind: ["p-kind", "kind"], disabled: ["p-disabled", "disabled"] }, outputs: { click: "p-click" } });
|
|
140
149
|
__decorate([
|
|
141
150
|
InputBoolean()
|
|
142
151
|
], PoButtonBaseComponent.prototype, "danger", null);
|
|
@@ -161,13 +170,19 @@ __decorate([
|
|
|
161
170
|
type: Input,
|
|
162
171
|
args: ['p-type']
|
|
163
172
|
}], danger: [{
|
|
173
|
+
type: HostBinding,
|
|
174
|
+
args: ['attr.p-danger']
|
|
175
|
+
}, {
|
|
164
176
|
type: Input,
|
|
165
177
|
args: ['p-danger']
|
|
166
178
|
}], kind: [{
|
|
179
|
+
type: HostBinding,
|
|
180
|
+
args: ['attr.p-kind']
|
|
181
|
+
}, {
|
|
167
182
|
type: Input,
|
|
168
183
|
args: ['p-kind']
|
|
169
184
|
}], disabled: [{
|
|
170
185
|
type: Input,
|
|
171
186
|
args: ['p-disabled']
|
|
172
187
|
}] }); })();
|
|
173
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-button-base.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/components/po-button/po-button-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter, Input, Output, Directive, TemplateRef } from '@angular/core';\r\n\r\nimport { convertToBoolean } from '../../utils/util';\r\nimport { InputBoolean } from '../../decorators';\r\n\r\nimport { PoButtonKind } from './po-button-type.enum';\r\n\r\n/**\r\n * @description\r\n *\r\n * O `po-button` permite que o usuário execute ações predefinidas pelo desenvolvedor.\r\n *\r\n * Através dos tipos, é possível identificar a importância de cada ação.\r\n *\r\n * #### Boas práticas\r\n *\r\n * - Evite `labels` extensos que quebram o layout do `po-button`, use `labels` diretos, curtos e intuitivos.\r\n * - Utilize apenas um `po-button` configurado como `primary` por página.\r\n * - Para ações irreversíveis use sempre a propriedade `p-danger`.\r\n */\r\n@Directive()\r\nexport class PoButtonBaseComponent {\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Label do botão.\r\n   */\r\n  @Input('p-label') label?: string;\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   * Ícone exibido ao lado esquerdo do label do botão.\r\n   *\r\n   * É possível usar qualquer um dos ícones da [Biblioteca de ícones](/guides/icons). conforme exemplo abaixo:\r\n   * ```\r\n   * <po-button p-icon=\"po-icon-user\" p-label=\"PO button\"></po-button>\r\n   * ```\r\n   * Também é possível utilizar outras fontes de ícones, por exemplo a biblioteca *Font Awesome*, da seguinte forma:\r\n   * ```\r\n   * <po-button p-icon=\"fa fa-podcast\" p-label=\"PO button\"></po-button>\r\n   * ```\r\n   * Outra opção seria a customização do ícone através do `TemplateRef`, conforme exemplo abaixo:\r\n   * ```\r\n   * <po-button [p-icon]=\"template\" p-label=\"button template ionic\"></po-button>\r\n   *\r\n   * <ng-template #template>\r\n   *  <ion-icon style=\"font-size: inherit\" name=\"heart\"></ion-icon>\r\n   * </ng-template>\r\n   * ```\r\n   * > Para o ícone enquadrar corretamente, deve-se utilizar `font-size: inherit` caso o ícone utilizado não aplique-o.\r\n   */\r\n  @Input('p-icon') icon?: string | TemplateRef<void>;\r\n\r\n  /** Ação que será executada quando o usuário clicar sobre o `po-button`. */\r\n  @Output('p-click') click = new EventEmitter<null>();\r\n\r\n  private _danger?: boolean = false;\r\n  private _disabled?: boolean = false;\r\n  private _loading?: boolean = false;\r\n  private _small?: boolean = false;\r\n  private _kind?: string = PoButtonKind.secondary;\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Exibe um ícone de carregamento à esquerda do _label_ do botão.\r\n   *\r\n   * > Quando esta propriedade estiver habilitada, desabilitará o botão.\r\n   *\r\n   * @default `false`\r\n   */\r\n  @Input('p-loading') set loading(value: boolean) {\r\n    this._loading = convertToBoolean(value);\r\n  }\r\n\r\n  get loading(): boolean {\r\n    return this._loading;\r\n  }\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Deixa o botão menor.\r\n   *\r\n   * @default `false`\r\n   */\r\n  @Input('p-small') set small(value: boolean) {\r\n    this._small = <any>value === '' ? true : convertToBoolean(value);\r\n  }\r\n  get small(): boolean {\r\n    return this._small;\r\n  }\r\n\r\n  /**\r\n   * @deprecated 15.x.x\r\n   *\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * **Deprecated 15.x.x**. Utilizar `p-kind` no lugar.\r\n   *\r\n   * Define o estilo do `po-button`.\r\n   *\r\n   * Valore válidos:\r\n   *  - `default`: **Deprecated 15.x.x**. Utilizar `p-kind=\"secondary\"`.\r\n   *  - `primary`: deixa o `po-button` com destaque, deve ser usado para ações primárias.\r\n   *  - `danger`: **Deprecated 15.x.x**. Utilizar `p-danger`.\r\n   *  - `link`: **Deprecated 15.x.x**. Utilizar `p-kind=\"tertiary\"`.\r\n   *\r\n   * @default `secondary`\r\n   */\r\n  @Input('p-type') set type(value: string) {\r\n    this.kind = value;\r\n  }\r\n  get type(): string {\r\n    return this.kind;\r\n  }\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Deve ser usado em ações irreversíveis que o usuário precisa ter cuidado ao executá-la, como a exclusão de um registro.\r\n   *\r\n   * > A propriedade `p-kind=\"tertiary\"` será inativada ao utilizar esta propriedade.\r\n   */\r\n\r\n  @Input('p-danger') @InputBoolean() set danger(value: boolean) {\r\n    this._danger = this.kind !== PoButtonKind.tertiary ? value : false;\r\n  }\r\n\r\n  get danger(): boolean {\r\n    return this._danger;\r\n  }\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Define o estilo do `po-button`.\r\n   *\r\n   * Valore válidos:\r\n   *  - `primary`: deixa o `po-button` com destaque, deve ser usado para ações primárias.\r\n   *  - `secondary`: estilo padrão do `po-button`.\r\n   *  - `tertiary`: o `po-button` é exibido sem cor do fundo, recebendo menos destaque entre as ações.\r\n   *\r\n   * @default `secondary`\r\n   */\r\n  @Input('p-kind') set kind(value: string) {\r\n    this._kind = PoButtonKind[value] ? PoButtonKind[value] : PoButtonKind.secondary;\r\n  }\r\n\r\n  get kind(): string {\r\n    return this._kind;\r\n  }\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Desabilita o `po-button` e não permite que o usuário interaja com o mesmo.\r\n   *\r\n   * @default `false`\r\n   */\r\n  @Input('p-disabled') set disabled(value: boolean) {\r\n    this._disabled = <any>value === '' ? true : convertToBoolean(value);\r\n  }\r\n  get disabled(): boolean {\r\n    return this._disabled;\r\n  }\r\n}\r\n"]}
|
|
188
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-button-base.component.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/components/po-button/po-button-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter, Input, Output, Directive, TemplateRef, HostBinding } from '@angular/core';\r\n\r\nimport { convertToBoolean } from '../../utils/util';\r\nimport { InputBoolean } from '../../decorators';\r\n\r\nimport { PoButtonKind } from './po-button-type.enum';\r\n\r\n/**\r\n * @description\r\n *\r\n * O `po-button` permite que o usuário execute ações predefinidas pelo desenvolvedor.\r\n *\r\n * Através dos tipos, é possível identificar a importância de cada ação.\r\n *\r\n * #### Boas práticas\r\n *\r\n * - Evite `labels` extensos que quebram o layout do `po-button`, use `labels` diretos, curtos e intuitivos.\r\n * - Utilize apenas um `po-button` configurado como `primary` por página.\r\n * - Para ações irreversíveis use sempre a propriedade `p-danger`.\r\n *\r\n * #### Acessibilidade tratada no componente\r\n *\r\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:\r\n *\r\n * - Quando em foco, o botão é ativado usando as teclas de Espaço e Enter do teclado. [W3C WAI-ARIA 3.5 Button - Keyboard Interaction](https://www.w3.org/WAI/ARIA/apg/#keyboard-interaction-3)\r\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)\r\n */\r\n@Directive()\r\nexport class PoButtonBaseComponent {\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Label do botão.\r\n   */\r\n  @Input('p-label') label?: string;\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   * Ícone exibido ao lado esquerdo do label do botão.\r\n   *\r\n   * É possível usar qualquer um dos ícones da [Biblioteca de ícones](/guides/icons). conforme exemplo abaixo:\r\n   * ```\r\n   * <po-button p-icon=\"po-icon-user\" p-label=\"PO button\"></po-button>\r\n   * ```\r\n   * Também é possível utilizar outras fontes de ícones, por exemplo a biblioteca *Font Awesome*, da seguinte forma:\r\n   * ```\r\n   * <po-button p-icon=\"fa fa-podcast\" p-label=\"PO button\"></po-button>\r\n   * ```\r\n   * Outra opção seria a customização do ícone através do `TemplateRef`, conforme exemplo abaixo:\r\n   * ```\r\n   * <po-button [p-icon]=\"template\" p-label=\"button template ionic\"></po-button>\r\n   *\r\n   * <ng-template #template>\r\n   *  <ion-icon style=\"font-size: inherit\" name=\"heart\"></ion-icon>\r\n   * </ng-template>\r\n   * ```\r\n   * > Para o ícone enquadrar corretamente, deve-se utilizar `font-size: inherit` caso o ícone utilizado não aplique-o.\r\n   */\r\n  @Input('p-icon') icon?: string | TemplateRef<void>;\r\n\r\n  /** Ação que será executada quando o usuário clicar sobre o `po-button`. */\r\n  @Output('p-click') click = new EventEmitter<null>();\r\n\r\n  private _danger?: boolean = false;\r\n  private _disabled?: boolean = false;\r\n  private _loading?: boolean = false;\r\n  private _small?: boolean = false;\r\n  private _kind?: string = PoButtonKind.secondary;\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Exibe um ícone de carregamento à esquerda do _label_ do botão.\r\n   *\r\n   * > Quando esta propriedade estiver habilitada, desabilitará o botão.\r\n   *\r\n   * @default `false`\r\n   */\r\n  @Input('p-loading') set loading(value: boolean) {\r\n    this._loading = convertToBoolean(value);\r\n  }\r\n\r\n  get loading(): boolean {\r\n    return this._loading;\r\n  }\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Deixa o botão menor.\r\n   *\r\n   * @default `false`\r\n   */\r\n  @Input('p-small') set small(value: boolean) {\r\n    this._small = <any>value === '' ? true : convertToBoolean(value);\r\n  }\r\n  get small(): boolean {\r\n    return this._small;\r\n  }\r\n\r\n  /**\r\n   * @deprecated 15.x.x\r\n   *\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * **Deprecated 15.x.x**. Utilizar `p-kind` no lugar.\r\n   *\r\n   * Define o estilo do `po-button`.\r\n   *\r\n   * Valore válidos:\r\n   *  - `default`: **Deprecated 15.x.x**. Utilizar `p-kind=\"secondary\"`.\r\n   *  - `primary`: deixa o `po-button` com destaque, deve ser usado para ações primárias.\r\n   *  - `danger`: **Deprecated 15.x.x**. Utilizar `p-danger`.\r\n   *  - `link`: **Deprecated 15.x.x**. Utilizar `p-kind=\"tertiary\"`.\r\n   *\r\n   * @default `secondary`\r\n   */\r\n  @Input('p-type') set type(value: string) {\r\n    this.kind = value;\r\n  }\r\n  get type(): string {\r\n    return this.kind;\r\n  }\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Deve ser usado em ações irreversíveis que o usuário precisa ter cuidado ao executá-la, como a exclusão de um registro.\r\n   *\r\n   * > A propriedade `p-kind=\"tertiary\"` será inativada ao utilizar esta propriedade.\r\n   */\r\n\r\n  @HostBinding('attr.p-danger')\r\n  @Input('p-danger')\r\n  @InputBoolean()\r\n  set danger(value: boolean) {\r\n    this._danger = this.kind !== PoButtonKind.tertiary ? value : false;\r\n  }\r\n\r\n  get danger(): boolean {\r\n    return this._danger;\r\n  }\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Define o estilo do `po-button`.\r\n   *\r\n   * Valore válidos:\r\n   *  - `primary`: deixa o `po-button` com destaque, deve ser usado para ações primárias.\r\n   *  - `secondary`: estilo padrão do `po-button`.\r\n   *  - `tertiary`: o `po-button` é exibido sem cor do fundo, recebendo menos destaque entre as ações.\r\n   *\r\n   * @default `secondary`\r\n   */\r\n\r\n  @HostBinding('attr.p-kind')\r\n  @Input('p-kind')\r\n  set kind(value: string) {\r\n    this._kind = PoButtonKind[value] ? PoButtonKind[value] : PoButtonKind.secondary;\r\n  }\r\n\r\n  get kind(): string {\r\n    return this._kind;\r\n  }\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Desabilita o `po-button` e não permite que o usuário interaja com o mesmo.\r\n   *\r\n   * @default `false`\r\n   */\r\n  @Input('p-disabled') set disabled(value: boolean) {\r\n    this._disabled = <any>value === '' ? true : convertToBoolean(value);\r\n  }\r\n  get disabled(): boolean {\r\n    return this._disabled;\r\n  }\r\n}\r\n"]}
|
|
@@ -82,7 +82,7 @@ PoButtonComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoButtonC
|
|
|
82
82
|
} if (rf & 2) {
|
|
83
83
|
let _t;
|
|
84
84
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.buttonElement = _t.first);
|
|
85
|
-
} }, features: [i0.ɵɵInheritDefinitionFeature], decls: 5, vars:
|
|
85
|
+
} }, features: [i0.ɵɵInheritDefinitionFeature], decls: 5, vars: 8, consts: [["type", "button", 1, "po-button", 3, "disabled", "click"], ["button", ""], ["class", "po-button-loading-icon", 4, "ngIf"], ["class", "po-button-icon", 3, "p-icon", 4, "ngIf"], ["class", "po-button-label", 4, "ngIf"], [1, "po-button-loading-icon"], ["p-neutral-color", ""], [1, "po-button-icon", 3, "p-icon"], [1, "po-button-label"]], template: function PoButtonComponent_Template(rf, ctx) { if (rf & 1) {
|
|
86
86
|
i0.ɵɵelementStart(0, "button", 0, 1);
|
|
87
87
|
i0.ɵɵlistener("click", function PoButtonComponent_Template_button_click_0_listener() { return ctx.onClick(); });
|
|
88
88
|
i0.ɵɵtemplate(2, PoButtonComponent_div_2_Template, 2, 0, "div", 2);
|
|
@@ -90,8 +90,9 @@ PoButtonComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoButtonC
|
|
|
90
90
|
i0.ɵɵtemplate(4, PoButtonComponent_span_4_Template, 2, 1, "span", 4);
|
|
91
91
|
i0.ɵɵelementEnd();
|
|
92
92
|
} if (rf & 2) {
|
|
93
|
-
i0.ɵɵclassProp("po-button-
|
|
93
|
+
i0.ɵɵclassProp("po-button-sm", ctx.small);
|
|
94
94
|
i0.ɵɵproperty("disabled", ctx.disabled || ctx.loading);
|
|
95
|
+
i0.ɵɵattribute("p-kind", ctx.kind)("p-danger", ctx.danger);
|
|
95
96
|
i0.ɵɵadvance(2);
|
|
96
97
|
i0.ɵɵproperty("ngIf", ctx.loading);
|
|
97
98
|
i0.ɵɵadvance(1);
|
|
@@ -101,9 +102,9 @@ PoButtonComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PoButtonC
|
|
|
101
102
|
} }, dependencies: [i1.NgIf, i2.PoLoadingIconComponent, i3.PoIconComponent], encapsulation: 2, changeDetection: 0 });
|
|
102
103
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoButtonComponent, [{
|
|
103
104
|
type: Component,
|
|
104
|
-
args: [{ selector: 'po-button', changeDetection: ChangeDetectionStrategy.OnPush, template: "<button\r\n #button\r\n class=\"po-button\"\r\n type=\"button\"\r\n [
|
|
105
|
+
args: [{ selector: 'po-button', changeDetection: ChangeDetectionStrategy.OnPush, template: "<button\r\n #button\r\n class=\"po-button\"\r\n type=\"button\"\r\n [attr.p-kind]=\"kind\"\r\n [attr.p-danger]=\"danger\"\r\n [class.po-button-sm]=\"small\"\r\n [disabled]=\"disabled || loading\"\r\n (click)=\"onClick()\"\r\n>\r\n <div *ngIf=\"loading\" class=\"po-button-loading-icon\">\r\n <po-loading-icon p-neutral-color></po-loading-icon>\r\n </div>\r\n\r\n <po-icon *ngIf=\"icon\" class=\"po-button-icon\" [p-icon]=\"icon\"></po-icon>\r\n <span *ngIf=\"label\" class=\"po-button-label\">{{ label }}</span>\r\n</button>\r\n" }]
|
|
105
106
|
}], null, { buttonElement: [{
|
|
106
107
|
type: ViewChild,
|
|
107
108
|
args: ['button', { static: true }]
|
|
108
109
|
}] }); })();
|
|
109
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8tYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL3NyYy9saWIvY29tcG9uZW50cy9wby1idXR0b24vcG8tYnV0dG9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL3NyYy9saWIvY29tcG9uZW50cy9wby1idXR0b24vcG8tYnV0dG9uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBaUIsdUJBQXVCLEVBQUUsU0FBUyxFQUFjLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6RyxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7Ozs7OztJQ1FqRSw4QkFBb0Q7SUFDbEQscUNBQW1EO0lBQ3JELGlCQUFNOzs7SUFFTiw2QkFBdUU7OztJQUExQixvQ0FBZTs7O0lBQzVELCtCQUE0QztJQUFBLFlBQVc7SUFBQSxpQkFBTzs7O0lBQWxCLGVBQVc7SUFBWCxrQ0FBVzs7QURYekQ7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBdUJHO0FBTUgsTUFBTSxPQUFPLGlCQUFrQixTQUFRLHFCQUFxQjtJQUcxRDs7Ozs7Ozs7Ozs7Ozs7OztPQWdCRztJQUNILEtBQUs7UUFDSCxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNsQixJQUFJLENBQUMsYUFBYSxDQUFDLGFBQWEsQ0FBQyxLQUFLLEVBQUUsQ0FBQztTQUMxQztJQUNILENBQUM7SUFFRCxPQUFPO1FBQ0wsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDeEIsQ0FBQzs7Nk9BNUJVLGlCQUFpQixTQUFqQixpQkFBaUI7b0VBQWpCLGlCQUFpQjs7Ozs7O1FDakM5QixvQ0FTQztRQURDLDhGQUFTLGFBQVMsSUFBQztRQUVuQixrRUFFTTtRQUVOLDBFQUF1RTtRQUN2RSxvRUFBOEQ7UUFDaEUsaUJBQVM7O1FBVlAseUNBQTRCO1FBQzVCLHNEQUFnQztRQUhoQyxrQ0FBb0Isd0JBQUE7UUFNZCxlQUFhO1FBQWIsa0NBQWE7UUFJVCxlQUFVO1FBQVYsK0JBQVU7UUFDYixlQUFXO1FBQVgsZ0NBQVc7O3VGRGtCUCxpQkFBaUI7Y0FMN0IsU0FBUzsyQkFDRSxXQUFXLG1CQUVKLHVCQUF1QixDQUFDLE1BQU07Z0JBR1IsYUFBYTtrQkFBbkQsU0FBUzttQkFBQyxRQUFRLEVBQUUsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQWZ0ZXJWaWV3SW5pdCwgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRWxlbWVudFJlZiwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5pbXBvcnQgeyBQb0J1dHRvbkJhc2VDb21wb25lbnQgfSBmcm9tICcuL3BvLWJ1dHRvbi1iYXNlLmNvbXBvbmVudCc7XHJcblxyXG4vKipcclxuICogQGRvY3NFeHRlbmRzIFBvQnV0dG9uQmFzZUNvbXBvbmVudFxyXG4gKlxyXG4gKiBAZXhhbXBsZVxyXG4gKlxyXG4gKiA8ZXhhbXBsZSBuYW1lPVwicG8tYnV0dG9uLWJhc2ljXCIgdGl0bGU9XCJQTyBCdXR0b24gQmFzaWNcIj5cclxuICogIDxmaWxlIG5hbWU9XCJzYW1wbGUtcG8tYnV0dG9uLWJhc2ljL3NhbXBsZS1wby1idXR0b24tYmFzaWMuY29tcG9uZW50Lmh0bWxcIj4gPC9maWxlPlxyXG4gKiAgPGZpbGUgbmFtZT1cInNhbXBsZS1wby1idXR0b24tYmFzaWMvc2FtcGxlLXBvLWJ1dHRvbi1iYXNpYy5jb21wb25lbnQudHNcIj4gPC9maWxlPlxyXG4gKiAgPGZpbGUgbmFtZT1cInNhbXBsZS1wby1idXR0b24tYmFzaWMvc2FtcGxlLXBvLWJ1dHRvbi1iYXNpYy5jb21wb25lbnQuZTJlLXNwZWMudHNcIj4gPC9maWxlPlxyXG4gKiAgPGZpbGUgbmFtZT1cInNhbXBsZS1wby1idXR0b24tYmFzaWMvc2FtcGxlLXBvLWJ1dHRvbi1iYXNpYy5jb21wb25lbnQucG8udHNcIj4gPC9maWxlPlxyXG4gKiA8L2V4YW1wbGU+XHJcbiAqXHJcbiAqIDxleGFtcGxlIG5hbWU9XCJwby1idXR0b24tbGFic1wiIHRpdGxlPVwiUE8gQnV0dG9uIExhYnNcIj5cclxuICogIDxmaWxlIG5hbWU9XCJzYW1wbGUtcG8tYnV0dG9uLWxhYnMvc2FtcGxlLXBvLWJ1dHRvbi1sYWJzLmNvbXBvbmVudC5odG1sXCI+IDwvZmlsZT5cclxuICogIDxmaWxlIG5hbWU9XCJzYW1wbGUtcG8tYnV0dG9uLWxhYnMvc2FtcGxlLXBvLWJ1dHRvbi1sYWJzLmNvbXBvbmVudC50c1wiPiA8L2ZpbGU+XHJcbiAqICA8ZmlsZSBuYW1lPVwic2FtcGxlLXBvLWJ1dHRvbi1sYWJzL3NhbXBsZS1wby1idXR0b24tbGFicy5jb21wb25lbnQuZTJlLXNwZWMudHNcIj4gPC9maWxlPlxyXG4gKiAgPGZpbGUgbmFtZT1cInNhbXBsZS1wby1idXR0b24tbGFicy9zYW1wbGUtcG8tYnV0dG9uLWxhYnMuY29tcG9uZW50LnBvLnRzXCI+IDwvZmlsZT5cclxuICogPC9leGFtcGxlPlxyXG4gKlxyXG4gKiA8ZXhhbXBsZSBuYW1lPVwicG8tYnV0dG9uLXNvY2lhbC1uZXR3b3JrXCIgdGl0bGU9XCJQTyBCdXR0b24gU29jaWFsIE5ldHdvcmtcIj5cclxuICogIDxmaWxlIG5hbWU9XCJzYW1wbGUtcG8tYnV0dG9uLXNvY2lhbC1uZXR3b3JrL3NhbXBsZS1wby1idXR0b24tc29jaWFsLW5ldHdvcmsuY29tcG9uZW50Lmh0bWxcIj4gPC9maWxlPlxyXG4gKiAgPGZpbGUgbmFtZT1cInNhbXBsZS1wby1idXR0b24tc29jaWFsLW5ldHdvcmsvc2FtcGxlLXBvLWJ1dHRvbi1zb2NpYWwtbmV0d29yay5jb21wb25lbnQudHNcIj4gPC9maWxlPlxyXG4gKiA8L2V4YW1wbGU+XHJcbiAqL1xyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ3BvLWJ1dHRvbicsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL3BvLWJ1dHRvbi5jb21wb25lbnQuaHRtbCcsXHJcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcclxufSlcclxuZXhwb3J0IGNsYXNzIFBvQnV0dG9uQ29tcG9uZW50IGV4dGVuZHMgUG9CdXR0b25CYXNlQ29tcG9uZW50IHtcclxuICBAVmlld0NoaWxkKCdidXR0b24nLCB7IHN0YXRpYzogdHJ1ZSB9KSBidXR0b25FbGVtZW50OiBFbGVtZW50UmVmO1xyXG5cclxuICAvKipcclxuICAgKiBGdW7Dp8OjbyBxdWUgYXRyaWJ1aSBmb2NvIGFvIGNvbXBvbmVudGUuXHJcbiAgICpcclxuICAgKiBQYXJhIHV0aWxpesOhLWxhIMOpIG5lY2Vzc8OhcmlvIHRlciBhIGluc3TDom5jaWEgZG8gY29tcG9uZW50ZSBubyBET00sIHBvZGVuZG8gc2VyIHV0aWxpemFkbyBvIFZpZXdDaGlsZCBkYSBzZWd1aW50ZSBmb3JtYTpcclxuICAgKlxyXG4gICAqIGBgYFxyXG4gICAqIGltcG9ydCB7IFBvQnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnQHBvLXVpL25nLWNvbXBvbmVudHMnO1xyXG4gICAqXHJcbiAgICogLi4uXHJcbiAgICpcclxuICAgKiBAVmlld0NoaWxkKFBvQnV0dG9uQ29tcG9uZW50LCB7IHN0YXRpYzogdHJ1ZSB9KSBidXR0b246IFBvQnV0dG9uQ29tcG9uZW50O1xyXG4gICAqXHJcbiAgICogZm9jdXNCdXR0b24oKSB7XHJcbiAgICogICB0aGlzLmJ1dHRvbi5mb2N1cygpO1xyXG4gICAqIH1cclxuICAgKiBgYGBcclxuICAgKi9cclxuICBmb2N1cygpOiB2b2lkIHtcclxuICAgIGlmICghdGhpcy5kaXNhYmxlZCkge1xyXG4gICAgICB0aGlzLmJ1dHRvbkVsZW1lbnQubmF0aXZlRWxlbWVudC5mb2N1cygpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgb25DbGljaygpIHtcclxuICAgIHRoaXMuY2xpY2suZW1pdChudWxsKTtcclxuICB9XHJcbn1cclxuIiwiPGJ1dHRvblxyXG4gICNidXR0b25cclxuICBjbGFzcz1cInBvLWJ1dHRvblwiXHJcbiAgdHlwZT1cImJ1dHRvblwiXHJcbiAgW2F0dHIucC1raW5kXT1cImtpbmRcIlxyXG4gIFthdHRyLnAtZGFuZ2VyXT1cImRhbmdlclwiXHJcbiAgW2NsYXNzLnBvLWJ1dHRvbi1zbV09XCJzbWFsbFwiXHJcbiAgW2Rpc2FibGVkXT1cImRpc2FibGVkIHx8IGxvYWRpbmdcIlxyXG4gIChjbGljayk9XCJvbkNsaWNrKClcIlxyXG4+XHJcbiAgPGRpdiAqbmdJZj1cImxvYWRpbmdcIiBjbGFzcz1cInBvLWJ1dHRvbi1sb2FkaW5nLWljb25cIj5cclxuICAgIDxwby1sb2FkaW5nLWljb24gcC1uZXV0cmFsLWNvbG9yPjwvcG8tbG9hZGluZy1pY29uPlxyXG4gIDwvZGl2PlxyXG5cclxuICA8cG8taWNvbiAqbmdJZj1cImljb25cIiBjbGFzcz1cInBvLWJ1dHRvbi1pY29uXCIgW3AtaWNvbl09XCJpY29uXCI+PC9wby1pY29uPlxyXG4gIDxzcGFuICpuZ0lmPVwibGFiZWxcIiBjbGFzcz1cInBvLWJ1dHRvbi1sYWJlbFwiPnt7IGxhYmVsIH19PC9zcGFuPlxyXG48L2J1dHRvbj5cclxuIl19
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export var ForceOptionComponentEnum;
|
|
2
|
+
(function (ForceOptionComponentEnum) {
|
|
3
|
+
ForceOptionComponentEnum["radioGroup"] = "radioGroup";
|
|
4
|
+
ForceOptionComponentEnum["select"] = "select";
|
|
5
|
+
})(ForceOptionComponentEnum || (ForceOptionComponentEnum = {}));
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8tZHluYW1pYy1maWVsZC1mb3JjZS1jb21wb25lbnQuZW51bS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL3NyYy9saWIvY29tcG9uZW50cy9wby1keW5hbWljL3BvLWR5bmFtaWMtZmllbGQtZm9yY2UtY29tcG9uZW50LmVudW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksd0JBR1g7QUFIRCxXQUFZLHdCQUF3QjtJQUNsQyxxREFBeUIsQ0FBQTtJQUN6Qiw2Q0FBaUIsQ0FBQTtBQUNuQixDQUFDLEVBSFcsd0JBQXdCLEtBQXhCLHdCQUF3QixRQUduQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIEZvcmNlT3B0aW9uQ29tcG9uZW50RW51bSB7XHJcbiAgcmFkaW9Hcm91cCA9ICdyYWRpb0dyb3VwJyxcclxuICBzZWxlY3QgPSAnc2VsZWN0J1xyXG59XHJcbiJdfQ==
|
package/esm2020/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-base.component.mjs
CHANGED
|
@@ -1,4 +1,6 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
1
2
|
import { EventEmitter, Input, Output, Directive } from '@angular/core';
|
|
3
|
+
import { InputBoolean } from '../../../decorators';
|
|
2
4
|
import { convertToBoolean } from '../../../utils/util';
|
|
3
5
|
import * as i0 from "@angular/core";
|
|
4
6
|
/**
|
|
@@ -65,6 +67,25 @@ export class PoDynamicFormBaseComponent {
|
|
|
65
67
|
*/
|
|
66
68
|
this.formOutput = new EventEmitter();
|
|
67
69
|
this._groupForm = false;
|
|
70
|
+
/**
|
|
71
|
+
* @optional
|
|
72
|
+
*
|
|
73
|
+
* @description
|
|
74
|
+
*
|
|
75
|
+
* Ao informar esta propriedade, o componente passará a emitir o valor a cada caractere digitado.
|
|
76
|
+
*
|
|
77
|
+
* Pode ser aplicado nos seguintes componentes:
|
|
78
|
+
* - po-input
|
|
79
|
+
* - po-number
|
|
80
|
+
* - po-decimal
|
|
81
|
+
* - po-textarea
|
|
82
|
+
* - po-password
|
|
83
|
+
*
|
|
84
|
+
* Deve informar os campos que deseja receber as emissões na propriedade `p-validate-fields`.
|
|
85
|
+
*
|
|
86
|
+
*
|
|
87
|
+
*/
|
|
88
|
+
this.validateOnInput = false;
|
|
68
89
|
}
|
|
69
90
|
/**
|
|
70
91
|
* @optional
|
|
@@ -90,7 +111,10 @@ export class PoDynamicFormBaseComponent {
|
|
|
90
111
|
}
|
|
91
112
|
}
|
|
92
113
|
PoDynamicFormBaseComponent.ɵfac = function PoDynamicFormBaseComponent_Factory(t) { return new (t || PoDynamicFormBaseComponent)(); };
|
|
93
|
-
PoDynamicFormBaseComponent.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: PoDynamicFormBaseComponent, inputs: { autoFocus: ["p-auto-focus", "autoFocus"], fields: ["p-fields", "fields"], value: ["p-value", "value"], load: ["p-load", "load"], validate: ["p-validate", "validate"], validateFields: ["p-validate-fields", "validateFields"], groupForm: ["p-group-form", "groupForm"] }, outputs: { formOutput: "p-form" } });
|
|
114
|
+
PoDynamicFormBaseComponent.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: PoDynamicFormBaseComponent, inputs: { autoFocus: ["p-auto-focus", "autoFocus"], fields: ["p-fields", "fields"], value: ["p-value", "value"], load: ["p-load", "load"], validate: ["p-validate", "validate"], validateFields: ["p-validate-fields", "validateFields"], groupForm: ["p-group-form", "groupForm"], validateOnInput: ["p-validate-on-input", "validateOnInput"] }, outputs: { formOutput: "p-form" } });
|
|
115
|
+
__decorate([
|
|
116
|
+
InputBoolean()
|
|
117
|
+
], PoDynamicFormBaseComponent.prototype, "validateOnInput", void 0);
|
|
94
118
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoDynamicFormBaseComponent, [{
|
|
95
119
|
type: Directive
|
|
96
120
|
}], null, { autoFocus: [{
|
|
@@ -117,5 +141,8 @@ PoDynamicFormBaseComponent.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type:
|
|
|
117
141
|
}], groupForm: [{
|
|
118
142
|
type: Input,
|
|
119
143
|
args: ['p-group-form']
|
|
144
|
+
}], validateOnInput: [{
|
|
145
|
+
type: Input,
|
|
146
|
+
args: ['p-validate-on-input']
|
|
120
147
|
}] }); })();
|
|
121
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-dynamic-form-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-base.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAGvE,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;;AAIvD;;;;;;;GAOG;AAEH,MAAM,OAAO,0BAA0B;IADvC;QAqDE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;WAmDG;QACe,eAAU,GAAyB,IAAI,YAAY,EAAU,CAAC;QAuFxE,eAAU,GAAa,KAAK,CAAC;KAyBtC;IAvBC;;;;;;;;;;;;;;;OAeG;IACH,IAA2B,SAAS,CAAC,KAAc;QACjD,IAAI,CAAC,UAAU,GAAQ,KAAK,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;IACvE,CAAC;IAED,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;;oGAvNU,0BAA0B;6EAA1B,0BAA0B;uFAA1B,0BAA0B;cADtC,SAAS;gBASe,SAAS;kBAA/B,KAAK;mBAAC,cAAc;YAgCF,MAAM;kBAAxB,KAAK;mBAAC,UAAU;YAUC,KAAK;kBAAtB,KAAK;mBAAC,SAAS;YAsDE,UAAU;kBAA3B,MAAM;mBAAC,QAAQ;YAkCC,IAAI;kBAApB,KAAK;mBAAC,QAAQ;YA0CM,QAAQ;kBAA5B,KAAK;mBAAC,YAAY;YASS,cAAc;kBAAzC,KAAK;mBAAC,mBAAmB;YAoBC,SAAS;kBAAnC,KAAK;mBAAC,cAAc","sourcesContent":["import { EventEmitter, Input, Output, Directive } from '@angular/core';\r\nimport { NgForm } from '@angular/forms';\r\n\r\nimport { convertToBoolean } from '../../../utils/util';\r\n\r\nimport { PoDynamicFormField } from './po-dynamic-form-field.interface';\r\n\r\n/**\r\n *\r\n * @description\r\n *\r\n * Componente para criação de formulários dinâmicos a partir de uma lista de objetos.\r\n *\r\n * Também é possível verificar se o formulário está válido e informar valores para a exibição de informações.\r\n */\r\n@Directive()\r\nexport class PoDynamicFormBaseComponent {\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Nome da propriedade, atribuída ao `PoDynamicFormField.property`, que iniciará o campo com foco.\r\n   */\r\n  @Input('p-auto-focus') autoFocus?: string;\r\n\r\n  /**\r\n   * @description\r\n   *\r\n   * Coleção de objetos que implementam a interface `PoDynamicFormField`, para definição dos campos que serão criados\r\n   * dinamicamente.\r\n   *\r\n   * > Ex: `[ { property: 'name' } ]`\r\n   *\r\n   * Regras de tipagem e criação dos componentes:\r\n   *\r\n   * - Caso o *type* informado seja *boolean* o componente criado será o `po-switch`.\r\n   * - Caso o *type* informado seja *currency* e não seja informado um *mask* ou *pattern* o componente criado será o `po-decimal`,\r\n   * caso seja informado um *mask* ou *pattern* o componente criado será o `po-input`.\r\n   * - Caso o *type* informado seja *number* e não seja informado um *mask* ou *pattern* o componente criado será o `po-number`, caso seja\r\n   * informado um *mask* ou *pattern* o componente criado será o `po-input`.\r\n   * - Caso a lista possua a propriedade `options` e a mesma possua até 3 itens o componente criado será o `po-radio-group`\r\n   * ou `po-checkbox-group` se informar a propriedade `optionsMulti`.\r\n   * - Caso a mesma possua 3 ou mais itens, será criado o componente `po-select` ou, `po-multiselect` se a propriedade `optionsMulti`\r\n   * for verdadeira.\r\n   * - Caso o *type* informado seja *date* ou *datetime* o componente criado será o `po-datepicker`.\r\n   * - Caso seja informado a propriedade `optionsService` o componente criado será o `po-combo`.\r\n   * - Caso o *type* informado seja *time* o componente criado será um `po-input` podendo receber um *mask* para formatar\r\n   * o valor exibido, caso não seja informado um *mask* o componente será criado com a máscara '99:99' por padrão.\r\n   * - Caso a lista possua a propriedade `rows` e esta seja definida com valor maior ou igual a 3 o componente criado será\r\n   * o `po-textarea`, caso o valor da propriedade `rows` seja menor que 3 o componente criado será o `po-input`.\r\n   * - Caso seja informada a propriedade `secret` o componente criado será o `po-password`.\r\n   * - Caso o *type* informado seja *string* o componente criado será o `po-input`.\r\n   *\r\n   * @default `[]`\r\n   */\r\n  @Input('p-fields') fields: Array<PoDynamicFormField>;\r\n\r\n  /**\r\n   * Objeto que será utilizado como valor para exibir as informações, será recuperado e preenchido através do atributo *property*\r\n   * dos objetos contidos na propridade `p-fields`.\r\n   *\r\n   * Pode iniciar com valor ou apenas com um objeto vazio que será preenchido conforme descrito acima.\r\n   *\r\n   * > Ex: `{ name: 'po' }`\r\n   */\r\n  @Input('p-value') value: any;\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Na inicialização do componente será repassado o objeto de formulário utilizado no componente,\r\n   * podendo ser utilizado para validações e/ou detecção de mudança dos valores.\r\n   *\r\n   * Portanto existem duas maneiras de recuperar o formulário,\r\n   * através de *template reference* e através do *output*, veja os exemplos abaixo:\r\n   *\r\n   * > *template reference*\r\n   *\r\n   * ```html\r\n   *  <po-dynamic-form #dynamicForm>\r\n   *  </po-dynamic-form>\r\n   *\r\n   *  <po-button p-label=\"Adicionar\" [p-disabled]=\"dynamicForm?.form.invalid\">\r\n   *  </po-button>\r\n   *\r\n   * ```\r\n   *\r\n   * > *Output*\r\n   *\r\n   * ```html\r\n   *  ...\r\n   *  <po-dynamic-form (p-form)=\"getForm($event)\">\r\n   *  </po-dynamic-form>\r\n   *\r\n   *  <po-button p-label=\"Adicionar\" [p-disabled]=\"dynamicForm?.invalid\">\r\n   *  </po-button>\r\n   *  ...\r\n   *\r\n   * ```\r\n   *\r\n   * ```ts\r\n   *  ...\r\n   *\r\n   *  export class AppComponent {\r\n   *\r\n   *    dynamicForm: NgForm;\r\n   *\r\n   *    getForm(form: NgForm) {\r\n   *      this.dynamicForm = form;\r\n   *    }\r\n   *\r\n   *  }\r\n   * ```\r\n   *\r\n   * > Caso a propriedade `p-group-form` for verdadeira não será repassado o formulário, pois o mesmo utilizará\r\n   * o formulário pai.\r\n   */\r\n  @Output('p-form') formOutput: EventEmitter<NgForm> = new EventEmitter<NgForm>();\r\n\r\n  /**\r\n   * Função ou serviço que será executado na inicialização do componente.\r\n   *\r\n   * A propriedade aceita os seguintes tipos:\r\n   * - `string`: *Endpoint* usado pelo componente para requisição via `POST`.\r\n   * - `function`: Método que será executado.\r\n   *\r\n   * Ao ser executado, irá receber como parâmetro o objeto informado no `p-value`.\r\n   *\r\n   * O retorno desta função deve ser do tipo [PoDynamicFormLoad](documentation/po-dynamic-form#po-dynamic-form-load),\r\n   * onde o usuário poderá determinar as novas atualizações dos campos, valores e determinar o campo a ser focado.\r\n   *\r\n   * Por exemplo:\r\n   *\r\n   * ```\r\n   * onLoadFields(): PoDynamicFormLoad {\r\n   *\r\n   *   return {\r\n   *     value: { cpf: undefined },\r\n   *     fields: [\r\n   *       { property: 'cpf' }\r\n   *     ],\r\n   *     focus: 'cpf'\r\n   *   };\r\n   * }\r\n   *\r\n   * ```\r\n   * Para referenciar a sua função utilize a propriedade `bind`, por exemplo:\r\n   * ```\r\n   *  [p-load]=\"onLoadFields.bind(this)\"\r\n   * ```\r\n   */\r\n  @Input('p-load') load?: string | Function;\r\n\r\n  /**\r\n   * Função ou serviço para validar as **mudanças do formulário**.\r\n   *\r\n   * A propriedade aceita os seguintes tipos:\r\n   * - `string`: *Endpoint* usado pelo componente para requisição via `POST`.\r\n   * - `function`: Método que será executado.\r\n   *\r\n   * Ao ser executado, irá receber como parâmetro um objeto com o nome da propriedade\r\n   * alterada e o novo valor, conforme a interface `PoDynamicFormFieldChanged`:\r\n   *\r\n   * ```\r\n   * { property: 'property name', value: 'new value' }\r\n   * ```\r\n   *\r\n   * O retorno desta função deve ser do tipo [PoDynamicFormValidation](documentation/po-dynamic-form#po-dynamic-form-validation),\r\n   * onde o usuário poderá determinar as novas atualizações dos campos.\r\n   * Por exemplo:\r\n   *\r\n   * ```\r\n   * onChangeFields(changeValue): PoDynamicFormValidation {\r\n   *\r\n   * if (changeValue.property === 'state') {\r\n   *\r\n   *   return {\r\n   *     value: { city: undefined },\r\n   *     fields: [\r\n   *       { property: 'city', options: this.getCity(changeValue.value.state) }\r\n   *     ],\r\n   *     focus: 'city'\r\n   *   };\r\n   * }\r\n   *\r\n   * ```\r\n   * Para referenciar a sua função utilize a propriedade `bind`, por exemplo:\r\n   * ```\r\n   *  [p-validate]=\"this.myFunction.bind(this)\"\r\n   * ```\r\n   *\r\n   * > Se houver uma lista de campos para validação definida em `p-validate-fields`, a propriedade `validate` só receberá o disparo para os campos equivalentes.\r\n   */\r\n  @Input('p-validate') validate?: string | Function;\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Lista que define os campos que irão disparar o validate do form.\r\n   */\r\n  @Input('p-validate-fields') validateFields?: Array<string>;\r\n\r\n  private _groupForm?: boolean = false;\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   * Ao informar esta propriedade, o componente passará a utilizar o formulário pai para criar os `FormControl`\r\n   * e com isso é possível recuperar o valor do formulário e suas validações a partir do formulário pai.\r\n   *\r\n   * ```html\r\n   * <form #parentForm=\"ngForm\">\r\n   *\r\n   *   <po-dynamic-form p-group-form [p-fields]=\"fields\"></po-dynamic-form>\r\n   *\r\n   *  <po-button p-label=\"Adicionar\" [p-disabled]=\"parentForm.invalid\"></po-button>\r\n   * </form>\r\n   * ```\r\n   */\r\n  @Input('p-group-form') set groupForm(value: boolean) {\r\n    this._groupForm = <any>value === '' ? true : convertToBoolean(value);\r\n  }\r\n\r\n  get groupForm(): boolean {\r\n    return this._groupForm;\r\n  }\r\n}\r\n"]}
|
|
148
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-dynamic-form-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-base.component.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAEvE,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;;AAIvD;;;;;;;GAOG;AAEH,MAAM,OAAO,0BAA0B;IADvC;QAqDE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;WAmDG;QACe,eAAU,GAAyB,IAAI,YAAY,EAAU,CAAC;QAuFxE,eAAU,GAAa,KAAK,CAAC;QA0BrC;;;;;;;;;;;;;;;;;WAiBG;QAC2C,oBAAe,GAAY,KAAK,CAAC;KAChF;IA3CC;;;;;;;;;;;;;;;OAeG;IACH,IAA2B,SAAS,CAAC,KAAc;QACjD,IAAI,CAAC,UAAU,GAAQ,KAAK,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;IACvE,CAAC;IAED,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;;oGAvNU,0BAA0B;6EAA1B,0BAA0B;AA2OS;IAAf,YAAY,EAAE;mEAAkC;uFA3OpE,0BAA0B;cADtC,SAAS;gBASe,SAAS;kBAA/B,KAAK;mBAAC,cAAc;YAgCF,MAAM;kBAAxB,KAAK;mBAAC,UAAU;YAUC,KAAK;kBAAtB,KAAK;mBAAC,SAAS;YAsDE,UAAU;kBAA3B,MAAM;mBAAC,QAAQ;YAkCC,IAAI;kBAApB,KAAK;mBAAC,QAAQ;YA0CM,QAAQ;kBAA5B,KAAK;mBAAC,YAAY;YASS,cAAc;kBAAzC,KAAK;mBAAC,mBAAmB;YAoBC,SAAS;kBAAnC,KAAK;mBAAC,cAAc;YA0ByB,eAAe;kBAA5D,KAAK;mBAAC,qBAAqB","sourcesContent":["import { EventEmitter, Input, Output, Directive } from '@angular/core';\r\nimport { NgForm } from '@angular/forms';\r\nimport { InputBoolean } from '../../../decorators';\r\nimport { convertToBoolean } from '../../../utils/util';\r\n\r\nimport { PoDynamicFormField } from './po-dynamic-form-field.interface';\r\n\r\n/**\r\n *\r\n * @description\r\n *\r\n * Componente para criação de formulários dinâmicos a partir de uma lista de objetos.\r\n *\r\n * Também é possível verificar se o formulário está válido e informar valores para a exibição de informações.\r\n */\r\n@Directive()\r\nexport class PoDynamicFormBaseComponent {\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Nome da propriedade, atribuída ao `PoDynamicFormField.property`, que iniciará o campo com foco.\r\n   */\r\n  @Input('p-auto-focus') autoFocus?: string;\r\n\r\n  /**\r\n   * @description\r\n   *\r\n   * Coleção de objetos que implementam a interface `PoDynamicFormField`, para definição dos campos que serão criados\r\n   * dinamicamente.\r\n   *\r\n   * > Ex: `[ { property: 'name' } ]`\r\n   *\r\n   * Regras de tipagem e criação dos componentes:\r\n   *\r\n   * - Caso o *type* informado seja *boolean* o componente criado será o `po-switch`.\r\n   * - Caso o *type* informado seja *currency* e não seja informado um *mask* ou *pattern* o componente criado será o `po-decimal`,\r\n   * caso seja informado um *mask* ou *pattern* o componente criado será o `po-input`.\r\n   * - Caso o *type* informado seja *number* e não seja informado um *mask* ou *pattern* o componente criado será o `po-number`, caso seja\r\n   * informado um *mask* ou *pattern* o componente criado será o `po-input`.\r\n   * - Caso a lista possua a propriedade `options` e a mesma possua até 3 itens o componente criado será o `po-radio-group`\r\n   * ou `po-checkbox-group` se informar a propriedade `optionsMulti`.\r\n   * - Caso a mesma possua 3 ou mais itens, será criado o componente `po-select` ou, `po-multiselect` se a propriedade `optionsMulti`\r\n   * for verdadeira.\r\n   * - Caso o *type* informado seja *date* ou *datetime* o componente criado será o `po-datepicker`.\r\n   * - Caso seja informado a propriedade `optionsService` o componente criado será o `po-combo`.\r\n   * - Caso o *type* informado seja *time* o componente criado será um `po-input` podendo receber um *mask* para formatar\r\n   * o valor exibido, caso não seja informado um *mask* o componente será criado com a máscara '99:99' por padrão.\r\n   * - Caso a lista possua a propriedade `rows` e esta seja definida com valor maior ou igual a 3 o componente criado será\r\n   * o `po-textarea`, caso o valor da propriedade `rows` seja menor que 3 o componente criado será o `po-input`.\r\n   * - Caso seja informada a propriedade `secret` o componente criado será o `po-password`.\r\n   * - Caso o *type* informado seja *string* o componente criado será o `po-input`.\r\n   *\r\n   * @default `[]`\r\n   */\r\n  @Input('p-fields') fields: Array<PoDynamicFormField>;\r\n\r\n  /**\r\n   * Objeto que será utilizado como valor para exibir as informações, será recuperado e preenchido através do atributo *property*\r\n   * dos objetos contidos na propridade `p-fields`.\r\n   *\r\n   * Pode iniciar com valor ou apenas com um objeto vazio que será preenchido conforme descrito acima.\r\n   *\r\n   * > Ex: `{ name: 'po' }`\r\n   */\r\n  @Input('p-value') value: any;\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Na inicialização do componente será repassado o objeto de formulário utilizado no componente,\r\n   * podendo ser utilizado para validações e/ou detecção de mudança dos valores.\r\n   *\r\n   * Portanto existem duas maneiras de recuperar o formulário,\r\n   * através de *template reference* e através do *output*, veja os exemplos abaixo:\r\n   *\r\n   * > *template reference*\r\n   *\r\n   * ```html\r\n   *  <po-dynamic-form #dynamicForm>\r\n   *  </po-dynamic-form>\r\n   *\r\n   *  <po-button p-label=\"Adicionar\" [p-disabled]=\"dynamicForm?.form.invalid\">\r\n   *  </po-button>\r\n   *\r\n   * ```\r\n   *\r\n   * > *Output*\r\n   *\r\n   * ```html\r\n   *  ...\r\n   *  <po-dynamic-form (p-form)=\"getForm($event)\">\r\n   *  </po-dynamic-form>\r\n   *\r\n   *  <po-button p-label=\"Adicionar\" [p-disabled]=\"dynamicForm?.invalid\">\r\n   *  </po-button>\r\n   *  ...\r\n   *\r\n   * ```\r\n   *\r\n   * ```ts\r\n   *  ...\r\n   *\r\n   *  export class AppComponent {\r\n   *\r\n   *    dynamicForm: NgForm;\r\n   *\r\n   *    getForm(form: NgForm) {\r\n   *      this.dynamicForm = form;\r\n   *    }\r\n   *\r\n   *  }\r\n   * ```\r\n   *\r\n   * > Caso a propriedade `p-group-form` for verdadeira não será repassado o formulário, pois o mesmo utilizará\r\n   * o formulário pai.\r\n   */\r\n  @Output('p-form') formOutput: EventEmitter<NgForm> = new EventEmitter<NgForm>();\r\n\r\n  /**\r\n   * Função ou serviço que será executado na inicialização do componente.\r\n   *\r\n   * A propriedade aceita os seguintes tipos:\r\n   * - `string`: *Endpoint* usado pelo componente para requisição via `POST`.\r\n   * - `function`: Método que será executado.\r\n   *\r\n   * Ao ser executado, irá receber como parâmetro o objeto informado no `p-value`.\r\n   *\r\n   * O retorno desta função deve ser do tipo [PoDynamicFormLoad](documentation/po-dynamic-form#po-dynamic-form-load),\r\n   * onde o usuário poderá determinar as novas atualizações dos campos, valores e determinar o campo a ser focado.\r\n   *\r\n   * Por exemplo:\r\n   *\r\n   * ```\r\n   * onLoadFields(): PoDynamicFormLoad {\r\n   *\r\n   *   return {\r\n   *     value: { cpf: undefined },\r\n   *     fields: [\r\n   *       { property: 'cpf' }\r\n   *     ],\r\n   *     focus: 'cpf'\r\n   *   };\r\n   * }\r\n   *\r\n   * ```\r\n   * Para referenciar a sua função utilize a propriedade `bind`, por exemplo:\r\n   * ```\r\n   *  [p-load]=\"onLoadFields.bind(this)\"\r\n   * ```\r\n   */\r\n  @Input('p-load') load?: string | Function;\r\n\r\n  /**\r\n   * Função ou serviço para validar as **mudanças do formulário**.\r\n   *\r\n   * A propriedade aceita os seguintes tipos:\r\n   * - `string`: *Endpoint* usado pelo componente para requisição via `POST`.\r\n   * - `function`: Método que será executado.\r\n   *\r\n   * Ao ser executado, irá receber como parâmetro um objeto com o nome da propriedade\r\n   * alterada e o novo valor, conforme a interface `PoDynamicFormFieldChanged`:\r\n   *\r\n   * ```\r\n   * { property: 'property name', value: 'new value' }\r\n   * ```\r\n   *\r\n   * O retorno desta função deve ser do tipo [PoDynamicFormValidation](documentation/po-dynamic-form#po-dynamic-form-validation),\r\n   * onde o usuário poderá determinar as novas atualizações dos campos.\r\n   * Por exemplo:\r\n   *\r\n   * ```\r\n   * onChangeFields(changeValue): PoDynamicFormValidation {\r\n   *\r\n   * if (changeValue.property === 'state') {\r\n   *\r\n   *   return {\r\n   *     value: { city: undefined },\r\n   *     fields: [\r\n   *       { property: 'city', options: this.getCity(changeValue.value.state) }\r\n   *     ],\r\n   *     focus: 'city'\r\n   *   };\r\n   * }\r\n   *\r\n   * ```\r\n   * Para referenciar a sua função utilize a propriedade `bind`, por exemplo:\r\n   * ```\r\n   *  [p-validate]=\"this.myFunction.bind(this)\"\r\n   * ```\r\n   *\r\n   * > Se houver uma lista de campos para validação definida em `p-validate-fields`, a propriedade `validate` só receberá o disparo para os campos equivalentes.\r\n   */\r\n  @Input('p-validate') validate?: string | Function;\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Lista que define os campos que irão disparar o validate do form.\r\n   */\r\n  @Input('p-validate-fields') validateFields?: Array<string>;\r\n\r\n  private _groupForm?: boolean = false;\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   * Ao informar esta propriedade, o componente passará a utilizar o formulário pai para criar os `FormControl`\r\n   * e com isso é possível recuperar o valor do formulário e suas validações a partir do formulário pai.\r\n   *\r\n   * ```html\r\n   * <form #parentForm=\"ngForm\">\r\n   *\r\n   *   <po-dynamic-form p-group-form [p-fields]=\"fields\"></po-dynamic-form>\r\n   *\r\n   *  <po-button p-label=\"Adicionar\" [p-disabled]=\"parentForm.invalid\"></po-button>\r\n   * </form>\r\n   * ```\r\n   */\r\n  @Input('p-group-form') set groupForm(value: boolean) {\r\n    this._groupForm = <any>value === '' ? true : convertToBoolean(value);\r\n  }\r\n\r\n  get groupForm(): boolean {\r\n    return this._groupForm;\r\n  }\r\n\r\n  /**\r\n   * @optional\r\n   *\r\n   * @description\r\n   *\r\n   * Ao informar esta propriedade, o componente passará a emitir o valor a cada caractere digitado.\r\n   *\r\n   * Pode ser aplicado nos seguintes componentes:\r\n   * - po-input\r\n   * - po-number\r\n   * - po-decimal\r\n   * - po-textarea\r\n   * - po-password\r\n   *\r\n   * Deve informar os campos que deseja receber as emissões na propriedade `p-validate-fields`.\r\n   *\r\n   *\r\n   */\r\n  @Input('p-validate-on-input') @InputBoolean() validateOnInput: boolean = false;\r\n}\r\n"]}
|
package/esm2020/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-field.interface.mjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-dynamic-form-field.interface.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-field.interface.ts"],"names":[],"mappings":"","sourcesContent":["import { TemplateRef } from '@angular/core';\r\nimport {\r\n  PoCheckboxGroupOption,\r\n  PoComboFilter,\r\n  PoComboLiterals,\r\n  PoDatepickerIsoFormat,\r\n  PoDatepickerRangeLiterals,\r\n  PoLookupFilter,\r\n  PoLookupLiterals,\r\n  PoMultiselectFilterMode,\r\n  PoMultiselectLiterals,\r\n  PoSwitchLabelPosition\r\n} from '../../po-field';\r\nimport { PoLookupAdvancedFilter } from '../../po-field/po-lookup/interfaces/po-lookup-advanced-filter.interface';\r\nimport { PoLookupColumn } from '../../po-field/po-lookup/interfaces/po-lookup-column.interface';\r\nimport { PoMultiselectOption } from '../../po-field/po-multiselect/po-multiselect-option.interface';\r\nimport { PoSelectOption } from '../../po-field/po-select/po-select-option.interface';\r\n\r\nimport { PoDynamicField } from '../po-dynamic-field.interface';\r\n\r\n/**\r\n * @usedBy PoDynamicFormComponent, PoAdvancedFilterComponent, PoPageDynamicSearchComponent\r\n *\r\n * @docsExtends PoDynamicField\r\n *\r\n * @description\r\n *\r\n * Interface para definição das propriedades dos campos de entrada que serão criados dinamicamente.\r\n */\r\nexport interface PoDynamicFormField extends PoDynamicField {\r\n  /**\r\n   * Define as colunas para utilização da busca avançada. Usada somente em conjunto com a propriedade `searchService`,\r\n   * essa propriedade deve receber um array de objetos que implementam a interface [`PoLookupColumn`](/documentation/po-lookup).\r\n   *\r\n   * > Caso sejam informadas colunas, deve-se obrigatoriamente conter colunas definidas como *label* e *value* para valores\r\n   * de tela e do model respectivamente.\r\n   *\r\n   * **Componentes compatíveis:** `po-radio-group`, `po-lookup`, `po-checkbox-group`.\r\n   */\r\n  columns?: Array<PoLookupColumn> | number;\r\n\r\n  /** Define a obrigatoriedade do campo. */\r\n  required?: boolean;\r\n\r\n  /**\r\n   * Define se a indicação de campo opcional será exibida.\r\n   *\r\n   * > A indicação não será exibida, se:\r\n   * - O campo for `required`, ou;\r\n   * - Não possuir `help` e `label`.\r\n   */\r\n  optional?: boolean;\r\n\r\n  /**\r\n   * Lista de opções que serão exibidos em um componente, podendo selecionar uma opção.\r\n   *\r\n   * **Componentes compatíveis:** `po-select`, `po-radio-group`, `po-checkbox-group`, `po-multiselect`.\r\n   * */\r\n  options?: Array<string> | Array<PoSelectOption> | Array<PoMultiselectOption> | Array<PoCheckboxGroupOption>;\r\n\r\n  /**\r\n   * Permite que o usuário faça múltipla seleção dentro da lista de opções.\r\n   */\r\n  optionsMulti?: boolean;\r\n\r\n  /**\r\n   *  Serviço que será utilizado para buscar os itens e preencher a lista de opções dinamicamente.\r\n   *  Pode ser informada uma URL ou uma instancia do serviço baseado em PoComboFilter.\r\n   *  **Importante**\r\n   *  > Para que funcione corretamente, é importante que o serviço siga o\r\n   *  [guia de API do PO UI](https://po-ui.io/guides/api).\r\n   */\r\n  optionsService?: string | PoComboFilter;\r\n\r\n  /**\r\n   * Serviço que será utilizado para realizar a busca avançada. Pode ser utilizado em conjunto com a propriedade `columns`.\r\n   * Pode ser ser informada uma URL ou uma instancia do serviço baseado em PoLookupFilter.\r\n   * **Importante:**\r\n   * > Caso utilizar a propriedade `optionsService` esta propriedade será ignorada.\r\n   * > Para que funcione corretamente, é importante que o serviço siga o\r\n   * [guia de API do PO UI](https://po-ui.io/guides/api).\r\n   */\r\n  searchService?: string | PoLookupFilter;\r\n\r\n  /**\r\n   * Máscara para o campo.\r\n   *\r\n   * **Componentes compatíveis:** `po-input`.\r\n   > também é atribuído ao utilizar a propriedade `type: time`.\r\n   */\r\n  mask?: string;\r\n\r\n  /**\r\n   * Define que o valor do componente será conforme especificado na mascára. O valor padrão é `false`.\r\n   *\r\n   * **Componentes compatíveis:** `po-input`.\r\n   > também é atribuído ao utilizar a propriedade `type: time`.\r\n   * */\r\n  maskFormatModel?: boolean;\r\n\r\n  /** Define o ícone que será exibido no início do campo.\r\n   * > Esta propriedade só pode ser utilizado nos campos:\r\n   * - Input;\r\n   * - Number;\r\n   * - Decimal;\r\n   * - Combo;\r\n   * - Password;\r\n   *\r\n   * > Veja a disponibilidade de ícones em [biblioteca de ícones](guides/icons).\r\n   */\r\n  icon?: string | TemplateRef<void>;\r\n\r\n  /**  Quantidade máxima de casas decimais.\r\n   *\r\n   * > Esta propriedade só pode ser utilizada quando o `type` for *currency*.\r\n   */\r\n  decimalsLength?: number;\r\n\r\n  /** Quantidade máxima de dígitos antes do separador decimal. O valor máximo permitido é 13\r\n   *\r\n   * > Esta propriedade só pode ser utilizada quando o `type` for *currency*.\r\n   */\r\n  thousandMaxlength?: number;\r\n\r\n  /**\r\n   * Regex para validação do campo.\r\n   *\r\n   * **Componentes compatíveis:** `po-input`, `po-password`.\r\n   * */\r\n  pattern?: string;\r\n\r\n  /**\r\n   * Tamanho mínimo de caracteres.\r\n   *\r\n   * **Componentes compatíveis:** `po-input`, `po-number`, `po-decimal`, `po-textarea`, `po-password`.\r\n   * */\r\n  minLength?: number;\r\n\r\n  /**\r\n   * Tamanho máximo de caracteres.\r\n   *\r\n   * **Componentes compatíveis:** `po-input`, `po-number`, `po-decimal`, `po-textarea`, `po-password`.\r\n   */\r\n  maxLength?: number;\r\n\r\n  /** Desabilita o campo caso informar o valor *true*. */\r\n  disabled?: boolean;\r\n\r\n  /** Texto de ajuda. */\r\n  help?: string;\r\n\r\n  /** Texto exibido quando o valor do componente for *true*. */\r\n  booleanTrue?: string;\r\n\r\n  /** Texto exibido quando o valor do componente for *false*. */\r\n  booleanFalse?: string;\r\n\r\n  /**\r\n   * Valor máximo a ser informado no componente, podendo ser utilizado quando o tipo de dado por *number*, *date* ou *dateTime*.\r\n   *\r\n   * **Componentes compatíveis:** `po-datepicker`, `po-datepicker-range`, `po-number`, `po-decimal`\r\n   * */\r\n  maxValue?: string | number;\r\n\r\n  /**\r\n   * Valor mínimo a ser informado no componente, podendo ser utilizado quando o tipo de dado por *number*, *date* ou *dateTime*.\r\n   *\r\n   * **Componentes compatíveis:** `po-datepicker`, `po-datepicker-range`, `po-number`, `po-decimal`\r\n   */\r\n  minValue?: string | number;\r\n\r\n  /** Quantidade de linhas exibidas no `po-textarea`. */\r\n  rows?: number;\r\n\r\n  /** Esconde a informação estilo *password*, pode ser utilizado quando o tipo de dado for *string*. */\r\n  secret?: boolean;\r\n\r\n  /**\r\n   * Função ou serviço para validar as **mudanças do campo**.\r\n   *\r\n   * * A propriedade aceita os seguintes tipos:\r\n   * - **String**: Endpoint usado pelo componente para requisição via `POST`.\r\n   * - **Function**: Método que será executado.\r\n   *\r\n   * Ao ser executado, irá receber como parâmetro um objeto com o nome da propriedade\r\n   * alterada e o novo valor, conforme a interface `PoDynamicFormFieldChanged`:\r\n   *\r\n   * ``\r\n   * { property: 'property name', value: 'new value' }\r\n   * ``\r\n   *\r\n   * O retorno desta função deve ser do tipo [PoDynamicFormFieldValidation](documentation/po-dynamic-form#po-dynamic-form-field-validation),\r\n   * onde o usuário poderá determinar as novas propriedades do campo.\r\n   * Por exemplo:\r\n   *\r\n   * ``\r\n   * onChangeField(changeValue): PoDynamicFormFieldValidation {\r\n   *\r\n   * if (changeValue.property === 'birthday' && !this.validate('birthday')) {\r\n   *   return {\r\n   *     value: '',\r\n   *     field: { property: 'birthday', required: true },\r\n   *     focus: true\r\n   *   };\r\n   * }\r\n   * ``\r\n   *\r\n   * Para referenciar a sua função utilize a propriedade `bind`, por exemplo:\r\n   * ``\r\n   * { property: 'state', gridColumns: 6, validate: this.myFunction.bind(this) }\r\n   * ``\r\n   */\r\n  validate?: string | Function;\r\n\r\n  /**\r\n   * Objeto que será enviado como parâmetro nas requisições de busca usados pelos componentes `po-lookup` e\r\n   * `po-combo`.\r\n   *\r\n   * Por exemplo, para o parâmetro `{ age: 23 }` a URL da requisição ficaria:\r\n   *\r\n   * ``\r\n   * url + ?age=23&filter=Peter\r\n   * ``\r\n   */\r\n  params?: any;\r\n\r\n  /**\r\n   * Mensagem que será apresentada quando o campo ficar inválido.\r\n   *\r\n   * O campo fica inválido quando as seguintes propriedades não forem respeitadas:\r\n   *  - pattern;\r\n   *  - minValue;\r\n   *  - maxValue;\r\n   *\r\n   * > Esta mensagem não é apresentada quando o campo estiver vazio, mesmo que ele seja requerido.\r\n   *\r\n   * **Componentes compatíveis:** `po-datepicker`, `po-input`, `po-number`, `po-decimal`, `po-password`.\r\n   */\r\n  errorMessage?: string;\r\n\r\n  /**\r\n   * Formato de exibição no campo.\r\n   *\r\n   * Ao utilizar esta propriedade com o `type` *PoDynamicFieldType.Date* ou *PoDynamicFieldType.DateTime*,\r\n   * pode ser utilizada para formatação de exibição da data:\r\n   *\r\n   * Valores válidos:\r\n   *\r\n   * - dd/mm/yyyy\r\n   * - mm/dd/yyyy\r\n   * - yyyy/mm/dd\r\n   *\r\n   *\r\n   * Também pode-se utilizar em conjunto com `searchService`, informando uma lista de propriedades que será utilizado\r\n   * para formatação da exibição no campo, por exemplo: [\"id\", \"name\"].\r\n   */\r\n  format?: string | Array<string>;\r\n\r\n  /**\r\n   * Nome da propriedade do objeto retornado que será utilizado como descrição do campo.\r\n   *\r\n   * O valor padrão é: `label`.\r\n   *\r\n   * > Esta propriedade pode ser utilizada em conjunto com: `optionsService` e `searchService`.\r\n   */\r\n  fieldLabel?: string;\r\n\r\n  /**\r\n   * Nome da propriedade do objeto retornado que será utilizado como valor do campo.\r\n   *\r\n   * O valor padrão é: `value`.\r\n   *\r\n   * > Esta propriedade pode ser utilizada em conjunto com: `optionsService` e `searchService`.\r\n   */\r\n  fieldValue?: string;\r\n\r\n  /**\r\n   * Informa a ordem de exibição do campo.\r\n   *\r\n   * Exemplo de utilização:\r\n   *\r\n   * ``\r\n   * [\r\n   *   { property: 'test 1', order: 2 },\r\n   *   { property: 'test 2', order: 1 },\r\n   *   { property: 'test 3' },\r\n   *   { property: 'test 4', order: 3 }\r\n   * ];\r\n   * ``\r\n   *\r\n   * Na exibição a ordem ficará dessa forma:\r\n   * ``\r\n   * [\r\n   *   { property: 'test 2', order: 1 },\r\n   *   { property: 'test 1', order: 2 },\r\n   *   { property: 'test 4', order: 3 },\r\n   *   { property: 'test 3' }\r\n   * ];\r\n   * ``\r\n   *\r\n   * Só serão aceitos valores com números inteiros maiores do que zero.\r\n   *\r\n   * Campos sem `order` ou com valores negativos, zerados ou inválidos\r\n   * serão os últimos a serem renderizados e seguirão o posicionamento dentro do\r\n   * array.\r\n   */\r\n  order?: number;\r\n\r\n  /** Mensagem que será exibida enquanto o campo não estiver preenchido. */\r\n  placeholder?: string;\r\n\r\n  /**\r\n   * Define a localidade a ser utilizada no componente.\r\n   * Por padrão o valor será configurado segundo a o módulo [`I18n`](documentation/po-i18n)\r\n   *\r\n   * Exemplo de utilização:\r\n   * ``\r\n   * [\r\n   *   { property: 'birthday', locale: 'en', type: 'date' },\r\n   *   { property: 'wage', locale: 'ru', type: 'currency' }\r\n   * ];\r\n   * ``\r\n   *\r\n   * > Para ver quais linguagens suportadas acesse [`I18n`](documentation/po-i18n)\r\n   * > A propriedade será repassada para os componentes que suportam a mesma.\r\n   */\r\n  locale?: string;\r\n\r\n  /**\r\n   * O controle passa a permitir a entrada de um intervalo ao invés de um único valor.\r\n   *\r\n   * > Atualmente essa propriedade está disponível apenas para o tipo 'date' e 'dateTime'.\r\n   */\r\n  range?: boolean;\r\n\r\n  /** Indica que o campo será somente leitura.\r\n   *\r\n   * **Componentes compatíveis:** `po-datepicker`, `po-datepicker-range`, `po-input`, `po-number`, `po-decimal`, `po-select`, `po-textarea`, `po-password`\r\n   */\r\n  readonly?: boolean;\r\n\r\n  /**\r\n   * Permite a seleção de múltiplos itens.\r\n   *\r\n   * **Componente compatível:** `po-lookup`\r\n   */\r\n  multiple?: boolean;\r\n\r\n  /** Se verdadeiro, o campo receberá um botão para ser limpo.\r\n   *\r\n   * **Componentes compatíveis:** `po-datepicker`, `po-datepicker-range`, `po-input`, `po-number`, `po-decimal`, `po-combo`, `po-lookup`, `po-password`\r\n   */\r\n  clean?: boolean;\r\n\r\n  /**\r\n   * Define a propriedade nativa `autocomplete` do campo como off.\r\n   *\r\n   * **Componentes compatíveis:** `po-datepicker`, `po-datepicker-range`, `po-input`, `po-number`, `po-decimal`, `po-lookup`, `po-password`\r\n   */\r\n  noAutocomplete?: boolean;\r\n\r\n  /**\r\n   * Posição de exibição do rótulo do PoSwich.\r\n   * > Por padrão exibe à direita.\r\n   */\r\n  labelPosition?: PoSwitchLabelPosition;\r\n\r\n  /**\r\n   * Permite esconder a função de espiar a senha digitada no `po-password`.\r\n   */\r\n  hidePasswordPeek?: boolean;\r\n\r\n  /**\r\n   * Padrão de formatação para saída do model, independentemente do formato de entrada.\r\n   *\r\n   * > Veja os valores válidos no `enumPoDatepickerIsoFormat`.\r\n   *\r\n   * **Componente compatível:** po-datepicker\r\n   */\r\n  isoFormat?: PoDatepickerIsoFormat;\r\n\r\n  /**\r\n   * Objeto com as literais usadas para os seguintes componentes: `po-lookup`, `po-multiselect`, `po-combo` e `po-datepicker-range`.\r\n   *\r\n   * > O objeto padrão de literais será traduzido de acordo com o idioma do PoI18nService ou do browser.\r\n   *\r\n   * **Componentes compatíveis:** `po-lookup`, `po-multiselect`, `po-combo`, `po-datepicker-range`\r\n   */\r\n  literals?: PoLookupLiterals | PoMultiselectLiterals | PoComboLiterals | PoDatepickerRangeLiterals;\r\n\r\n  /**\r\n   * Se verdadeiro ativa a funcionalidade de scroll infinito para o combo ou lookup, ao chegar ao fim da tabela executará nova busca dos dados conforme paginação.\r\n   *\r\n   * **Componentes compatíveis:** `po-combo`, `po-lookup`.\r\n   */\r\n  infiniteScroll?: boolean;\r\n\r\n  /**\r\n   * Define o percentual necessário para disparar o evento show-more, que é responsável por carregar mais dados no combo. Caso o valor seja maior que 100 ou menor que 0, o valor padrão será 100%.\r\n   * **Exemplos**\r\n   * `{ infiniteScrollDistance: 80 }`: Quando atingir 80% do scroll do combo, o show-more será disparado.\r\n   *\r\n   * **Componente compatível:** `po-combo`.\r\n   */\r\n  infiniteScrollDistance?: number;\r\n\r\n  /**\r\n   * Define que a altura do componente será auto ajustável, possuindo uma altura minima porém a altura máxima será de acordo com o número de itens selecionados e a extensão dos mesmos, mantendo-os sempre visíveis.\r\n   *\r\n   * **Componentes compatíveis:** `po-multiselect`, `po-lookup`.\r\n   */\r\n  autoHeight?: boolean;\r\n\r\n  /**\r\n   * Intervalo utilizado no `po-number`.\r\n   */\r\n  step?: number;\r\n\r\n  /**\r\n   * Define o modo de pesquisa utilizado no filtro da lista de seleção: `startsWith`, `contains` ou `endsWith`.\r\n   * > Quando utilizar a propriedade p-filter-service esta propriedade será ignorada.\r\n   *\r\n   * **Componentes compatíveis:** `po-multiselect`.\r\n   */\r\n  filterMode?: PoMultiselectFilterMode;\r\n\r\n  /**\r\n   * Valor mínimo de caracteres para realizar o filtro no serviço do `po-combo`.\r\n   */\r\n  filterMinlength?: number;\r\n\r\n  /**\r\n   * Desabilita o filtro inicial no serviço do `po-combo`, que é executado no primeiro clique no campo.\r\n   */\r\n  disabledInitFilter?: boolean;\r\n\r\n  /**\r\n   * Se verdadeiro, desabilitará a busca de um item via TAB no `po-combo`.\r\n   */\r\n  disabledTabFilter?: boolean;\r\n\r\n  /**\r\n   * Esta propriedade define em quanto tempo (em milissegundos), aguarda para acionar o evento de filtro após cada pressionamento de tecla. Será utilizada apenas quando houver serviço (`p-filter-service`).\r\n   *\r\n   * **Componentes compatíveis:** `po-combo`, `po-multiselect`.\r\n   */\r\n  debounceTime?: number;\r\n\r\n  /**\r\n   * Indica que o evento `p-change` só será disparado ao clicar ou pressionar a tecla \"Enter\" sobre uma opção selecionada no `po-combo`.\r\n   */\r\n  changeOnEnter?: boolean;\r\n\r\n  /**\r\n   * Indica que a lista definida na propriedade p-options será ordenada pela descrição.\r\n   *\r\n   * **Componentes compatíveis:** `po-combo`, po-multiselect\r\n   */\r\n  sort?: boolean;\r\n\r\n  /**\r\n   * Placeholder do campo de pesquisa do `po-multiselect`.\r\n   *\r\n   * > Caso o mesmo não seja informado, o valor padrão será traduzido com base no idioma do navegador (pt, es e en).\r\n   */\r\n  placeholderSearch?: string;\r\n\r\n  /**\r\n   * Esconde o campo de pesquisa existente dentro do dropdown do `po-multiselect`.\r\n   */\r\n  hideSearch?: boolean;\r\n\r\n  /**\r\n   * Indica se o campo \"Selecionar todos\" do `po-multiselect` será escondido.\r\n   */\r\n  hideSelectAll?: boolean;\r\n\r\n  /**\r\n   * Lista de objetos dos campos que serão criados na busca avançada.\r\n   *\r\n   * > Caso não seja passado um objeto ou então ele esteja em branco o link de busca avançada ficará escondido.\r\n   *\r\n   * Exemplo de URL com busca avançada:\r\n   *\r\n   * `url + ?page=1&pageSize=20&name=Tony%20Stark&nickname=Homem%20de%20Ferro`\r\n   *\r\n   * Caso algum parâmetro seja uma lista, a concatenação é feita utilizando vírgula. Exemplo:\r\n   *\r\n   * `url + ?page=1&pageSize=20&name=Tony%20Stark,Peter%20Parker,Gohan`\r\n   */\r\n  advancedFilters?: Array<PoLookupAdvancedFilter>;\r\n}\r\n"]}
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-dynamic-form-field.interface.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-field.interface.ts"],"names":[],"mappings":"","sourcesContent":["import { TemplateRef } from '@angular/core';\r\nimport {\r\n  PoCheckboxGroupOption,\r\n  PoComboFilter,\r\n  PoComboLiterals,\r\n  PoDatepickerIsoFormat,\r\n  PoDatepickerRangeLiterals,\r\n  PoLookupFilter,\r\n  PoLookupLiterals,\r\n  PoMultiselectFilterMode,\r\n  PoMultiselectLiterals,\r\n  PoSwitchLabelPosition\r\n} from '../../po-field';\r\nimport { PoLookupAdvancedFilter } from '../../po-field/po-lookup/interfaces/po-lookup-advanced-filter.interface';\r\nimport { PoLookupColumn } from '../../po-field/po-lookup/interfaces/po-lookup-column.interface';\r\nimport { PoMultiselectOption } from '../../po-field/po-multiselect/po-multiselect-option.interface';\r\nimport { PoSelectOption } from '../../po-field/po-select/po-select-option.interface';\r\nimport { ForceOptionComponentEnum } from '../po-dynamic-field-force-component.enum';\r\n\r\nimport { PoDynamicField } from '../po-dynamic-field.interface';\r\n\r\n/**\r\n * @usedBy PoDynamicFormComponent, PoAdvancedFilterComponent, PoPageDynamicSearchComponent\r\n *\r\n * @docsExtends PoDynamicField\r\n *\r\n * @description\r\n *\r\n * Interface para definição das propriedades dos campos de entrada que serão criados dinamicamente.\r\n */\r\nexport interface PoDynamicFormField extends PoDynamicField {\r\n  /**\r\n   * Define as colunas para utilização da busca avançada. Usada somente em conjunto com a propriedade `searchService`,\r\n   * essa propriedade deve receber um array de objetos que implementam a interface [`PoLookupColumn`](/documentation/po-lookup).\r\n   *\r\n   * > Caso sejam informadas colunas, deve-se obrigatoriamente conter colunas definidas como *label* e *value* para valores\r\n   * de tela e do model respectivamente.\r\n   *\r\n   * **Componentes compatíveis:** `po-radio-group`, `po-lookup`, `po-checkbox-group`.\r\n   */\r\n  columns?: Array<PoLookupColumn> | number;\r\n\r\n  /** Define a obrigatoriedade do campo. */\r\n  required?: boolean;\r\n\r\n  /**\r\n   * Define se a indicação de campo opcional será exibida.\r\n   *\r\n   * > A indicação não será exibida, se:\r\n   * - O campo for `required`, ou;\r\n   * - Não possuir `help` e `label`.\r\n   */\r\n  optional?: boolean;\r\n\r\n  /**\r\n   * Lista de opções que serão exibidos em um componente, podendo selecionar uma opção.\r\n   *\r\n   * **Componentes compatíveis:** `po-select`, `po-radio-group`, `po-checkbox-group`, `po-multiselect`.\r\n   * */\r\n  options?: Array<string> | Array<PoSelectOption> | Array<PoMultiselectOption> | Array<PoCheckboxGroupOption>;\r\n\r\n  /**\r\n   * Permite que o usuário faça múltipla seleção dentro da lista de opções.\r\n   */\r\n  optionsMulti?: boolean;\r\n\r\n  /**\r\n   *  Serviço que será utilizado para buscar os itens e preencher a lista de opções dinamicamente.\r\n   *  Pode ser informada uma URL ou uma instancia do serviço baseado em PoComboFilter.\r\n   *  **Importante**\r\n   *  > Para que funcione corretamente, é importante que o serviço siga o\r\n   *  [guia de API do PO UI](https://po-ui.io/guides/api).\r\n   */\r\n  optionsService?: string | PoComboFilter;\r\n\r\n  /**\r\n   * Serviço que será utilizado para realizar a busca avançada. Pode ser utilizado em conjunto com a propriedade `columns`.\r\n   * Pode ser ser informada uma URL ou uma instancia do serviço baseado em PoLookupFilter.\r\n   * **Importante:**\r\n   * > Caso utilizar a propriedade `optionsService` esta propriedade será ignorada.\r\n   * > Para que funcione corretamente, é importante que o serviço siga o\r\n   * [guia de API do PO UI](https://po-ui.io/guides/api).\r\n   */\r\n  searchService?: string | PoLookupFilter;\r\n\r\n  /**\r\n   * Máscara para o campo.\r\n   *\r\n   * **Componentes compatíveis:** `po-input`.\r\n   > também é atribuído ao utilizar a propriedade `type: time`.\r\n   */\r\n  mask?: string;\r\n\r\n  /**\r\n   * Define que o valor do componente será conforme especificado na mascára. O valor padrão é `false`.\r\n   *\r\n   * **Componentes compatíveis:** `po-input`.\r\n   > também é atribuído ao utilizar a propriedade `type: time`.\r\n   * */\r\n  maskFormatModel?: boolean;\r\n\r\n  /** Define o ícone que será exibido no início do campo.\r\n   * > Esta propriedade só pode ser utilizado nos campos:\r\n   * - Input;\r\n   * - Number;\r\n   * - Decimal;\r\n   * - Combo;\r\n   * - Password;\r\n   *\r\n   * > Veja a disponibilidade de ícones em [biblioteca de ícones](guides/icons).\r\n   */\r\n  icon?: string | TemplateRef<void>;\r\n\r\n  /**  Quantidade máxima de casas decimais.\r\n   *\r\n   * > Esta propriedade só pode ser utilizada quando o `type` for *currency*.\r\n   */\r\n  decimalsLength?: number;\r\n\r\n  /** Quantidade máxima de dígitos antes do separador decimal. O valor máximo permitido é 13\r\n   *\r\n   * > Esta propriedade só pode ser utilizada quando o `type` for *currency*.\r\n   */\r\n  thousandMaxlength?: number;\r\n\r\n  /**\r\n   * Regex para validação do campo.\r\n   *\r\n   * **Componentes compatíveis:** `po-input`, `po-password`.\r\n   * */\r\n  pattern?: string;\r\n\r\n  /**\r\n   * Tamanho mínimo de caracteres.\r\n   *\r\n   * **Componentes compatíveis:** `po-input`, `po-number`, `po-decimal`, `po-textarea`, `po-password`.\r\n   * */\r\n  minLength?: number;\r\n\r\n  /**\r\n   * Tamanho máximo de caracteres.\r\n   *\r\n   * **Componentes compatíveis:** `po-input`, `po-number`, `po-decimal`, `po-textarea`, `po-password`.\r\n   */\r\n  maxLength?: number;\r\n\r\n  /** Desabilita o campo caso informar o valor *true*. */\r\n  disabled?: boolean;\r\n\r\n  /** Texto de ajuda. */\r\n  help?: string;\r\n\r\n  /** Texto exibido quando o valor do componente for *true*. */\r\n  booleanTrue?: string;\r\n\r\n  /** Texto exibido quando o valor do componente for *false*. */\r\n  booleanFalse?: string;\r\n\r\n  /**\r\n   * Valor máximo a ser informado no componente, podendo ser utilizado quando o tipo de dado por *number*, *date* ou *dateTime*.\r\n   *\r\n   * **Componentes compatíveis:** `po-datepicker`, `po-datepicker-range`, `po-number`, `po-decimal`\r\n   * */\r\n  maxValue?: string | number;\r\n\r\n  /**\r\n   * Valor mínimo a ser informado no componente, podendo ser utilizado quando o tipo de dado por *number*, *date* ou *dateTime*.\r\n   *\r\n   * **Componentes compatíveis:** `po-datepicker`, `po-datepicker-range`, `po-number`, `po-decimal`\r\n   */\r\n  minValue?: string | number;\r\n\r\n  /** Quantidade de linhas exibidas no `po-textarea`. */\r\n  rows?: number;\r\n\r\n  /** Esconde a informação estilo *password*, pode ser utilizado quando o tipo de dado for *string*. */\r\n  secret?: boolean;\r\n\r\n  /**\r\n   * Função ou serviço para validar as **mudanças do campo**.\r\n   *\r\n   * * A propriedade aceita os seguintes tipos:\r\n   * - **String**: Endpoint usado pelo componente para requisição via `POST`.\r\n   * - **Function**: Método que será executado.\r\n   *\r\n   * Ao ser executado, irá receber como parâmetro um objeto com o nome da propriedade\r\n   * alterada e o novo valor, conforme a interface `PoDynamicFormFieldChanged`:\r\n   *\r\n   * ``\r\n   * { property: 'property name', value: 'new value' }\r\n   * ``\r\n   *\r\n   * O retorno desta função deve ser do tipo [PoDynamicFormFieldValidation](documentation/po-dynamic-form#po-dynamic-form-field-validation),\r\n   * onde o usuário poderá determinar as novas propriedades do campo.\r\n   * Por exemplo:\r\n   *\r\n   * ``\r\n   * onChangeField(changeValue): PoDynamicFormFieldValidation {\r\n   *\r\n   * if (changeValue.property === 'birthday' && !this.validate('birthday')) {\r\n   *   return {\r\n   *     value: '',\r\n   *     field: { property: 'birthday', required: true },\r\n   *     focus: true\r\n   *   };\r\n   * }\r\n   * ``\r\n   *\r\n   * Para referenciar a sua função utilize a propriedade `bind`, por exemplo:\r\n   * ``\r\n   * { property: 'state', gridColumns: 6, validate: this.myFunction.bind(this) }\r\n   * ``\r\n   */\r\n  validate?: string | Function;\r\n\r\n  /**\r\n   * Objeto que será enviado como parâmetro nas requisições de busca usados pelos componentes `po-lookup` e\r\n   * `po-combo`.\r\n   *\r\n   * Por exemplo, para o parâmetro `{ age: 23 }` a URL da requisição ficaria:\r\n   *\r\n   * ``\r\n   * url + ?age=23&filter=Peter\r\n   * ``\r\n   */\r\n  params?: any;\r\n\r\n  /**\r\n   * Mensagem que será apresentada quando o campo ficar inválido.\r\n   *\r\n   * O campo fica inválido quando as seguintes propriedades não forem respeitadas:\r\n   *  - pattern;\r\n   *  - minValue;\r\n   *  - maxValue;\r\n   *\r\n   * > Esta mensagem não é apresentada quando o campo estiver vazio, mesmo que ele seja requerido.\r\n   *\r\n   * **Componentes compatíveis:** `po-datepicker`, `po-input`, `po-number`, `po-decimal`, `po-password`.\r\n   */\r\n  errorMessage?: string;\r\n\r\n  /**\r\n   * Formato de exibição no campo.\r\n   *\r\n   * Ao utilizar esta propriedade com o `type` *PoDynamicFieldType.Date* ou *PoDynamicFieldType.DateTime*,\r\n   * pode ser utilizada para formatação de exibição da data:\r\n   *\r\n   * Valores válidos:\r\n   *\r\n   * - dd/mm/yyyy\r\n   * - mm/dd/yyyy\r\n   * - yyyy/mm/dd\r\n   *\r\n   *\r\n   * Também pode-se utilizar em conjunto com `searchService`, informando uma lista de propriedades que será utilizado\r\n   * para formatação da exibição no campo, por exemplo: [\"id\", \"name\"].\r\n   */\r\n  format?: string | Array<string>;\r\n\r\n  /**\r\n   * Nome da propriedade do objeto retornado que será utilizado como descrição do campo.\r\n   *\r\n   * O valor padrão é: `label`.\r\n   *\r\n   * > Esta propriedade pode ser utilizada em conjunto com: `optionsService` e `searchService`.\r\n   */\r\n  fieldLabel?: string;\r\n\r\n  /**\r\n   * Nome da propriedade do objeto retornado que será utilizado como valor do campo.\r\n   *\r\n   * O valor padrão é: `value`.\r\n   *\r\n   * > Esta propriedade pode ser utilizada em conjunto com: `optionsService` e `searchService`.\r\n   */\r\n  fieldValue?: string;\r\n\r\n  /**\r\n   * Informa a ordem de exibição do campo.\r\n   *\r\n   * Exemplo de utilização:\r\n   *\r\n   * ``\r\n   * [\r\n   *   { property: 'test 1', order: 2 },\r\n   *   { property: 'test 2', order: 1 },\r\n   *   { property: 'test 3' },\r\n   *   { property: 'test 4', order: 3 }\r\n   * ];\r\n   * ``\r\n   *\r\n   * Na exibição a ordem ficará dessa forma:\r\n   * ``\r\n   * [\r\n   *   { property: 'test 2', order: 1 },\r\n   *   { property: 'test 1', order: 2 },\r\n   *   { property: 'test 4', order: 3 },\r\n   *   { property: 'test 3' }\r\n   * ];\r\n   * ``\r\n   *\r\n   * Só serão aceitos valores com números inteiros maiores do que zero.\r\n   *\r\n   * Campos sem `order` ou com valores negativos, zerados ou inválidos\r\n   * serão os últimos a serem renderizados e seguirão o posicionamento dentro do\r\n   * array.\r\n   */\r\n  order?: number;\r\n\r\n  /** Mensagem que será exibida enquanto o campo não estiver preenchido. */\r\n  placeholder?: string;\r\n\r\n  /**\r\n   * Define a localidade a ser utilizada no componente.\r\n   * Por padrão o valor será configurado segundo a o módulo [`I18n`](documentation/po-i18n)\r\n   *\r\n   * Exemplo de utilização:\r\n   * ``\r\n   * [\r\n   *   { property: 'birthday', locale: 'en', type: 'date' },\r\n   *   { property: 'wage', locale: 'ru', type: 'currency' }\r\n   * ];\r\n   * ``\r\n   *\r\n   * > Para ver quais linguagens suportadas acesse [`I18n`](documentation/po-i18n)\r\n   * > A propriedade será repassada para os componentes que suportam a mesma.\r\n   */\r\n  locale?: string;\r\n\r\n  /**\r\n   * O controle passa a permitir a entrada de um intervalo ao invés de um único valor.\r\n   *\r\n   * > Atualmente essa propriedade está disponível apenas para o tipo 'date' e 'dateTime'.\r\n   */\r\n  range?: boolean;\r\n\r\n  /** Indica que o campo será somente leitura.\r\n   *\r\n   * **Componentes compatíveis:** `po-datepicker`, `po-datepicker-range`, `po-input`, `po-number`, `po-decimal`, `po-select`, `po-textarea`, `po-password`\r\n   */\r\n  readonly?: boolean;\r\n\r\n  /**\r\n   * Permite a seleção de múltiplos itens.\r\n   *\r\n   * **Componente compatível:** `po-lookup`\r\n   */\r\n  multiple?: boolean;\r\n\r\n  /** Se verdadeiro, o campo receberá um botão para ser limpo.\r\n   *\r\n   * **Componentes compatíveis:** `po-datepicker`, `po-datepicker-range`, `po-input`, `po-number`, `po-decimal`, `po-combo`, `po-lookup`, `po-password`\r\n   */\r\n  clean?: boolean;\r\n\r\n  /**\r\n   * Define a propriedade nativa `autocomplete` do campo como off.\r\n   *\r\n   * **Componentes compatíveis:** `po-datepicker`, `po-datepicker-range`, `po-input`, `po-number`, `po-decimal`, `po-lookup`, `po-password`\r\n   */\r\n  noAutocomplete?: boolean;\r\n\r\n  /**\r\n   * Posição de exibição do rótulo do PoSwich.\r\n   * > Por padrão exibe à direita.\r\n   */\r\n  labelPosition?: PoSwitchLabelPosition;\r\n\r\n  /**\r\n   * Permite esconder a função de espiar a senha digitada no `po-password`.\r\n   */\r\n  hidePasswordPeek?: boolean;\r\n\r\n  /**\r\n   * Padrão de formatação para saída do model, independentemente do formato de entrada.\r\n   *\r\n   * > Veja os valores válidos no `enumPoDatepickerIsoFormat`.\r\n   *\r\n   * **Componente compatível:** po-datepicker\r\n   */\r\n  isoFormat?: PoDatepickerIsoFormat;\r\n\r\n  /**\r\n   * Objeto com as literais usadas para os seguintes componentes: `po-lookup`, `po-multiselect`, `po-combo` e `po-datepicker-range`.\r\n   *\r\n   * > O objeto padrão de literais será traduzido de acordo com o idioma do PoI18nService ou do browser.\r\n   *\r\n   * **Componentes compatíveis:** `po-lookup`, `po-multiselect`, `po-combo`, `po-datepicker-range`\r\n   */\r\n  literals?: PoLookupLiterals | PoMultiselectLiterals | PoComboLiterals | PoDatepickerRangeLiterals;\r\n\r\n  /**\r\n   * Se verdadeiro ativa a funcionalidade de scroll infinito para o combo ou lookup, ao chegar ao fim da tabela executará nova busca dos dados conforme paginação.\r\n   *\r\n   * **Componentes compatíveis:** `po-combo`, `po-lookup`.\r\n   */\r\n  infiniteScroll?: boolean;\r\n\r\n  /**\r\n   * Define o percentual necessário para disparar o evento show-more, que é responsável por carregar mais dados no combo. Caso o valor seja maior que 100 ou menor que 0, o valor padrão será 100%.\r\n   * **Exemplos**\r\n   * `{ infiniteScrollDistance: 80 }`: Quando atingir 80% do scroll do combo, o show-more será disparado.\r\n   *\r\n   * **Componente compatível:** `po-combo`.\r\n   */\r\n  infiniteScrollDistance?: number;\r\n\r\n  /**\r\n   * Define que a altura do componente será auto ajustável, possuindo uma altura minima porém a altura máxima será de acordo com o número de itens selecionados e a extensão dos mesmos, mantendo-os sempre visíveis.\r\n   *\r\n   * **Componentes compatíveis:** `po-multiselect`, `po-lookup`.\r\n   */\r\n  autoHeight?: boolean;\r\n\r\n  /**\r\n   * Intervalo utilizado no `po-number`.\r\n   */\r\n  step?: number;\r\n\r\n  /**\r\n   * Define o modo de pesquisa utilizado no filtro da lista de seleção: `startsWith`, `contains` ou `endsWith`.\r\n   * > Quando utilizar a propriedade p-filter-service esta propriedade será ignorada.\r\n   *\r\n   * **Componentes compatíveis:** `po-multiselect`.\r\n   */\r\n  filterMode?: PoMultiselectFilterMode;\r\n\r\n  /**\r\n   * Valor mínimo de caracteres para realizar o filtro no serviço do `po-combo`.\r\n   */\r\n  filterMinlength?: number;\r\n\r\n  /**\r\n   * Desabilita o filtro inicial no serviço do `po-combo`, que é executado no primeiro clique no campo.\r\n   */\r\n  disabledInitFilter?: boolean;\r\n\r\n  /**\r\n   * Se verdadeiro, desabilitará a busca de um item via TAB no `po-combo`.\r\n   */\r\n  disabledTabFilter?: boolean;\r\n\r\n  /**\r\n   * Esta propriedade define em quanto tempo (em milissegundos), aguarda para acionar o evento de filtro após cada pressionamento de tecla. Será utilizada apenas quando houver serviço (`p-filter-service`).\r\n   *\r\n   * **Componentes compatíveis:** `po-combo`, `po-multiselect`.\r\n   */\r\n  debounceTime?: number;\r\n\r\n  /**\r\n   * Indica que o evento `p-change` só será disparado ao clicar ou pressionar a tecla \"Enter\" sobre uma opção selecionada no `po-combo`.\r\n   */\r\n  changeOnEnter?: boolean;\r\n\r\n  /**\r\n   * Indica que a lista definida na propriedade p-options será ordenada pela descrição.\r\n   *\r\n   * **Componentes compatíveis:** `po-combo`, po-multiselect\r\n   */\r\n  sort?: boolean;\r\n\r\n  /**\r\n   * Placeholder do campo de pesquisa do `po-multiselect`.\r\n   *\r\n   * > Caso o mesmo não seja informado, o valor padrão será traduzido com base no idioma do navegador (pt, es e en).\r\n   */\r\n  placeholderSearch?: string;\r\n\r\n  /**\r\n   * Esconde o campo de pesquisa existente dentro do dropdown do `po-multiselect`.\r\n   */\r\n  hideSearch?: boolean;\r\n\r\n  /**\r\n   * Indica se o campo \"Selecionar todos\" do `po-multiselect` será escondido.\r\n   */\r\n  hideSelectAll?: boolean;\r\n\r\n  /**\r\n   * Lista de objetos dos campos que serão criados na busca avançada.\r\n   *\r\n   * > Caso não seja passado um objeto ou então ele esteja em branco o link de busca avançada ficará escondido.\r\n   *\r\n   * Exemplo de URL com busca avançada:\r\n   *\r\n   * `url + ?page=1&pageSize=20&name=Tony%20Stark&nickname=Homem%20de%20Ferro`\r\n   *\r\n   * Caso algum parâmetro seja uma lista, a concatenação é feita utilizando vírgula. Exemplo:\r\n   *\r\n   * `url + ?page=1&pageSize=20&name=Tony%20Stark,Peter%20Parker,Gohan`\r\n   */\r\n  advancedFilters?: Array<PoLookupAdvancedFilter>;\r\n  /**\r\n   * pode ser utilizada em conjunto com a propriedade `options` forçando o componente a renderizar um `po-select` ou `po-radio-group`.\r\n   *\r\n   * Valores aceitos:\r\n   * - ForceOptionComponentEnum.radioGroup\r\n   * - ForceOptionComponentEnum.select\r\n   *\r\n   * >Essa propriedade será ignorada caso seja utilizada em conjunto com a propriedade `optionsMulti` e `optionsService`.\r\n   */\r\n  forceOptionsComponentType?: ForceOptionComponentEnum;\r\n}\r\n"]}
|
|
@@ -101,6 +101,11 @@ export class PoDynamicFormFieldsBaseComponent {
|
|
|
101
101
|
// recupera o componente de acordo com algumas regras do field.
|
|
102
102
|
getComponentControl(field = {}) {
|
|
103
103
|
const type = field && field.type ? field.type.toLocaleLowerCase() : 'string';
|
|
104
|
+
const forceOptionComponent = this.verifyforceOptionComponent(field);
|
|
105
|
+
if (forceOptionComponent) {
|
|
106
|
+
const { forceOptionsComponentType } = field;
|
|
107
|
+
return forceOptionsComponentType;
|
|
108
|
+
}
|
|
104
109
|
if (this.isNumberType(field, type)) {
|
|
105
110
|
return 'number';
|
|
106
111
|
}
|
|
@@ -184,6 +189,13 @@ export class PoDynamicFormFieldsBaseComponent {
|
|
|
184
189
|
const { optionsMulti, options } = field;
|
|
185
190
|
return !optionsMulti && !!options && options.length <= 3;
|
|
186
191
|
}
|
|
192
|
+
verifyforceOptionComponent(field) {
|
|
193
|
+
const { optionsMulti, optionsService, forceOptionsComponentType } = field;
|
|
194
|
+
if (forceOptionsComponentType && !optionsMulti && !optionsService) {
|
|
195
|
+
return true;
|
|
196
|
+
}
|
|
197
|
+
return false;
|
|
198
|
+
}
|
|
187
199
|
isSelect(field) {
|
|
188
200
|
const { optionsMulti, options } = field;
|
|
189
201
|
return !optionsMulti && !!options && options.length > 3;
|
|
@@ -197,7 +209,7 @@ export class PoDynamicFormFieldsBaseComponent {
|
|
|
197
209
|
}
|
|
198
210
|
}
|
|
199
211
|
PoDynamicFormFieldsBaseComponent.ɵfac = function PoDynamicFormFieldsBaseComponent_Factory(t) { return new (t || PoDynamicFormFieldsBaseComponent)(i0.ɵɵdirectiveInject(i1.TitleCasePipe)); };
|
|
200
|
-
PoDynamicFormFieldsBaseComponent.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: PoDynamicFormFieldsBaseComponent, inputs: { autoFocus: ["p-auto-focus", "autoFocus"], disabledForm: ["p-disabled-form", "disabledForm"], validate: ["p-validate", "validate"], fields: ["p-fields", "fields"], value: ["p-value", "value"], validateFields: ["p-validate-fields", "validateFields"] }, outputs: { formValidate: "p-form-validate", fieldsChange: "p-fieldsChange", objectValue: "p-object-value" } });
|
|
212
|
+
PoDynamicFormFieldsBaseComponent.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: PoDynamicFormFieldsBaseComponent, inputs: { autoFocus: ["p-auto-focus", "autoFocus"], disabledForm: ["p-disabled-form", "disabledForm"], validate: ["p-validate", "validate"], validateOnInput: ["p-validate-on-input", "validateOnInput"], fields: ["p-fields", "fields"], value: ["p-value", "value"], validateFields: ["p-validate-fields", "validateFields"] }, outputs: { formValidate: "p-form-validate", fieldsChange: "p-fieldsChange", objectValue: "p-object-value" } });
|
|
201
213
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoDynamicFormFieldsBaseComponent, [{
|
|
202
214
|
type: Directive
|
|
203
215
|
}], function () { return [{ type: i1.TitleCasePipe }]; }, { autoFocus: [{
|
|
@@ -218,6 +230,9 @@ PoDynamicFormFieldsBaseComponent.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({
|
|
|
218
230
|
}], objectValue: [{
|
|
219
231
|
type: Output,
|
|
220
232
|
args: ['p-object-value']
|
|
233
|
+
}], validateOnInput: [{
|
|
234
|
+
type: Input,
|
|
235
|
+
args: ['p-validate-on-input']
|
|
221
236
|
}], fields: [{
|
|
222
237
|
type: Input,
|
|
223
238
|
args: ['p-fields']
|
|
@@ -228,4 +243,4 @@ PoDynamicFormFieldsBaseComponent.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({
|
|
|
228
243
|
type: Input,
|
|
229
244
|
args: ['p-validate-fields']
|
|
230
245
|
}] }); })();
|
|
231
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-dynamic-form-fields-base.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ui/src/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-fields/po-dynamic-form-fields-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Input, EventEmitter, Output, Directive } from '@angular/core';\r\nimport { TitleCasePipe } from '@angular/common';\r\n\r\nimport { isTypeof, sortFields } from '../../../../utils/util';\r\n\r\nimport { getGridColumnsClasses, isVisibleField } from '../../po-dynamic.util';\r\nimport { PoDynamicFieldType } from '../../po-dynamic-field-type.enum';\r\nimport { PoDynamicFormField } from '../po-dynamic-form-field.interface';\r\nimport { PoDynamicFormFieldInternal } from './po-dynamic-form-field-internal.interface';\r\nimport { PoComboFilter } from '../../../po-field/po-combo/interfaces/po-combo-filter.interface';\r\nimport { PoLookupFilter } from '../../../po-field/po-lookup/interfaces/po-lookup-filter.interface';\r\n\r\n@Directive()\r\nexport class PoDynamicFormFieldsBaseComponent {\r\n  @Input('p-auto-focus') autoFocus?: string;\r\n\r\n  @Input('p-disabled-form') disabledForm: boolean;\r\n\r\n  @Input('p-validate') validate?: string | Function;\r\n\r\n  @Output('p-form-validate') formValidate = new EventEmitter<any>();\r\n\r\n  @Output('p-fieldsChange') fieldsChange = new EventEmitter<any>();\r\n\r\n  // Evento disparado se existir optionsService em visibleField. Necessário resgatar referência do objeto selecionado para quando se tratar de recebimento de opções via serviço.\r\n  @Output('p-object-value') objectValue = new EventEmitter<any>();\r\n\r\n  visibleFields: Array<PoDynamicFormFieldInternal> = [];\r\n\r\n  private _fields: Array<PoDynamicFormField>;\r\n  private _validateFields: Array<string>;\r\n  private _value?: any = {};\r\n\r\n  // array de objetos que implementam a interface PoDynamicFormField, que serão exibidos no componente.\r\n  @Input('p-fields') set fields(value: Array<PoDynamicFormField>) {\r\n    this._fields = Array.isArray(value) ? [...value] : [];\r\n  }\r\n\r\n  get fields() {\r\n    return this._fields;\r\n  }\r\n\r\n  // valor que será utilizado para iniciar valor no componente.\r\n  @Input('p-value') set value(value: any) {\r\n    this._value = value && isTypeof(value, 'object') ? value : {};\r\n  }\r\n\r\n  get value() {\r\n    return this._value;\r\n  }\r\n\r\n  @Input('p-validate-fields') set validateFields(value: Array<string>) {\r\n    this._validateFields = Array.isArray(value) ? [...value] : [];\r\n  }\r\n\r\n  get validateFields() {\r\n    return this._validateFields;\r\n  }\r\n\r\n  constructor(private titleCasePipe: TitleCasePipe) {}\r\n\r\n  compareTo(value, compareTo) {\r\n    return value === compareTo;\r\n  }\r\n\r\n  // retorna um array com os objetos configurados e visiveis.\r\n  protected getVisibleFields() {\r\n    const visibleFields = [];\r\n\r\n    this.fields.forEach(field => {\r\n      if (this.existsProperty(visibleFields, field.property)) {\r\n        this.printError(\r\n          `\"po-dynamic-form\" property \"${field.property}\" está duplicado. Interface: PoDynamicFormField.`\r\n        );\r\n        return;\r\n      }\r\n\r\n      if (!field['property']) {\r\n        this.printError('\"po-dynamic-form\" É obrigatório ser especificado um property.');\r\n        return;\r\n      }\r\n\r\n      if (isVisibleField(field)) {\r\n        visibleFields.push(this.createField(field));\r\n      }\r\n    });\r\n\r\n    return sortFields(visibleFields);\r\n  }\r\n\r\n  // converte um array em string para um array de objetos que contem label e value.\r\n  private convertOptions(options: Array<any>): Array<{ label: string; value: string }> {\r\n    const everyOptionString = options.every(option => typeof option === 'string');\r\n\r\n    if (everyOptionString) {\r\n      return options.map(value => ({ label: value, value }));\r\n    }\r\n\r\n    return options;\r\n  }\r\n\r\n  // cria um novo objeto com as classes de grid system, com control (tipo do componente) e label default.\r\n  private createField(field: PoDynamicFormField): PoDynamicFormFieldInternal {\r\n    const control = this.getComponentControl(field);\r\n    const options = !!field.options ? this.convertOptions(field.options) : undefined;\r\n    const focus = this.hasFocus(field);\r\n    const type = field && field.type ? field.type.toLocaleLowerCase() : 'string';\r\n\r\n    const componentClass = getGridColumnsClasses(\r\n      field.gridColumns,\r\n      field.offsetColumns,\r\n      {\r\n        smGrid: field.gridSmColumns,\r\n        mdGrid: field.gridMdColumns,\r\n        lgGrid: field.gridLgColumns,\r\n        xlGrid: field.gridXlColumns\r\n      },\r\n      {\r\n        smOffset: field.offsetSmColumns,\r\n        mdOffset: field.offsetMdColumns,\r\n        lgOffset: field.offsetLgColumns,\r\n        xlOffset: field.offsetXlColumns\r\n      },\r\n      {\r\n        smPull: field.gridSmPull,\r\n        mdPull: field.gridMdPull,\r\n        lgPull: field.gridLgPull,\r\n        xlPull: field.gridXlPull\r\n      }\r\n    );\r\n\r\n    return {\r\n      label: this.titleCasePipe.transform(field.property),\r\n      maskFormatModel: this.compareTo(type, PoDynamicFieldType.Time),\r\n      ...field,\r\n      componentClass,\r\n      control,\r\n      focus,\r\n      options\r\n    };\r\n  }\r\n\r\n  private existsProperty(fields: Array<PoDynamicFormField>, property: string) {\r\n    return fields.some(field => field.property === property);\r\n  }\r\n\r\n  // recupera o componente de acordo com algumas regras do field.\r\n  private getComponentControl(field: PoDynamicFormField = <any>{}) {\r\n    const type = field && field.type ? field.type.toLocaleLowerCase() : 'string';\r\n\r\n    if (this.isNumberType(field, type)) {\r\n      return 'number';\r\n    } else if (this.isCurrencyType(field, type)) {\r\n      return 'decimal';\r\n    } else if (this.isSelect(field)) {\r\n      return 'select';\r\n    } else if (this.isRadioGroup(field)) {\r\n      return 'radioGroup';\r\n    } else if (this.isCheckboxGroup(field)) {\r\n      return 'checkboxGroup';\r\n    } else if (this.isMultiselect(field)) {\r\n      return 'multiselect';\r\n    } else if (this.compareTo(type, PoDynamicFieldType.Boolean)) {\r\n      return 'switch';\r\n    } else if (this.compareTo(type, PoDynamicFieldType.Date) || this.compareTo(type, PoDynamicFieldType.DateTime)) {\r\n      return field.range ? 'datepickerrange' : 'datepicker';\r\n    } else if (this.compareTo(type, PoDynamicFieldType.Time)) {\r\n      field.mask = field.mask || '99:99';\r\n\r\n      return 'input';\r\n    } else if (this.isCombo(field)) {\r\n      return 'combo';\r\n    } else if (this.isLookup(field)) {\r\n      return 'lookup';\r\n    } else if (this.isTextarea(field)) {\r\n      return 'textarea';\r\n    } else if (this.isPassword(field)) {\r\n      return 'password';\r\n    }\r\n\r\n    return 'input';\r\n  }\r\n\r\n  private hasFocus(field: PoDynamicFormField) {\r\n    return !!this.autoFocus && this.autoFocus === field.property;\r\n  }\r\n\r\n  private isCheckboxGroup(field: PoDynamicFormField) {\r\n    const { optionsService, optionsMulti, options } = field;\r\n\r\n    return !optionsService && optionsMulti && !!options && options.length <= 3;\r\n  }\r\n\r\n  private isCombo(field: PoDynamicFormField) {\r\n    const { optionsService } = field;\r\n\r\n    return !!optionsService && (isTypeof(optionsService, 'string') || this.isComboFilter(optionsService));\r\n  }\r\n\r\n  private isCurrencyType(field: PoDynamicFormField, type: string) {\r\n    const { mask, pattern } = field;\r\n\r\n    return this.compareTo(type, PoDynamicFieldType.Currency) && !mask && !pattern;\r\n  }\r\n\r\n  private isLookupFilter(object: any): object is PoLookupFilter {\r\n    return object && (<PoLookupFilter>object).getObjectByValue !== undefined;\r\n  }\r\n\r\n  private isComboFilter(object: any): object is PoComboFilter {\r\n    return object && (<PoComboFilter>object).getFilteredData !== undefined;\r\n  }\r\n\r\n  private isLookup(field: PoDynamicFormField) {\r\n    const { searchService } = field;\r\n\r\n    return !!searchService && (isTypeof(searchService, 'string') || this.isLookupFilter(searchService));\r\n  }\r\n\r\n  private isMultiselect(field: PoDynamicFormField) {\r\n    const { optionsService, optionsMulti, options } = field;\r\n\r\n    return optionsMulti && (!!optionsService || (!!options && options.length > 3));\r\n  }\r\n\r\n  private isNumberType(field: PoDynamicFormField, type: string) {\r\n    const { mask, pattern } = field;\r\n\r\n    return this.compareTo(type, PoDynamicFieldType.Number) && !mask && !pattern;\r\n  }\r\n\r\n  private isPassword(field: PoDynamicFormField) {\r\n    const { secret } = field;\r\n\r\n    return secret;\r\n  }\r\n\r\n  private isRadioGroup(field: PoDynamicFormField) {\r\n    const { optionsMulti, options } = field;\r\n\r\n    return !optionsMulti && !!options && options.length <= 3;\r\n  }\r\n\r\n  private isSelect(field: PoDynamicFormField) {\r\n    const { optionsMulti, options } = field;\r\n\r\n    return !optionsMulti && !!options && options.length > 3;\r\n  }\r\n\r\n  private isTextarea(field: PoDynamicFormField) {\r\n    const { rows } = field;\r\n\r\n    return rows && rows >= 3;\r\n  }\r\n\r\n  private printError(error: string) {\r\n    console.error(error);\r\n  }\r\n}\r\n"]}
|
|
246
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-dynamic-form-fields-base.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ui/src/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-fields/po-dynamic-form-fields-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Input, EventEmitter, Output, Directive } from '@angular/core';\r\nimport { TitleCasePipe } from '@angular/common';\r\n\r\nimport { isTypeof, sortFields } from '../../../../utils/util';\r\n\r\nimport { getGridColumnsClasses, isVisibleField } from '../../po-dynamic.util';\r\nimport { PoDynamicFieldType } from '../../po-dynamic-field-type.enum';\r\nimport { PoDynamicFormField } from '../po-dynamic-form-field.interface';\r\nimport { PoDynamicFormFieldInternal } from './po-dynamic-form-field-internal.interface';\r\nimport { PoComboFilter } from '../../../po-field/po-combo/interfaces/po-combo-filter.interface';\r\nimport { PoLookupFilter } from '../../../po-field/po-lookup/interfaces/po-lookup-filter.interface';\r\n\r\n@Directive()\r\nexport class PoDynamicFormFieldsBaseComponent {\r\n  @Input('p-auto-focus') autoFocus?: string;\r\n\r\n  @Input('p-disabled-form') disabledForm: boolean;\r\n\r\n  @Input('p-validate') validate?: string | Function;\r\n\r\n  @Output('p-form-validate') formValidate = new EventEmitter<any>();\r\n\r\n  @Output('p-fieldsChange') fieldsChange = new EventEmitter<any>();\r\n\r\n  // Evento disparado se existir optionsService em visibleField. Necessário resgatar referência do objeto selecionado para quando se tratar de recebimento de opções via serviço.\r\n  @Output('p-object-value') objectValue = new EventEmitter<any>();\r\n\r\n  @Input('p-validate-on-input') validateOnInput: boolean;\r\n\r\n  visibleFields: Array<PoDynamicFormFieldInternal> = [];\r\n\r\n  private _fields: Array<PoDynamicFormField>;\r\n  private _validateFields: Array<string>;\r\n  private _value?: any = {};\r\n\r\n  // array de objetos que implementam a interface PoDynamicFormField, que serão exibidos no componente.\r\n  @Input('p-fields') set fields(value: Array<PoDynamicFormField>) {\r\n    this._fields = Array.isArray(value) ? [...value] : [];\r\n  }\r\n\r\n  get fields() {\r\n    return this._fields;\r\n  }\r\n\r\n  // valor que será utilizado para iniciar valor no componente.\r\n  @Input('p-value') set value(value: any) {\r\n    this._value = value && isTypeof(value, 'object') ? value : {};\r\n  }\r\n\r\n  get value() {\r\n    return this._value;\r\n  }\r\n\r\n  @Input('p-validate-fields') set validateFields(value: Array<string>) {\r\n    this._validateFields = Array.isArray(value) ? [...value] : [];\r\n  }\r\n\r\n  get validateFields() {\r\n    return this._validateFields;\r\n  }\r\n\r\n  constructor(private titleCasePipe: TitleCasePipe) {}\r\n\r\n  compareTo(value, compareTo) {\r\n    return value === compareTo;\r\n  }\r\n\r\n  // retorna um array com os objetos configurados e visiveis.\r\n  protected getVisibleFields() {\r\n    const visibleFields = [];\r\n\r\n    this.fields.forEach(field => {\r\n      if (this.existsProperty(visibleFields, field.property)) {\r\n        this.printError(\r\n          `\"po-dynamic-form\" property \"${field.property}\" está duplicado. Interface: PoDynamicFormField.`\r\n        );\r\n        return;\r\n      }\r\n\r\n      if (!field['property']) {\r\n        this.printError('\"po-dynamic-form\" É obrigatório ser especificado um property.');\r\n        return;\r\n      }\r\n\r\n      if (isVisibleField(field)) {\r\n        visibleFields.push(this.createField(field));\r\n      }\r\n    });\r\n\r\n    return sortFields(visibleFields);\r\n  }\r\n\r\n  // converte um array em string para um array de objetos que contem label e value.\r\n  private convertOptions(options: Array<any>): Array<{ label: string; value: string }> {\r\n    const everyOptionString = options.every(option => typeof option === 'string');\r\n\r\n    if (everyOptionString) {\r\n      return options.map(value => ({ label: value, value }));\r\n    }\r\n\r\n    return options;\r\n  }\r\n\r\n  // cria um novo objeto com as classes de grid system, com control (tipo do componente) e label default.\r\n  private createField(field: PoDynamicFormField): PoDynamicFormFieldInternal {\r\n    const control = this.getComponentControl(field);\r\n    const options = !!field.options ? this.convertOptions(field.options) : undefined;\r\n    const focus = this.hasFocus(field);\r\n    const type = field && field.type ? field.type.toLocaleLowerCase() : 'string';\r\n\r\n    const componentClass = getGridColumnsClasses(\r\n      field.gridColumns,\r\n      field.offsetColumns,\r\n      {\r\n        smGrid: field.gridSmColumns,\r\n        mdGrid: field.gridMdColumns,\r\n        lgGrid: field.gridLgColumns,\r\n        xlGrid: field.gridXlColumns\r\n      },\r\n      {\r\n        smOffset: field.offsetSmColumns,\r\n        mdOffset: field.offsetMdColumns,\r\n        lgOffset: field.offsetLgColumns,\r\n        xlOffset: field.offsetXlColumns\r\n      },\r\n      {\r\n        smPull: field.gridSmPull,\r\n        mdPull: field.gridMdPull,\r\n        lgPull: field.gridLgPull,\r\n        xlPull: field.gridXlPull\r\n      }\r\n    );\r\n\r\n    return {\r\n      label: this.titleCasePipe.transform(field.property),\r\n      maskFormatModel: this.compareTo(type, PoDynamicFieldType.Time),\r\n      ...field,\r\n      componentClass,\r\n      control,\r\n      focus,\r\n      options\r\n    };\r\n  }\r\n\r\n  private existsProperty(fields: Array<PoDynamicFormField>, property: string) {\r\n    return fields.some(field => field.property === property);\r\n  }\r\n\r\n  // recupera o componente de acordo com algumas regras do field.\r\n  private getComponentControl(field: PoDynamicFormField = <any>{}) {\r\n    const type = field && field.type ? field.type.toLocaleLowerCase() : 'string';\r\n\r\n    const forceOptionComponent = this.verifyforceOptionComponent(field);\r\n    if (forceOptionComponent) {\r\n      const { forceOptionsComponentType } = field;\r\n      return forceOptionsComponentType;\r\n    }\r\n\r\n    if (this.isNumberType(field, type)) {\r\n      return 'number';\r\n    } else if (this.isCurrencyType(field, type)) {\r\n      return 'decimal';\r\n    } else if (this.isSelect(field)) {\r\n      return 'select';\r\n    } else if (this.isRadioGroup(field)) {\r\n      return 'radioGroup';\r\n    } else if (this.isCheckboxGroup(field)) {\r\n      return 'checkboxGroup';\r\n    } else if (this.isMultiselect(field)) {\r\n      return 'multiselect';\r\n    } else if (this.compareTo(type, PoDynamicFieldType.Boolean)) {\r\n      return 'switch';\r\n    } else if (this.compareTo(type, PoDynamicFieldType.Date) || this.compareTo(type, PoDynamicFieldType.DateTime)) {\r\n      return field.range ? 'datepickerrange' : 'datepicker';\r\n    } else if (this.compareTo(type, PoDynamicFieldType.Time)) {\r\n      field.mask = field.mask || '99:99';\r\n\r\n      return 'input';\r\n    } else if (this.isCombo(field)) {\r\n      return 'combo';\r\n    } else if (this.isLookup(field)) {\r\n      return 'lookup';\r\n    } else if (this.isTextarea(field)) {\r\n      return 'textarea';\r\n    } else if (this.isPassword(field)) {\r\n      return 'password';\r\n    }\r\n\r\n    return 'input';\r\n  }\r\n\r\n  private hasFocus(field: PoDynamicFormField) {\r\n    return !!this.autoFocus && this.autoFocus === field.property;\r\n  }\r\n\r\n  private isCheckboxGroup(field: PoDynamicFormField) {\r\n    const { optionsService, optionsMulti, options } = field;\r\n\r\n    return !optionsService && optionsMulti && !!options && options.length <= 3;\r\n  }\r\n\r\n  private isCombo(field: PoDynamicFormField) {\r\n    const { optionsService } = field;\r\n\r\n    return !!optionsService && (isTypeof(optionsService, 'string') || this.isComboFilter(optionsService));\r\n  }\r\n\r\n  private isCurrencyType(field: PoDynamicFormField, type: string) {\r\n    const { mask, pattern } = field;\r\n\r\n    return this.compareTo(type, PoDynamicFieldType.Currency) && !mask && !pattern;\r\n  }\r\n\r\n  private isLookupFilter(object: any): object is PoLookupFilter {\r\n    return object && (<PoLookupFilter>object).getObjectByValue !== undefined;\r\n  }\r\n\r\n  private isComboFilter(object: any): object is PoComboFilter {\r\n    return object && (<PoComboFilter>object).getFilteredData !== undefined;\r\n  }\r\n\r\n  private isLookup(field: PoDynamicFormField) {\r\n    const { searchService } = field;\r\n\r\n    return !!searchService && (isTypeof(searchService, 'string') || this.isLookupFilter(searchService));\r\n  }\r\n\r\n  private isMultiselect(field: PoDynamicFormField) {\r\n    const { optionsService, optionsMulti, options } = field;\r\n\r\n    return optionsMulti && (!!optionsService || (!!options && options.length > 3));\r\n  }\r\n\r\n  private isNumberType(field: PoDynamicFormField, type: string) {\r\n    const { mask, pattern } = field;\r\n\r\n    return this.compareTo(type, PoDynamicFieldType.Number) && !mask && !pattern;\r\n  }\r\n\r\n  private isPassword(field: PoDynamicFormField) {\r\n    const { secret } = field;\r\n\r\n    return secret;\r\n  }\r\n\r\n  private isRadioGroup(field: PoDynamicFormField) {\r\n    const { optionsMulti, options } = field;\r\n\r\n    return !optionsMulti && !!options && options.length <= 3;\r\n  }\r\n\r\n  private verifyforceOptionComponent(field: PoDynamicFormField) {\r\n    const { optionsMulti, optionsService, forceOptionsComponentType } = field;\r\n\r\n    if (forceOptionsComponentType && !optionsMulti && !optionsService) {\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  private isSelect(field: PoDynamicFormField) {\r\n    const { optionsMulti, options } = field;\r\n\r\n    return !optionsMulti && !!options && options.length > 3;\r\n  }\r\n\r\n  private isTextarea(field: PoDynamicFormField) {\r\n    const { rows } = field;\r\n\r\n    return rows && rows >= 3;\r\n  }\r\n\r\n  private printError(error: string) {\r\n    console.error(error);\r\n  }\r\n}\r\n"]}
|