@po-ui/ng-components 17.26.16 → 17.26.17

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.
@@ -152,11 +152,8 @@ export class PoDynamicFormBaseComponent {
152
152
  * - `function`: Método que será executado.
153
153
  *
154
154
  * Ao ser executado, irá receber como parâmetro um objeto com o nome da propriedade
155
- * alterada e o novo valor, conforme a interface `PoDynamicFormFieldChanged`:
155
+ * alterada e os valores atualizados do formulário, conforme a interface `PoDynamicFormFieldChanged`
156
156
  *
157
- * ```
158
- * { property: 'property name', value: 'new value' }
159
- * ```
160
157
  *
161
158
  * O retorno desta função deve ser do tipo [PoDynamicFormValidation](documentation/po-dynamic-form#po-dynamic-form-validation),
162
159
  * onde o usuário poderá determinar as novas atualizações dos campos.
@@ -268,4 +265,4 @@ export class PoDynamicFormBaseComponent {
268
265
  type: Input,
269
266
  args: [{ alias: 'p-validate-on-input', transform: convertToBoolean }]
270
267
  }] }); })();
271
- //# 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,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvE,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;;AAIvD;;;;;;;GAOG;AAEH,MAAM,OAAO,0BAA0B;IACrC;;;;;;OAMG;IACoB,SAAS,CAAU;IAE1C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA6BG;IACgB,MAAM,CAA4B;IAErD;;;;;;;OAOG;IACe,KAAK,CAAM;IAE7B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAmDG;IACe,UAAU,GAAyB,IAAI,YAAY,EAAU,CAAC;IAEhF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA+BG;IACc,IAAI,CAAqB;IAE1C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAuCG;IACkB,QAAQ,CAAqB;IAElD;;;;;;OAMG;IACyB,cAAc,CAAiB;IAEnD,UAAU,GAAa,KAAK,CAAC;IAErC;;;;;;;;;;;;;;;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;IAED;;;;;;;;;;;;;;;;;OAiBG;IACmE,eAAe,GAAY,KAAK,CAAC;oFA3O5F,0BAA0B;6DAA1B,0BAA0B,whBA2Oa,gBAAgB;;iFA3OvD,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;YA0BiD,eAAe;kBAApF,KAAK;mBAAC,EAAE,KAAK,EAAE,qBAAqB,EAAE,SAAS,EAAE,gBAAgB,EAAE","sourcesContent":["import { Directive, EventEmitter, Input, Output } from '@angular/core';\nimport { NgForm } from '@angular/forms';\nimport { convertToBoolean } from '../../../utils/util';\n\nimport { PoDynamicFormField } from './po-dynamic-form-field.interface';\n\n/**\n *\n * @description\n *\n * Componente para criação de formulários dinâmicos a partir de uma lista de objetos.\n *\n * Também é possível verificar se o formulário está válido e informar valores para a exibição de informações.\n */\n@Directive()\nexport class PoDynamicFormBaseComponent {\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Nome da propriedade, atribuída ao `PoDynamicFormField.property`, que iniciará o campo com foco.\n   */\n  @Input('p-auto-focus') autoFocus?: string;\n\n  /**\n   * @description\n   *\n   * Coleção de objetos que implementam a interface `PoDynamicFormField`, para definição dos campos que serão criados\n   * dinamicamente.\n   *\n   * > Ex: `[ { property: 'name' } ]`\n   *\n   * Regras de tipagem e criação dos componentes:\n   *\n   * - Caso o *type* informado seja *boolean* o componente criado será o `po-switch`.\n   * - Caso o *type* informado seja *currency* e não seja informado um *mask* ou *pattern* o componente criado será o `po-decimal`,\n   * caso seja informado um *mask* ou *pattern* o componente criado será o `po-input`.\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\n   * informado um *mask* ou *pattern* o componente criado será o `po-input`.\n   * - Caso a lista possua a propriedade `options` e a mesma possua até 3 itens o componente criado será o `po-radio-group`\n   * ou `po-checkbox-group` se informar a propriedade `optionsMulti`.\n   * - Caso a mesma possua 3 ou mais itens, será criado o componente `po-select` ou, `po-multiselect` se a propriedade `optionsMulti`\n   * for verdadeira.\n   * - Caso o *type* informado seja *date* ou *datetime* o componente criado será o `po-datepicker`.\n   * - Caso seja informado a propriedade `optionsService` o componente criado será o `po-combo`.\n   * - Caso o *type* informado seja *time* o componente criado será um `po-input` podendo receber um *mask* para formatar\n   * o valor exibido, caso não seja informado um *mask* o componente será criado com a máscara '99:99' por padrão.\n   * - Caso a lista possua a propriedade `rows` e esta seja definida com valor maior ou igual a 3 o componente criado será\n   * o `po-textarea`, caso o valor da propriedade `rows` seja menor que 3 o componente criado será o `po-input`.\n   * - Caso seja informada a propriedade `secret` o componente criado será o `po-password`.\n   * - Caso o *type* informado seja *string* o componente criado será o `po-input`.\n   * > Ao alterar o valor das `properties`, visibilidade e/ou agrupamentos via container, os `fields` que utilizam serviço podem refazer as chamadas para as API's.\n   * @default `[]`\n   */\n  @Input('p-fields') fields: Array<PoDynamicFormField>;\n\n  /**\n   * Objeto que será utilizado como valor para exibir as informações, será recuperado e preenchido através do atributo *property*\n   * dos objetos contidos na propridade `p-fields`.\n   *\n   * Pode iniciar com valor ou apenas com um objeto vazio que será preenchido conforme descrito acima.\n   *\n   * > Ex: `{ name: 'po' }`\n   */\n  @Input('p-value') value: any;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Na inicialização do componente será repassado o objeto de formulário utilizado no componente,\n   * podendo ser utilizado para validações e/ou detecção de mudança dos valores.\n   *\n   * Portanto existem duas maneiras de recuperar o formulário,\n   * através de *template reference* e através do *output*, veja os exemplos abaixo:\n   *\n   * > *template reference*\n   *\n   * ```html\n   *  <po-dynamic-form #dynamicForm>\n   *  </po-dynamic-form>\n   *\n   *  <po-button p-label=\"Adicionar\" [p-disabled]=\"dynamicForm?.form.invalid\">\n   *  </po-button>\n   *\n   * ```\n   *\n   * > *Output*\n   *\n   * ```html\n   *  ...\n   *  <po-dynamic-form (p-form)=\"getForm($event)\">\n   *  </po-dynamic-form>\n   *\n   *  <po-button p-label=\"Adicionar\" [p-disabled]=\"dynamicForm?.invalid\">\n   *  </po-button>\n   *  ...\n   *\n   * ```\n   *\n   * ```ts\n   *  ...\n   *\n   *  export class AppComponent {\n   *\n   *    dynamicForm: NgForm;\n   *\n   *    getForm(form: NgForm) {\n   *      this.dynamicForm = form;\n   *    }\n   *\n   *  }\n   * ```\n   *\n   * > Caso a propriedade `p-group-form` for verdadeira não será repassado o formulário, pois o mesmo utilizará\n   * o formulário pai.\n   */\n  @Output('p-form') formOutput: EventEmitter<NgForm> = new EventEmitter<NgForm>();\n\n  /**\n   * Função ou serviço que será executado na inicialização do componente.\n   *\n   * A propriedade aceita os seguintes tipos:\n   * - `string`: *Endpoint* usado pelo componente para requisição via `POST`.\n   * - `function`: Método que será executado.\n   *\n   * Ao ser executado, irá receber como parâmetro o objeto informado no `p-value`.\n   *\n   * O retorno desta função deve ser do tipo [PoDynamicFormLoad](documentation/po-dynamic-form#po-dynamic-form-load),\n   * onde o usuário poderá determinar as novas atualizações dos campos, valores e determinar o campo a ser focado.\n   *\n   * Por exemplo:\n   *\n   * ```\n   * onLoadFields(): PoDynamicFormLoad {\n   *\n   *   return {\n   *     value: { cpf: undefined },\n   *     fields: [\n   *       { property: 'cpf' }\n   *     ],\n   *     focus: 'cpf'\n   *   };\n   * }\n   *\n   * ```\n   * Para referenciar a sua função utilize a propriedade `bind`, por exemplo:\n   * ```\n   *  [p-load]=\"onLoadFields.bind(this)\"\n   * ```\n   */\n  @Input('p-load') load?: string | Function;\n\n  /**\n   * Função ou serviço para validar as **mudanças do formulário**.\n   *\n   * A propriedade aceita os seguintes tipos:\n   * - `string`: *Endpoint* usado pelo componente para requisição via `POST`.\n   * - `function`: Método que será executado.\n   *\n   * Ao ser executado, irá receber como parâmetro um objeto com o nome da propriedade\n   * alterada e o novo valor, conforme a interface `PoDynamicFormFieldChanged`:\n   *\n   * ```\n   * { property: 'property name', value: 'new value' }\n   * ```\n   *\n   * O retorno desta função deve ser do tipo [PoDynamicFormValidation](documentation/po-dynamic-form#po-dynamic-form-validation),\n   * onde o usuário poderá determinar as novas atualizações dos campos.\n   * Por exemplo:\n   *\n   * ```\n   * onChangeFields(changeValue): PoDynamicFormValidation {\n   *\n   * if (changeValue.property === 'state') {\n   *\n   *   return {\n   *     value: { city: undefined },\n   *     fields: [\n   *       { property: 'city', options: this.getCity(changeValue.value.state) }\n   *     ],\n   *     focus: 'city'\n   *   };\n   * }\n   *\n   * ```\n   * Para referenciar a sua função utilize a propriedade `bind`, por exemplo:\n   * ```\n   *  [p-validate]=\"this.myFunction.bind(this)\"\n   * ```\n   *\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.\n   */\n  @Input('p-validate') validate?: string | Function;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Lista que define os campos que irão disparar o validate do form.\n   */\n  @Input('p-validate-fields') validateFields?: Array<string>;\n\n  private _groupForm?: boolean = false;\n\n  /**\n   * @optional\n   *\n   * @description\n   * Ao informar esta propriedade, o componente passará a utilizar o formulário pai para criar os `FormControl`\n   * e com isso é possível recuperar o valor do formulário e suas validações a partir do formulário pai.\n   *\n   * ```html\n   * <form #parentForm=\"ngForm\">\n   *\n   *   <po-dynamic-form p-group-form [p-fields]=\"fields\"></po-dynamic-form>\n   *\n   *  <po-button p-label=\"Adicionar\" [p-disabled]=\"parentForm.invalid\"></po-button>\n   * </form>\n   * ```\n   */\n  @Input('p-group-form') set groupForm(value: boolean) {\n    this._groupForm = <any>value === '' ? true : convertToBoolean(value);\n  }\n\n  get groupForm(): boolean {\n    return this._groupForm;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Ao informar esta propriedade, o componente passará a emitir o valor a cada caractere digitado.\n   *\n   * Pode ser aplicado nos seguintes componentes:\n   * - po-input\n   * - po-number\n   * - po-decimal\n   * - po-textarea\n   * - po-password\n   *\n   * Deve informar os campos que deseja receber as emissões na propriedade `p-validate-fields`.\n   *\n   *\n   */\n  @Input({ alias: 'p-validate-on-input', transform: convertToBoolean }) validateOnInput: boolean = false;\n}\n"]}
268
+ //# 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,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvE,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;;AAIvD;;;;;;;GAOG;AAEH,MAAM,OAAO,0BAA0B;IACrC;;;;;;OAMG;IACoB,SAAS,CAAU;IAE1C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA6BG;IACgB,MAAM,CAA4B;IAErD;;;;;;;OAOG;IACe,KAAK,CAAM;IAE7B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAmDG;IACe,UAAU,GAAyB,IAAI,YAAY,EAAU,CAAC;IAEhF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA+BG;IACc,IAAI,CAAqB;IAE1C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAoCG;IACkB,QAAQ,CAAqB;IAElD;;;;;;OAMG;IACyB,cAAc,CAAiB;IAEnD,UAAU,GAAa,KAAK,CAAC;IAErC;;;;;;;;;;;;;;;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;IAED;;;;;;;;;;;;;;;;;OAiBG;IACmE,eAAe,GAAY,KAAK,CAAC;oFAxO5F,0BAA0B;6DAA1B,0BAA0B,whBAwOa,gBAAgB;;iFAxOvD,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;YAuCM,QAAQ;kBAA5B,KAAK;mBAAC,YAAY;YASS,cAAc;kBAAzC,KAAK;mBAAC,mBAAmB;YAoBC,SAAS;kBAAnC,KAAK;mBAAC,cAAc;YA0BiD,eAAe;kBAApF,KAAK;mBAAC,EAAE,KAAK,EAAE,qBAAqB,EAAE,SAAS,EAAE,gBAAgB,EAAE","sourcesContent":["import { Directive, EventEmitter, Input, Output } from '@angular/core';\nimport { NgForm } from '@angular/forms';\nimport { convertToBoolean } from '../../../utils/util';\n\nimport { PoDynamicFormField } from './po-dynamic-form-field.interface';\n\n/**\n *\n * @description\n *\n * Componente para criação de formulários dinâmicos a partir de uma lista de objetos.\n *\n * Também é possível verificar se o formulário está válido e informar valores para a exibição de informações.\n */\n@Directive()\nexport class PoDynamicFormBaseComponent {\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Nome da propriedade, atribuída ao `PoDynamicFormField.property`, que iniciará o campo com foco.\n   */\n  @Input('p-auto-focus') autoFocus?: string;\n\n  /**\n   * @description\n   *\n   * Coleção de objetos que implementam a interface `PoDynamicFormField`, para definição dos campos que serão criados\n   * dinamicamente.\n   *\n   * > Ex: `[ { property: 'name' } ]`\n   *\n   * Regras de tipagem e criação dos componentes:\n   *\n   * - Caso o *type* informado seja *boolean* o componente criado será o `po-switch`.\n   * - Caso o *type* informado seja *currency* e não seja informado um *mask* ou *pattern* o componente criado será o `po-decimal`,\n   * caso seja informado um *mask* ou *pattern* o componente criado será o `po-input`.\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\n   * informado um *mask* ou *pattern* o componente criado será o `po-input`.\n   * - Caso a lista possua a propriedade `options` e a mesma possua até 3 itens o componente criado será o `po-radio-group`\n   * ou `po-checkbox-group` se informar a propriedade `optionsMulti`.\n   * - Caso a mesma possua 3 ou mais itens, será criado o componente `po-select` ou, `po-multiselect` se a propriedade `optionsMulti`\n   * for verdadeira.\n   * - Caso o *type* informado seja *date* ou *datetime* o componente criado será o `po-datepicker`.\n   * - Caso seja informado a propriedade `optionsService` o componente criado será o `po-combo`.\n   * - Caso o *type* informado seja *time* o componente criado será um `po-input` podendo receber um *mask* para formatar\n   * o valor exibido, caso não seja informado um *mask* o componente será criado com a máscara '99:99' por padrão.\n   * - Caso a lista possua a propriedade `rows` e esta seja definida com valor maior ou igual a 3 o componente criado será\n   * o `po-textarea`, caso o valor da propriedade `rows` seja menor que 3 o componente criado será o `po-input`.\n   * - Caso seja informada a propriedade `secret` o componente criado será o `po-password`.\n   * - Caso o *type* informado seja *string* o componente criado será o `po-input`.\n   * > Ao alterar o valor das `properties`, visibilidade e/ou agrupamentos via container, os `fields` que utilizam serviço podem refazer as chamadas para as API's.\n   * @default `[]`\n   */\n  @Input('p-fields') fields: Array<PoDynamicFormField>;\n\n  /**\n   * Objeto que será utilizado como valor para exibir as informações, será recuperado e preenchido através do atributo *property*\n   * dos objetos contidos na propridade `p-fields`.\n   *\n   * Pode iniciar com valor ou apenas com um objeto vazio que será preenchido conforme descrito acima.\n   *\n   * > Ex: `{ name: 'po' }`\n   */\n  @Input('p-value') value: any;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Na inicialização do componente será repassado o objeto de formulário utilizado no componente,\n   * podendo ser utilizado para validações e/ou detecção de mudança dos valores.\n   *\n   * Portanto existem duas maneiras de recuperar o formulário,\n   * através de *template reference* e através do *output*, veja os exemplos abaixo:\n   *\n   * > *template reference*\n   *\n   * ```html\n   *  <po-dynamic-form #dynamicForm>\n   *  </po-dynamic-form>\n   *\n   *  <po-button p-label=\"Adicionar\" [p-disabled]=\"dynamicForm?.form.invalid\">\n   *  </po-button>\n   *\n   * ```\n   *\n   * > *Output*\n   *\n   * ```html\n   *  ...\n   *  <po-dynamic-form (p-form)=\"getForm($event)\">\n   *  </po-dynamic-form>\n   *\n   *  <po-button p-label=\"Adicionar\" [p-disabled]=\"dynamicForm?.invalid\">\n   *  </po-button>\n   *  ...\n   *\n   * ```\n   *\n   * ```ts\n   *  ...\n   *\n   *  export class AppComponent {\n   *\n   *    dynamicForm: NgForm;\n   *\n   *    getForm(form: NgForm) {\n   *      this.dynamicForm = form;\n   *    }\n   *\n   *  }\n   * ```\n   *\n   * > Caso a propriedade `p-group-form` for verdadeira não será repassado o formulário, pois o mesmo utilizará\n   * o formulário pai.\n   */\n  @Output('p-form') formOutput: EventEmitter<NgForm> = new EventEmitter<NgForm>();\n\n  /**\n   * Função ou serviço que será executado na inicialização do componente.\n   *\n   * A propriedade aceita os seguintes tipos:\n   * - `string`: *Endpoint* usado pelo componente para requisição via `POST`.\n   * - `function`: Método que será executado.\n   *\n   * Ao ser executado, irá receber como parâmetro o objeto informado no `p-value`.\n   *\n   * O retorno desta função deve ser do tipo [PoDynamicFormLoad](documentation/po-dynamic-form#po-dynamic-form-load),\n   * onde o usuário poderá determinar as novas atualizações dos campos, valores e determinar o campo a ser focado.\n   *\n   * Por exemplo:\n   *\n   * ```\n   * onLoadFields(): PoDynamicFormLoad {\n   *\n   *   return {\n   *     value: { cpf: undefined },\n   *     fields: [\n   *       { property: 'cpf' }\n   *     ],\n   *     focus: 'cpf'\n   *   };\n   * }\n   *\n   * ```\n   * Para referenciar a sua função utilize a propriedade `bind`, por exemplo:\n   * ```\n   *  [p-load]=\"onLoadFields.bind(this)\"\n   * ```\n   */\n  @Input('p-load') load?: string | Function;\n\n  /**\n   * Função ou serviço para validar as **mudanças do formulário**.\n   *\n   * A propriedade aceita os seguintes tipos:\n   * - `string`: *Endpoint* usado pelo componente para requisição via `POST`.\n   * - `function`: Método que será executado.\n   *\n   * Ao ser executado, irá receber como parâmetro um objeto com o nome da propriedade\n   * alterada e os valores atualizados do formulário, conforme a interface `PoDynamicFormFieldChanged`\n   *\n   *\n   * O retorno desta função deve ser do tipo [PoDynamicFormValidation](documentation/po-dynamic-form#po-dynamic-form-validation),\n   * onde o usuário poderá determinar as novas atualizações dos campos.\n   * Por exemplo:\n   *\n   * ```\n   * onChangeFields(changeValue): PoDynamicFormValidation {\n   *\n   * if (changeValue.property === 'state') {\n   *\n   *   return {\n   *     value: { city: undefined },\n   *     fields: [\n   *       { property: 'city', options: this.getCity(changeValue.value.state) }\n   *     ],\n   *     focus: 'city'\n   *   };\n   * }\n   *\n   * ```\n   * Para referenciar a sua função utilize a propriedade `bind`, por exemplo:\n   * ```\n   *  [p-validate]=\"this.myFunction.bind(this)\"\n   * ```\n   *\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.\n   */\n  @Input('p-validate') validate?: string | Function;\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Lista que define os campos que irão disparar o validate do form.\n   */\n  @Input('p-validate-fields') validateFields?: Array<string>;\n\n  private _groupForm?: boolean = false;\n\n  /**\n   * @optional\n   *\n   * @description\n   * Ao informar esta propriedade, o componente passará a utilizar o formulário pai para criar os `FormControl`\n   * e com isso é possível recuperar o valor do formulário e suas validações a partir do formulário pai.\n   *\n   * ```html\n   * <form #parentForm=\"ngForm\">\n   *\n   *   <po-dynamic-form p-group-form [p-fields]=\"fields\"></po-dynamic-form>\n   *\n   *  <po-button p-label=\"Adicionar\" [p-disabled]=\"parentForm.invalid\"></po-button>\n   * </form>\n   * ```\n   */\n  @Input('p-group-form') set groupForm(value: boolean) {\n    this._groupForm = <any>value === '' ? true : convertToBoolean(value);\n  }\n\n  get groupForm(): boolean {\n    return this._groupForm;\n  }\n\n  /**\n   * @optional\n   *\n   * @description\n   *\n   * Ao informar esta propriedade, o componente passará a emitir o valor a cada caractere digitado.\n   *\n   * Pode ser aplicado nos seguintes componentes:\n   * - po-input\n   * - po-number\n   * - po-decimal\n   * - po-textarea\n   * - po-password\n   *\n   * Deve informar os campos que deseja receber as emissões na propriedade `p-validate-fields`.\n   *\n   *\n   */\n  @Input({ alias: 'p-validate-on-input', transform: convertToBoolean }) validateOnInput: boolean = false;\n}\n"]}
@@ -340,6 +340,9 @@ export class PoDynamicFormFieldsComponent extends PoDynamicFormFieldsBaseCompone
340
340
  this.setContainerFields();
341
341
  }
342
342
  }
343
+ if (changes.value) {
344
+ this.updatePreviousValue();
345
+ }
343
346
  }
344
347
  focus(property) {
345
348
  const foundComponent = this.components.find(component => component.name === property);
@@ -577,4 +580,4 @@ export class PoDynamicFormFieldsComponent extends PoDynamicFormFieldsBaseCompone
577
580
  args: ['component']
578
581
  }] }); })();
579
582
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PoDynamicFormFieldsComponent, { className: "PoDynamicFormFieldsComponent", filePath: "lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-fields/po-dynamic-form-fields.component.ts", lineNumber: 23 }); })();
580
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-dynamic-form-fields.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ui/src/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-fields/po-dynamic-form-fields.component.ts","../../../../../../../../projects/ui/src/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-fields/po-dynamic-form-fields.component.html"],"names":[],"mappings":"AACA,OAAO,EAAqB,SAAS,EAAuC,YAAY,EAAE,MAAM,eAAe,CAAC;AAChH,OAAO,EAAE,gBAAgB,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AAI1D,OAAO,EAAE,8BAA8B,EAAE,MAAM,kEAAkE,CAAC;AAClH,OAAO,EAAE,gCAAgC,EAAE,MAAM,yCAAyC,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;ICNzF,wBAKgB;;;;IANlB,8BAAyG;IACvG,qGAKgB;IAClB,iBAAM;;;;;IAPc,kDAAkC;IAEjD,cAEQ;IAFR,mEAEQ,6HAAA;;;IAOT,iCAAoG;;;IAAxC,0CAAyB;;;;IAErF,6CAwBC;IApBC,+aAAmC;IAkBnC,+QAAY,eAAA,+BAAoB,CAAA,IAAC;IAGnC,iBAAgB;;;;IAtBd,wCAAuB;IACvB,gEAAmC;IACnC,iDAAgC,2BAAA,4CAAA,0CAAA,gCAAA,6BAAA,yBAAA,oCAAA,2BAAA,6BAAA,iCAAA,iCAAA,8CAAA,iCAAA,iCAAA,iCAAA,0CAAA,uCAAA;;;;IAsBlC,mDAoBC;IAhBC,2bAAmC;IAenC,2RAAY,eAAA,+BAAoB,CAAA,IAAC;IAEnC,iBAAsB;;;;IAlBpB,wCAAuB;IACvB,gEAAmC;IACnC,iDAAgC,2BAAA,4CAAA,gCAAA,yBAAA,2BAAA,iCAAA,iCAAA,iCAAA,8CAAA,iCAAA,iCAAA,iCAAA,0CAAA;;;;IAkBlC,wCA0BC;IAtBC,qaAAmC;IAiBnC,qQAAY,eAAA,+BAAoB,CAAA,IAAC,oQACf,eAAA,oCAAyB,CAAA,IADV;IAMnC,iBAAW;;;;IAxBT,wCAAuB;IACvB,gEAAmC;IACnC,iDAAgC,2BAAA,4CAAA,0CAAA,gCAAA,yBAAA,2BAAA,iDAAA,yBAAA,mCAAA,mCAAA,8CAAA,iCAAA,+BAAA,iCAAA,0CAAA,yBAAA,uCAAA,iCAAA;;;;IAwBlC,yCA0BC;IAtBC,uaAAmC;IAkBnC,uQAAY,eAAA,+BAAoB,CAAA,IAAC,sQACf,eAAA,oCAAyB,CAAA,IADV;IAKnC,iBAAY;;;;IAxBV,wCAAuB;IACvB,gEAAmC;IACnC,iDAAgC,2BAAA,4CAAA,0CAAA,gCAAA,yBAAA,2BAAA,4BAAA,4BAAA,mCAAA,mCAAA,8CAAA,iCAAA,yBAAA,iCAAA,iCAAA,0CAAA,yBAAA,uCAAA;;;;IAwBlC,0CA4BC;IAxBC,yaAAmC;IAqBnC,yQAAY,eAAA,+BAAoB,CAAA,IAAC,wQACf,eAAA,oCAAyB,CAAA,IADV;IAInC,iBAAa;;;;IA1BX,wCAAuB;IACvB,gEAAmC;IACnC,iDAAgC,2BAAA,0CAAA,4CAAA,8CAAA,oDAAA,yBAAA,gCAAA,yBAAA,2BAAA,6BAAA,4BAAA,4BAAA,mCAAA,mCAAA,8CAAA,iCAAA,iCAAA,iCAAA,0CAAA,uCAAA;;;;IA0BlC,yCAkBC;IAdC,uaAAmC;IAWnC,uQAAY,eAAA,+BAAoB,CAAA,IAAC;IAInC,iBAAY;;;;IAhBV,wCAAuB;IACvB,gEAAmC;IACnC,iDAAgC,sCAAA,sCAAA,4CAAA,yBAAA,2BAAA,iCAAA,+BAAA,iCAAA,0CAAA,uCAAA,iCAAA;;;;IAgBlC,8CAgBC;IAZC,ibAAmC;IAWnC,iRAAY,eAAA,+BAAoB,CAAA,IAAC;IAEnC,iBAAiB;;;;IAdf,wCAAuB;IACvB,gEAAmC;IACnC,iDAAgC,oCAAA,gCAAA,4CAAA,yBAAA,2BAAA,iCAAA,+BAAA,iCAAA,0CAAA;;;;IAclC,yCAeC;IAXC,uaAAmC;IAUnC,uQAAY,eAAA,+BAAoB,CAAA,IAAC;IAEnC,iBAAY;;;;IAbV,wCAAuB;IACvB,gEAAmC;IACnC,iDAAgC,4CAAA,wCAAA,yBAAA,2BAAA,sCAAA,oCAAA,4CAAA,iDAAA;;;;IAalC,2CAWC;IAPC,4aAAmC;IAMnC,4QAAY,eAAA,+BAAoB,CAAA,IAAC;IAEnC,iBAAc;;;;IATZ,wCAAuB;IACvB,gEAAmC;IACnC,iDAAgC,gCAAA,4CAAA,2BAAA,yBAAA;;;;IASlC,wCAiCC;IA7BC,saAAmC;IAoBnC,6QAAY,eAAA,wCAA4B,CAAA,IAAC;IAU3C,iBAAW;;;;IA/BT,wCAAuB;IACvB,gEAAmC;IACnC,iDAAgC,gCAAA,2BAAA,4CAAA,sCAAA,sCAAA,oCAAA,6CAAA,yBAAA,8CAAA,sEAAA,2BAAA,iCAAA,+BAAA,iCAAA,yBAAA,iCAAA,0CAAA,yBAAA,uCAAA,gDAAA,sCAAA,uDAAA,qDAAA,0CAAA,6CAAA;;;;IA+BlC,yCAgCC;IA5BC,4aAAmC;IAuBnC,0QAAY,eAAA,gCAAoB,CAAA,IAAC,2TAGL,qCAAoC,KAH/B,2TAIL,qCAAoC,KAJ/B;IAMnC,iBAAY;;;;IA9BV,wCAAuB;IACvB,gEAAmC;IAGnC,iDAAgC,2BAAA,+BAAA,4CAAA,iDAAA,iDAAA,oCAAA,4CAAA,gCAAA,sCAAA,yBAAA,mCAAA,8CAAA,2BAAA,iCAAA,iCAAA,8CAAA,iCAAA,iCAAA,0CAAA,uCAAA,gDAAA;;;;IA4BlC,iDAgBC;IAZC,4bAAmC;IAWnC,0RAAY,eAAA,gCAAoB,CAAA,IAAC;IAEnC,iBAAoB;;;;IAdlB,wCAAuB;IACvB,gEAAmC;IACnC,iDAAgC,oCAAA,gCAAA,4CAAA,yBAAA,2BAAA,iCAAA,+BAAA,iCAAA,0CAAA;;;;IAclC,8CA2BC;IAvBC,sbAAmC;IAYnC,oRAAY,eAAA,gCAAoB,CAAA,IAAC;IAYnC,iBAAiB;;;;IAzBf,wCAAuB;IACvB,gEAAmC;IACnC,iDAAgC,4CAAA,gCAAA,sCAAA,yBAAA,2BAAA,iCAAA,iCAAA,+BAAA,iCAAA,0CAAA,uCAAA,sCAAA,sCAAA,6CAAA,sCAAA,0CAAA,yBAAA,oDAAA,sCAAA,6CAAA;;;;IAyBlC,2CAoBC;IAhBC,gbAAmC;IAanC,8QAAY,eAAA,gCAAoB,CAAA,IAAC,6QACf,eAAA,qCAAyB,CAAA,IADV;IAInC,iBAAc;;;;IAlBZ,wCAAuB;IACvB,gEAAmC;IACnC,iDAAgC,4CAAA,gCAAA,yBAAA,2BAAA,mCAAA,mCAAA,iCAAA,iCAAA,iCAAA,0CAAA,yBAAA,uCAAA;;;;IAkBlC,2CAyBC;IArBC,gbAAmC;IAkBnC,8QAAY,eAAA,gCAAoB,CAAA,IAAC,6QACf,eAAA,qCAAyB,CAAA,IADV;IAInC,iBAAc;;;;IAvBZ,wCAAuB;IACvB,gEAAmC;IACnC,iDAAgC,2BAAA,4CAAA,0CAAA,gCAAA,yBAAA,mDAAA,yBAAA,2BAAA,mCAAA,mCAAA,8CAAA,iCAAA,+BAAA,iCAAA,iCAAA,0CAAA,uCAAA;;;;IAuBlC,yCA8BC;IA3BC,4aAAmC;IAkBnC,wOAAW,eAAA,wBAAqB,CAAA,IAAC,+NACpB,eAAA,0BAAuB,CAAA,IADH,6NAErB,eAAA,yBAAsB,CAAA,IAFD,6PAMrB,eAAA,gCAAoB,CAAA,IANC,yQAOf,eAAA,qCAAyB,CAAA,IAPV;IAUnC,iBAAY;;;;IA5BV,gEAAmC;IACnC,iDAAgC,sCAAA,mCAAA,4CAAA,kCAAA,+CAAA,yCAAA,oCAAA,+BAAA,yBAAA,2DAAA,mDAAA,+CAAA,iCAAA,2BAAA,iCAAA,2BAAA,iCAAA,iCAAA,0CAAA,uBAAA;;;IArYpC,6BAA6D;IAC3D,wHAAoG,kHAAA,8HAAA,wGAAA,2GAAA,6GAAA,2GAAA,qHAAA,2GAAA,gHAAA,2GAAA,6GAAA,6HAAA,uHAAA,iHAAA,iHAAA,6GAAA;IAgatG,0BAAe;;;;IAhaA,cAA4B;IAA5B,0GAA4B;IAItC,cAA4C;IAA5C,uEAA4C;IA2B5C,cAAiD;IAAjD,4EAAiD;IAuBjD,cAAuC;IAAvC,kEAAuC;IA6BvC,cAAwC;IAAxC,mEAAwC;IA6BxC,cAAyC;IAAzC,oEAAyC;IA+BzC,cAAwC;IAAxC,mEAAwC;IAqBxC,cAA4C;IAA5C,uEAA4C;IAmB5C,cAAwC;IAAxC,mEAAwC;IAkBxC,cAA0C;IAA1C,qEAA0C;IAc1C,cAAuC;IAAvC,kEAAuC;IAoCvC,cAAwC;IAAxC,mEAAwC;IAmCxC,cAA+C;IAA/C,0EAA+C;IAmB/C,cAA6C;IAA7C,wEAA6C;IA8B7C,cAA0C;IAA1C,qEAA0C;IAuB1C,cAA0C;IAA1C,qEAA0C;IA4B1C,cAAwC;IAAxC,mEAAwC;;;IAnY7C,+GAiae;;;;IAjaiB,mCAAW,gCAAA;;;IAqa3C,2CAAyF;;;;;IAAnE,sCAAmB,kBAAA;;ADta3C;;;;;;GAMG;AAOH,MAAM,OAAO,4BAA6B,SAAQ,gCAAgC;IAOtE;IACA;IACA;IARiB,UAAU,CAAiD;IAE9E,aAAa,GAAG,EAAE,CAAC;IAE3B,YACE,aAA4B,EACpB,iBAAiD,EACjD,OAA0B,EAC1B,IAAY;QAEpB,KAAK,CAAC,aAAa,CAAC,CAAC;QAJb,sBAAiB,GAAjB,iBAAiB,CAAgC;QACjD,YAAO,GAAP,OAAO,CAAmB;QAC1B,SAAI,GAAJ,IAAI,CAAQ;IAGtB,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,MAAM,EAAE;YAClB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAE7C,IAAI,OAAO,CAAC,MAAM,CAAC,aAAa,IAAI,IAAI,CAAC,YAAY,EAAE,EAAE;gBACvD,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,MAAM,CAAC,aAAa,EAAE,OAAO,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;aACpF;YAED,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,aAAa,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,YAAY,EAAE;gBACjE,IAAI,CAAC,kBAAkB,EAAE,CAAC;aAC3B;SACF;IACH,CAAC;IAED,KAAK,CAAC,QAAgB;QACpB,MAAM,cAAc,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC;QACtF,IAAI,cAAc,EAAE;YAClB,cAAc,CAAC,KAAK,EAAE,CAAC;SACxB;IACH,CAAC;IAED,UAAU,CAAC,KAAyB;QAClC,OAAO,KAAK,CAAC,QAAQ,IAAI,IAAI,CAAC,YAAY,CAAC;IAC7C,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,YAAgC,EAAE,WAAiB;QACrE,MAAM,EAAE,QAAQ,EAAE,GAAG,YAAY,CAAC;QAClC,MAAM,aAAa,GAAG,YAAY,CAAC,IAAI,KAAK,SAAS,CAAC;QACtD,MAAM,mBAAmB,GAAG,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QAElF,IAAI,YAAY,CAAC,cAAc,EAAE;YAC/B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SACpC;QAED,uFAAuF;QACvF,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,aAAa,CAAC,IAAI,mBAAmB,EAAE;YAC7D,MAAM,EAAE,YAAY,EAAE,iBAAiB,EAAE,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;YAEpE,IAAI,YAAY,CAAC,QAAQ,EAAE;gBACzB,MAAM,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,iBAAiB,EAAE,YAAY,CAAC,CAAC;aACzE;YAED,IAAI,CAAC,uBAAuB,CAAC,iBAAiB,CAAC,CAAC;SACjD;QAED,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAED,kDAAkD;IAClD,kBAAkB,CAAC,YAAgC;QACjD,IAAI,IAAI,CAAC,eAAe,EAAE;YACxB,MAAM,EAAE,QAAQ,EAAE,GAAG,YAAY,CAAC;YAClC,MAAM,EAAE,iBAAiB,EAAE,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;YACtD,IAAI,CAAC,uBAAuB,CAAC,iBAAiB,CAAC,CAAC;SACjD;IACH,CAAC;IAED,mBAAmB;QACjB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;IAC9D,CAAC;IAED,OAAO,CAAC,KAAK;QACX,OAAO,KAAK,CAAC;IACf,CAAC;IAEO,oBAAoB,CAAC,KAAa,EAAE,cAA4C;QACtF,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QAEjC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,EAAE,GAAG,KAAK,EAAE,GAAG,cAAc,CAAC,KAAK,EAAE,CAAC;QAC3D,IAAI,CAAC,YAAY,EAAE,CAAC;QAEpB,IAAI,cAAc,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE;YAC1C,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,cAAc,CAAC,KAAK,CAAC;SACnD;QAED,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,CAAC;QAE7B,IAAI,cAAc,CAAC,KAAK,EAAE;YACxB,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;SAC5B;IACH,CAAC;IAEO,QAAQ,CAAC,QAAgB;QAC/B,MAAM,iBAAiB,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,KAAK,QAAQ,CAAC,CAAC;QACtF,MAAM,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAEpD,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,CAAC;IAC7C,CAAC;IAEO,uBAAuB,CAAC,iBAAyB;QACvD,MAAM,kBAAkB,GAAG,IAAI,CAAC,cAAc,EAAE,MAAM;YACpD,CAAC,CAAC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC,QAAQ,CAAC;YAC1F,CAAC,CAAC,IAAI,CAAC;QACT,MAAM,iBAAiB,GAAG,IAAI,CAAC,QAAQ,IAAI,kBAAkB,IAAI,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,MAAM,CAAC;QAEpG,IAAI,iBAAiB,EAAE;YACrB,MAAM,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC;YACpD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;SACtC;IACH,CAAC;IAEO,YAAY;QAClB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACpC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC7C,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAEO,qBAAqB,CAAC,cAA6B,EAAE,aAA6C;QACxG,OAAO,cAAc,CAAC,IAAI,CAAC,iBAAiB,CAAC,EAAE,CAAC,iBAAiB,KAAK,aAAa,CAAC,CAAC;IACvF,CAAC;IAEO,KAAK,CAAC,aAAa,CAAC,KAAyB,EAAE,UAAkB,EAAE,YAAgC;QACzG,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QAEzC,MAAM,gBAAgB,GAAG,YAAY,CAAC,QAAQ,CAAC;QAC/C,YAAY,CAAC,QAAQ,GAAG,IAAI,CAAC;QAC7B,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,CAAC;QAE7B,IAAI;YACF,MAAM,cAAc,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,SAAS,EAAE,CAAC;YAC9F,IAAI,CAAC,oBAAoB,CAAC,UAAU,EAAE,cAAc,CAAC,CAAC;SACvD;QAAC,MAAM;YACN,YAAY,CAAC,QAAQ,GAAG,gBAAgB,CAAC;SAC1C;IACH,CAAC;IAEO,kBAAkB,CAAC,QAAmC,EAAE,OAAkC;QAChG,MAAM,SAAS,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;YAC/C,SAAS,EAAE,IAAI,CAAC,SAAS,IAAI,IAAI;YACjC,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,KAAK;YACL,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,OAAO,EAAE,IAAI,CAAC,OAAO,IAAI,IAAI;SAC9B,CAAC,CAAC,CAAC;QAEJ,MAAM,SAAS,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;YAC9C,SAAS,EAAE,IAAI,CAAC,SAAS,IAAI,IAAI;YACjC,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,KAAK;YACL,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,OAAO,EAAE,IAAI,CAAC,OAAO,IAAI,IAAI;SAC9B,CAAC,CAAC,CAAC;QAEJ,MAAM,cAAc,GAAG,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAChE,MAAM,cAAc,GAAG,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAEhE,MAAM,SAAS,GAAG,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACvD,MAAM,SAAS,GAAG,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAEvD,MAAM,eAAe,GAAG,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,KAAK,IAAI,CAAC,CAAC;QACxE,MAAM,eAAe,GAAG,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,KAAK,IAAI,CAAC,CAAC;QAExE,MAAM,gBAAgB,GAAG,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACjE,MAAM,gBAAgB,GAAG,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAEjE,+CAA+C;QAC/C,IAAI,cAAc,CAAC,MAAM,KAAK,cAAc,CAAC,MAAM,EAAE;YACnD,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC1B,OAAO;SACR;QAED,0CAA0C;QAC1C,IAAI,SAAS,CAAC,MAAM,KAAK,SAAS,CAAC,MAAM,EAAE;YACzC,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC1B,OAAO;SACR;QAED,4CAA4C;QAC5C,IAAI,eAAe,CAAC,MAAM,KAAK,eAAe,CAAC,MAAM,EAAE;YACrD,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC1B,OAAO;SACR;QAED,4CAA4C;QAC5C,IAAI,gBAAgB,CAAC,MAAM,KAAK,gBAAgB,CAAC,MAAM,EAAE;YACvD,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC1B,OAAO;SACR;QAED,IAAI,cAAc,CAAC,MAAM,EAAE;YACzB,IAAI,CAAC,sBAAsB,CAAC,cAAc,EAAE,cAAc,EAAE,WAAW,CAAC,CAAC;SAC1E;QAED,IAAI,SAAS,CAAC,MAAM,EAAE;YACpB,IAAI,CAAC,sBAAsB,CAAC,SAAS,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;SAC5D;QAED,IAAI,eAAe,CAAC,MAAM,EAAE;YAC1B,IAAI,CAAC,sBAAsB,CAAC,eAAe,EAAE,eAAe,EAAE,SAAS,CAAC,CAAC;SAC1E;QAED,IAAI,gBAAgB,CAAC,MAAM,EAAE;YAC3B,IAAI,CAAC,sBAAsB,CAAC,gBAAgB,EAAE,gBAAgB,EAAE,SAAS,CAAC,CAAC;SAC5E;QAED,0DAA0D;QAC1D,MAAM,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC;QACxE,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,oBAAoB,CAAC,MAAM,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;IACjF,CAAC;IAEO,oBAAoB,CAAC,OAAO,EAAE,eAAe;QACnD,MAAM,UAAU,GAAG,IAAI,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;QAEpE,eAAe,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE;YACjC,QAAQ,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,KAAK,EAAE,EAAE;gBAClC,MAAM,IAAI,GAAQ,UAAU,CAAC,GAAG,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;gBACnD,IAAI,IAAI,EAAE;oBACR,QAAQ,CAAC,KAAK,CAAC,GAAG,EAAE,GAAG,OAAO,EAAE,GAAG,IAAI,EAAE,CAAC;iBAC3C;YACH,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,OAAO,eAAe,CAAC;IACzB,CAAC;IAEO,gBAAgB,CAAC,QAAQ,EAAE,QAAQ;QACzC,MAAM,WAAW,GAAG,EAAE,CAAC;QAEvB,QAAQ,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YACxB,MAAM,MAAM,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,MAAM,CAAC,QAAQ,CAAC,CAAC;YAElE,IAAI,CAAC,MAAM,EAAE;gBACX,0EAA0E;gBAC1E,WAAW,CAAC,IAAI,CAAC,EAAE,GAAG,MAAM,EAAE,CAAC,CAAC;aACjC;iBAAM;gBACL,8CAA8C;gBAC9C,MAAM,IAAI,GAAG,EAAE,QAAQ,EAAE,MAAM,CAAC,QAAQ,EAAE,CAAC;gBAC3C,IAAI,cAAc,GAAG,KAAK,CAAC;gBAE3B,KAAK,MAAM,GAAG,IAAI,MAAM,EAAE;oBACxB,IAAI,MAAM,CAAC,GAAG,CAAC,KAAK,MAAM,CAAC,GAAG,CAAC,EAAE;wBAC/B,IAAI,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC;wBACxB,cAAc,GAAG,IAAI,CAAC;qBACvB;iBACF;gBAED,IAAI,cAAc,EAAE;oBAClB,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;iBACxB;aACF;QACH,CAAC,CAAC,CAAC;QAEH,iEAAiE;QACjE,OAAO,WAAW,CAAC;IACrB,CAAC;IAEO,YAAY;QAClB,OAAO,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;IACjF,CAAC;IAEO,sBAAsB,CAAC,cAAc,EAAE,cAAc,EAAE,GAAG;QAChE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,cAAc,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAC9C,MAAM,IAAI,GAAG,cAAc,CAAC,CAAC,CAAC,CAAC;YAC/B,MAAM,IAAI,GAAG,cAAc,CAAC,CAAC,CAAC,CAAC;YAE/B,wCAAwC;YACxC,IAAI,IAAI,CAAC,GAAG,CAAC,KAAK,IAAI,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,EAAE;gBACxD,IAAI,CAAC,kBAAkB,EAAE,CAAC;gBAC1B,OAAO;aACR;YACD,iFAAiF;YACjF,IAAI,IAAI,CAAC,GAAG,CAAC,KAAK,IAAI,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,EAAE;gBACxD,IAAI,GAAG,KAAK,OAAO,EAAE;oBACnB,IAAI,CAAC,kBAAkB,EAAE,CAAC;oBAC1B,OAAO;iBACR;gBACD,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CACrC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;oBACrB,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ,EAAE;wBACnC,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;qBACvB;gBACH,CAAC,CAAC,CACH,CAAC;aACH;YACD,oFAAoF;YACpF,IAAI,IAAI,CAAC,GAAG,CAAC,KAAK,IAAI,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ,EAAE;gBAC9D,IAAI,CAAC,kBAAkB,EAAE,CAAC;gBAC1B,OAAO;aACR;SACF;IACH,CAAC;sFAtSU,4BAA4B;6DAA5B,4BAA4B;;;;;8CAF5B,CAAC,8BAA8B,CAAC,EAD5B,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAE,WAAW,EAAE,MAAM,EAAE,CAAC;YCnBrE,6EAOM,iHAAA,iHAAA;;YAPkD,wEAA+C;;;iFDsB1F,4BAA4B;cANxC,SAAS;2BACE,wBAAwB,iBAEnB,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAE,WAAW,EAAE,MAAM,EAAE,CAAC,aACxD,CAAC,8BAA8B,CAAC;gJAGhB,UAAU;kBAApC,YAAY;mBAAC,WAAW;;kFADd,4BAA4B","sourcesContent":["import { TitleCasePipe } from '@angular/common';\nimport { ChangeDetectorRef, Component, OnChanges, QueryList, SimpleChanges, ViewChildren } from '@angular/core';\nimport { ControlContainer, NgForm } from '@angular/forms';\n\nimport { PoDynamicFormField } from '../po-dynamic-form-field.interface';\nimport { PoDynamicFormFieldValidation } from '../po-dynamic-form-validation/po-dynamic-form-field-validation.interface';\nimport { PoDynamicFormValidationService } from '../po-dynamic-form-validation/po-dynamic-form-validation.service';\nimport { PoDynamicFormFieldsBaseComponent } from './po-dynamic-form-fields-base.component';\n\n/**\n * @docsPrivate\n *\n * @description\n *\n * Componente de criação dos campos dinâmicos.\n */\n@Component({\n  selector: 'po-dynamic-form-fields',\n  templateUrl: 'po-dynamic-form-fields.component.html',\n  viewProviders: [{ provide: ControlContainer, useExisting: NgForm }],\n  providers: [PoDynamicFormValidationService]\n})\nexport class PoDynamicFormFieldsComponent extends PoDynamicFormFieldsBaseComponent implements OnChanges {\n  @ViewChildren('component') components: QueryList<{ name: string; focus: () => void }>;\n\n  private previousValue = {};\n\n  constructor(\n    titleCasePipe: TitleCasePipe,\n    private validationService: PoDynamicFormValidationService,\n    private changes: ChangeDetectorRef,\n    private form: NgForm\n  ) {\n    super(titleCasePipe);\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.fields) {\n      this.visibleFields = this.getVisibleFields();\n\n      if (changes.fields.previousValue && this.hasContainer()) {\n        this.hasChangeContainer(changes.fields.previousValue, changes.fields.currentValue);\n      }\n\n      if (!changes.fields.previousValue || !changes.fields.currentValue) {\n        this.setContainerFields();\n      }\n    }\n  }\n\n  focus(property: string) {\n    const foundComponent = this.components.find(component => component.name === property);\n    if (foundComponent) {\n      foundComponent.focus();\n    }\n  }\n\n  isDisabled(field: PoDynamicFormField): boolean {\n    return field.disabled || this.disabledForm;\n  }\n\n  async onChangeField(visibleField: PoDynamicFormField, objectValue?: any) {\n    const { property } = visibleField;\n    const isBooleanType = visibleField.type === 'boolean';\n    const isChangedValueField = this.previousValue[property] !== this.value[property];\n\n    if (visibleField.optionsService) {\n      this.objectValue.emit(objectValue);\n    }\n\n    // verifica se o formulario esta dirty para não disparar o validate ao carregar a tela.\n    if ((this.form.dirty || isBooleanType) && isChangedValueField) {\n      const { changedField, changedFieldIndex } = this.getField(property);\n\n      if (changedField.validate) {\n        await this.validateField(changedField, changedFieldIndex, visibleField);\n      }\n\n      this.triggerValidationOnForm(changedFieldIndex);\n    }\n\n    this.updatePreviousValue();\n  }\n\n  //emite o valor a cada caractere digitado no input\n  onChangeFieldModel(visibleField: PoDynamicFormField) {\n    if (this.validateOnInput) {\n      const { property } = visibleField;\n      const { changedFieldIndex } = this.getField(property);\n      this.triggerValidationOnForm(changedFieldIndex);\n    }\n  }\n\n  updatePreviousValue() {\n    this.previousValue = JSON.parse(JSON.stringify(this.value));\n  }\n\n  trackBy(index) {\n    return index;\n  }\n\n  private applyFieldValidation(index: number, validatedField: PoDynamicFormFieldValidation) {\n    const field = this.fields[index];\n\n    this.fields[index] = { ...field, ...validatedField.field };\n    this.updateFields();\n\n    if (validatedField.hasOwnProperty('value')) {\n      this.value[field.property] = validatedField.value;\n    }\n\n    this.changes.detectChanges();\n\n    if (validatedField.focus) {\n      this.focus(field.property);\n    }\n  }\n\n  private getField(property: string) {\n    const changedFieldIndex = this.fields.findIndex(field => field.property === property);\n    const changedField = this.fields[changedFieldIndex];\n\n    return { changedField, changedFieldIndex };\n  }\n\n  private triggerValidationOnForm(changedFieldIndex: number) {\n    const isValidatableField = this.validateFields?.length\n      ? this.validateFieldsChecker(this.validateFields, this.fields[changedFieldIndex].property)\n      : true;\n    const hasValidationForm = this.validate && isValidatableField && this.formValidate.observers.length;\n\n    if (hasValidationForm) {\n      const updatedField = this.fields[changedFieldIndex];\n      this.formValidate.emit(updatedField);\n    }\n  }\n\n  private updateFields() {\n    this.fieldsChange.emit(this.fields);\n    this.visibleFields = this.getVisibleFields();\n    this.setContainerFields();\n  }\n\n  private validateFieldsChecker(validateFields: Array<string>, propertyField: PoDynamicFormField['property']): boolean {\n    return validateFields.some(validateFieldItem => validateFieldItem === propertyField);\n  }\n\n  private async validateField(field: PoDynamicFormField, fieldIndex: number, visibleField: PoDynamicFormField) {\n    const value = this.value[field.property];\n\n    const previousDisabled = visibleField.disabled;\n    visibleField.disabled = true;\n    this.changes.detectChanges();\n\n    try {\n      const validatedField = await this.validationService.sendFieldChange(field, value).toPromise();\n      this.applyFieldValidation(fieldIndex, validatedField);\n    } catch {\n      visibleField.disabled = previousDisabled;\n    }\n  }\n\n  private hasChangeContainer(previous: Array<PoDynamicFormField>, current: Array<PoDynamicFormField>): void {\n    const prevArray = previous.map((item, index) => ({\n      container: item.container || null,\n      property: item.property,\n      index,\n      order: item.order,\n      visible: item.visible ?? true\n    }));\n\n    const currArray = current.map((item, index) => ({\n      container: item.container || null,\n      property: item.property,\n      index,\n      order: item.order,\n      visible: item.visible ?? true\n    }));\n\n    const prevContainers = prevArray.filter(item => item.container);\n    const currContainers = currArray.filter(item => item.container);\n\n    const prevOrder = prevArray.filter(item => item.order);\n    const currOrder = currArray.filter(item => item.order);\n\n    const prevVisibleTrue = prevArray.filter(item => item.visible === true);\n    const currVisibleTrue = currArray.filter(item => item.visible === true);\n\n    const prevVisibleFalse = prevArray.filter(item => !item.visible);\n    const currVisibleFalse = currArray.filter(item => !item.visible);\n\n    // Verifica mudança na quantidade de containers\n    if (prevContainers.length !== currContainers.length) {\n      this.setContainerFields();\n      return;\n    }\n\n    // Verifica mudança na quantidade de order\n    if (prevOrder.length !== currOrder.length) {\n      this.setContainerFields();\n      return;\n    }\n\n    // Verifica mudança na quantidade de visible\n    if (prevVisibleTrue.length !== currVisibleTrue.length) {\n      this.setContainerFields();\n      return;\n    }\n\n    // Verifica mudança na quantidade de visible\n    if (prevVisibleFalse.length !== currVisibleFalse.length) {\n      this.setContainerFields();\n      return;\n    }\n\n    if (currContainers.length) {\n      this.handleChangesContainer(prevContainers, currContainers, 'container');\n    }\n\n    if (currOrder.length) {\n      this.handleChangesContainer(prevOrder, currOrder, 'order');\n    }\n\n    if (currVisibleTrue.length) {\n      this.handleChangesContainer(prevVisibleTrue, currVisibleTrue, 'visible');\n    }\n\n    if (currVisibleFalse.length) {\n      this.handleChangesContainer(prevVisibleFalse, currVisibleFalse, 'visible');\n    }\n\n    //atualiza container sem mudança na estrutura da interface\n    const result = this.diffObjectsArray(previous, this.getVisibleFields());\n    this.containerFields = this.updateFieldContainer(result, this.containerFields);\n  }\n\n  private updateFieldContainer(changes, containerFields) {\n    const mapchanges = new Map(changes.map(obj => [obj.property, obj]));\n\n    containerFields.forEach(subArray => {\n      subArray.forEach((subItem, index) => {\n        const item: any = mapchanges.get(subItem.property);\n        if (item) {\n          subArray[index] = { ...subItem, ...item };\n        }\n      });\n    });\n\n    return containerFields;\n  }\n\n  private diffObjectsArray(oldArray, newArray) {\n    const differences = [];\n\n    newArray.forEach(newObj => {\n      const oldObj = oldArray.find(o => o.property === newObj.property);\n\n      if (!oldObj) {\n        // Se o objeto é novo, adiciona todo o objeto com a propriedade \"property\"\n        differences.push({ ...newObj });\n      } else {\n        // Verificar se há diferenças nas propriedades\n        const diff = { property: newObj.property };\n        let hasDifferences = false;\n\n        for (const key in newObj) {\n          if (newObj[key] !== oldObj[key]) {\n            diff[key] = newObj[key];\n            hasDifferences = true;\n          }\n        }\n\n        if (hasDifferences) {\n          differences.push(diff);\n        }\n      }\n    });\n\n    //retorna mudanças nos fields para atualização do containerFields\n    return differences;\n  }\n\n  private hasContainer() {\n    return this.visibleFields && this.visibleFields.some(field => field.container);\n  }\n\n  private handleChangesContainer(prevContainers, currContainers, key) {\n    for (let i = 0; i < prevContainers.length; i++) {\n      const prev = prevContainers[i];\n      const curr = currContainers[i];\n\n      //Verifica se container mudou de posição\n      if (prev[key] === curr[key] && prev.index !== curr.index) {\n        this.setContainerFields();\n        return;\n      }\n      //Verifica se foi apenas mudança da string em caso do container ou valor no order\n      if (prev[key] !== curr[key] && prev.index === curr.index) {\n        if (key === 'order') {\n          this.setContainerFields();\n          return;\n        }\n        this.containerFields.forEach(subItem =>\n          subItem.forEach(item => {\n            if (item.property === curr.property) {\n              item[key] = curr[key];\n            }\n          })\n        );\n      }\n      //verifica se manteve o mesmo número de container, mas alterou property do container\n      if (prev[key] !== curr[key] && prev.property !== curr.property) {\n        this.setContainerFields();\n        return;\n      }\n    }\n  }\n}\n","<div class=\"po-row\" [class.po-dynamic]=\"hasContainers\" *ngIf=\"visibleFields && visibleFields.length > 0\">\n  <ng-container\n    *ngTemplateOutlet=\"\n      hasContainers ? poContentContainer : poContent;\n      context: { $implicit: hasContainers ? containerFields : visibleFields }\n    \"\n  ></ng-container>\n</div>\n\n<ng-template #poContent let-fields>\n  <ng-container *ngFor=\"let field of fields; trackBy: trackBy\">\n    <po-divider *ngIf=\"field?.divider?.trim()\" class=\"po-sm-12\" [p-label]=\"field.divider\"> </po-divider>\n\n    <po-datepicker\n      #component\n      *ngIf=\"compareTo(field.control, 'datepicker')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-clean]=\"field.clean\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-error-pattern]=\"field.errorMessage\"\n      [p-auto-focus]=\"field.focus\"\n      [p-format]=\"field.format\"\n      [p-help]=\"field.help\"\n      [p-iso-format]=\"field.isoFormat\"\n      [p-label]=\"field.label\"\n      [p-locale]=\"field.locale\"\n      [p-max-date]=\"field.maxValue\"\n      [p-min-date]=\"field.minValue\"\n      [p-no-autocomplete]=\"field.noAutocomplete\"\n      [p-optional]=\"field.optional\"\n      [p-readonly]=\"field.readonly\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      (p-change)=\"onChangeField(field)\"\n      [p-placeholder]=\"field.placeholder\"\n    >\n    </po-datepicker>\n\n    <po-datepicker-range\n      #component\n      *ngIf=\"compareTo(field.control, 'datepickerrange')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-clean]=\"field.clean\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-auto-focus]=\"field.focus\"\n      [p-help]=\"field.help\"\n      [p-label]=\"field.label\"\n      [p-literals]=\"field.literals\"\n      [p-max-date]=\"field.maxValue\"\n      [p-min-date]=\"field.minValue\"\n      [p-no-autocomplete]=\"field.noAutocomplete\"\n      [p-optional]=\"field.optional\"\n      [p-readonly]=\"field.readonly\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      (p-change)=\"onChangeField(field)\"\n    >\n    </po-datepicker-range>\n\n    <po-input\n      #component\n      *ngIf=\"compareTo(field.control, 'input')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-clean]=\"field.clean\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-error-pattern]=\"field.errorMessage\"\n      [p-auto-focus]=\"field.focus\"\n      [p-help]=\"field.help\"\n      [p-label]=\"field.label\"\n      [p-mask-format-model]=\"field.maskFormatModel\"\n      [p-mask]=\"field.mask\"\n      [p-maxlength]=\"field.maxLength\"\n      [p-minlength]=\"field.minLength\"\n      [p-no-autocomplete]=\"field.noAutocomplete\"\n      [p-optional]=\"field.optional\"\n      [p-pattern]=\"field.pattern\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      (p-change)=\"onChangeField(field)\"\n      (p-change-model)=\"onChangeFieldModel(field)\"\n      [p-icon]=\"field.icon\"\n      [p-placeholder]=\"field.placeholder\"\n      [p-readonly]=\"field.readonly\"\n    >\n    </po-input>\n\n    <po-number\n      #component\n      *ngIf=\"compareTo(field.control, 'number')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-clean]=\"field.clean\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-error-pattern]=\"field.errorMessage\"\n      [p-auto-focus]=\"field.focus\"\n      [p-help]=\"field.help\"\n      [p-label]=\"field.label\"\n      [p-min]=\"field.minValue\"\n      [p-max]=\"field.maxValue\"\n      [p-maxlength]=\"field.maxLength\"\n      [p-minlength]=\"field.minLength\"\n      [p-no-autocomplete]=\"field.noAutocomplete\"\n      [p-optional]=\"field.optional\"\n      [p-step]=\"field.step\"\n      [p-readonly]=\"field.readonly\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      (p-change)=\"onChangeField(field)\"\n      (p-change-model)=\"onChangeFieldModel(field)\"\n      [p-icon]=\"field.icon\"\n      [p-placeholder]=\"field.placeholder\"\n    >\n    </po-number>\n\n    <po-decimal\n      #component\n      *ngIf=\"compareTo(field.control, 'decimal')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-clean]=\"field.clean\"\n      [p-error-pattern]=\"field.errorMessage\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-decimals-length]=\"field.decimalsLength\"\n      [p-thousand-maxlength]=\"field.thousandMaxlength\"\n      [p-icon]=\"field.icon\"\n      [p-auto-focus]=\"field.focus\"\n      [p-help]=\"field.help\"\n      [p-label]=\"field.label\"\n      [p-locale]=\"field.locale\"\n      [p-min]=\"field.minValue\"\n      [p-max]=\"field.maxValue\"\n      [p-maxlength]=\"field.maxLength\"\n      [p-minlength]=\"field.minLength\"\n      [p-no-autocomplete]=\"field.noAutocomplete\"\n      [p-optional]=\"field.optional\"\n      [p-readonly]=\"field.readonly\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      (p-change)=\"onChangeField(field)\"\n      (p-change-model)=\"onChangeFieldModel(field)\"\n      [p-placeholder]=\"field.placeholder\"\n    >\n    </po-decimal>\n\n    <po-select\n      #component\n      *ngIf=\"compareTo(field.control, 'select')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-field-label]=\"field.fieldLabel\"\n      [p-field-value]=\"field.fieldValue\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-help]=\"field.help\"\n      [p-label]=\"field.label\"\n      [p-optional]=\"field.optional\"\n      [p-options]=\"field.options\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      (p-change)=\"onChangeField(field)\"\n      [p-placeholder]=\"field.placeholder\"\n      [p-readonly]=\"field.readonly\"\n    >\n    </po-select>\n\n    <po-radio-group\n      #component\n      *ngIf=\"compareTo(field.control, 'radioGroup')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-columns]=\"field.columns || 3\"\n      [p-auto-focus]=\"field.focus\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-help]=\"field.help\"\n      [p-label]=\"field.label\"\n      [p-optional]=\"field.optional\"\n      [p-options]=\"field.options\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      (p-change)=\"onChangeField(field)\"\n    >\n    </po-radio-group>\n\n    <po-switch\n      #component\n      *ngIf=\"compareTo(field.control, 'switch')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-format-model]=\"field.formatModel\"\n      [p-help]=\"field.help\"\n      [p-label]=\"field.label\"\n      [p-label-off]=\"field.booleanFalse\"\n      [p-label-on]=\"field.booleanTrue\"\n      [p-label-position]=\"field.labelPosition\"\n      [p-hide-label-status]=\"field.hideLabelStatus\"\n      (p-change)=\"onChangeField(field)\"\n    >\n    </po-switch>\n\n    <po-checkbox\n      #component\n      *ngIf=\"compareTo(field.control, 'checkbox')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-auto-focus]=\"field.focus\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-label]=\"field.label\"\n      [p-size]=\"field.size\"\n      (p-change)=\"onChangeField(field)\"\n    >\n    </po-checkbox>\n\n    <po-combo\n      #component\n      *ngIf=\"compareTo(field.control, 'combo')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      p-emit-object-value\n      [p-auto-focus]=\"field.focus\"\n      [p-clean]=\"field.clean\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-field-label]=\"field.fieldLabel\"\n      [p-field-value]=\"field.fieldValue\"\n      [p-filter-params]=\"field.params\"\n      [p-filter-service]=\"field.optionsService\"\n      [p-help]=\"field.help\"\n      [p-infinite-scroll]=\"field.infiniteScroll\"\n      [p-infinite-scroll-distance]=\"field.infiniteScrollDistance || 100\"\n      [p-label]=\"field.label\"\n      [p-literals]=\"field.literals\"\n      [p-options]=\"field.options\"\n      [p-optional]=\"field.optional\"\n      [p-sort]=\"field.sort\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      (p-change)=\"onChangeField(field, $event)\"\n      [p-icon]=\"field.icon\"\n      [p-placeholder]=\"field.placeholder\"\n      [p-filter-minlength]=\"field.filterMinlength\"\n      [p-filter-mode]=\"field.filterMode\"\n      [p-disabled-init-filter]=\"field.disabledInitFilter\"\n      [p-disabled-tab-filter]=\"field.disabledTabFilter\"\n      [p-debounce-time]=\"field.debounceTime\"\n      [p-change-on-enter]=\"field.changeOnEnter\"\n    >\n    </po-combo>\n\n    <po-lookup\n      #component\n      *ngIf=\"compareTo(field.control, 'lookup')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      p-field-label=\"label\"\n      p-field-value=\"value\"\n      [ngClass]=\"field.componentClass\"\n      [p-clean]=\"field.clean\"\n      [p-columns]=\"field.columns\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-field-label]=\"field.fieldLabel || 'label'\"\n      [p-field-value]=\"field.fieldValue || 'value'\"\n      [p-filter-params]=\"field.params\"\n      [p-filter-service]=\"field.searchService\"\n      [p-auto-focus]=\"field.focus\"\n      [p-auto-height]=\"field.autoHeight\"\n      [p-help]=\"field.help\"\n      [p-field-format]=\"field.format\"\n      [p-infinite-scroll]=\"field.infiniteScroll\"\n      [p-label]=\"field.label\"\n      [p-literals]=\"field.literals\"\n      [p-multiple]=\"field.multiple\"\n      [p-no-autocomplete]=\"field.noAutocomplete\"\n      [p-optional]=\"field.optional\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      (p-change)=\"onChangeField(field)\"\n      [p-placeholder]=\"field.placeholder\"\n      [p-advanced-filters]=\"field.advancedFilters\"\n      (p-change-visible-columns)=\"field.changeVisibleColumns?.($event)\"\n      (p-restore-column-manager)=\"field.columnRestoreManager?.($event)\"\n    >\n    </po-lookup>\n\n    <po-checkbox-group\n      #component\n      *ngIf=\"compareTo(field.control, 'checkboxGroup')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-columns]=\"field.columns || 3\"\n      [p-auto-focus]=\"field.focus\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-help]=\"field.help\"\n      [p-label]=\"field.label\"\n      [p-optional]=\"field.optional\"\n      [p-options]=\"field.options\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      (p-change)=\"onChangeField(field)\"\n    >\n    </po-checkbox-group>\n\n    <po-multiselect\n      #component\n      *ngIf=\"compareTo(field.control, 'multiselect')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-auto-focus]=\"field.focus\"\n      [p-auto-height]=\"field.autoHeight\"\n      [p-help]=\"field.help\"\n      [p-label]=\"field.label\"\n      [p-literals]=\"field.literals\"\n      [p-optional]=\"field.optional\"\n      [p-options]=\"field.options\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      (p-change)=\"onChangeField(field)\"\n      [p-placeholder]=\"field.placeholder\"\n      [p-field-label]=\"field.fieldLabel\"\n      [p-field-value]=\"field.fieldValue\"\n      [p-filter-service]=\"field.optionsService\"\n      [p-filter-mode]=\"field.filterMode\"\n      [p-debounce-time]=\"field.debounceTime\"\n      [p-sort]=\"field.sort\"\n      [p-placeholder-search]=\"field.placeholderSearch\"\n      [p-hide-search]=\"field.hideSearch\"\n      [p-hide-select-all]=\"field.hideSelectAll\"\n    >\n    </po-multiselect>\n\n    <po-textarea\n      #component\n      *ngIf=\"compareTo(field.control, 'textarea')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-auto-focus]=\"field.focus\"\n      [p-help]=\"field.help\"\n      [p-label]=\"field.label\"\n      [p-maxlength]=\"field.maxLength\"\n      [p-minlength]=\"field.minLength\"\n      [p-optional]=\"field.optional\"\n      [p-readonly]=\"field.readonly\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      [p-rows]=\"field.rows\"\n      (p-change)=\"onChangeField(field)\"\n      (p-change-model)=\"onChangeFieldModel(field)\"\n      [p-placeholder]=\"field.placeholder\"\n    >\n    </po-textarea>\n\n    <po-password\n      #component\n      *ngIf=\"compareTo(field.control, 'password')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-clean]=\"field.clean\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-error-pattern]=\"field.errorMessage\"\n      [p-auto-focus]=\"field.focus\"\n      [p-help]=\"field.help\"\n      [p-hide-password-peek]=\"field.hidePasswordPeek\"\n      [p-icon]=\"field.icon\"\n      [p-label]=\"field.label\"\n      [p-maxlength]=\"field.maxLength\"\n      [p-minlength]=\"field.minLength\"\n      [p-no-autocomplete]=\"field.noAutocomplete\"\n      [p-optional]=\"field.optional\"\n      [p-pattern]=\"field.pattern\"\n      [p-readonly]=\"field.readonly\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      (p-change)=\"onChangeField(field)\"\n      (p-change-model)=\"onChangeFieldModel(field)\"\n      [p-placeholder]=\"field.placeholder\"\n    >\n    </po-password>\n\n    <po-upload\n      #component\n      *ngIf=\"compareTo(field.control, 'upload')\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-auto-upload]=\"field.autoUpload\"\n      [p-directory]=\"field.directory\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-drag-drop]=\"field.dragDrop\"\n      [p-drag-drop-height]=\"field.dragDropHeight\"\n      [p-restrictions]=\"field.restrictions\"\n      [p-form-field]=\"field.formField\"\n      [p-headers]=\"field.headers\"\n      [p-help]=\"field.help\"\n      [p-hide-restrictions-info]=\"field.hideRestrictionsInfo\"\n      [p-hide-select-button]=\"field.hideSelectButton\"\n      [p-hide-send-button]=\"field.hideSendButton\"\n      [p-multiple]=\"field.multiple\"\n      [p-label]=\"field.label\"\n      [p-literals]=\"field.literals\"\n      [name]=\"field.property\"\n      (p-error)=\"field.onError($event)\"\n      (p-success)=\"field.onSuccess($event)\"\n      (p-upload)=\"field.onUpload($event)\"\n      [p-optional]=\"field.optional\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      (p-change)=\"onChangeField(field)\"\n      (p-change-model)=\"onChangeFieldModel(field)\"\n      [p-url]=\"field.url\"\n    >\n    </po-upload>\n  </ng-container>\n</ng-template>\n\n<ng-template #poContentContainer let-fields>\n  <po-dynamic-container [p-fields]=\"fields\" [p-content]=\"poContent\"></po-dynamic-container>\n</ng-template>\n"]}
583
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-dynamic-form-fields.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ui/src/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-fields/po-dynamic-form-fields.component.ts","../../../../../../../../projects/ui/src/lib/components/po-dynamic/po-dynamic-form/po-dynamic-form-fields/po-dynamic-form-fields.component.html"],"names":[],"mappings":"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","sourcesContent":["import { TitleCasePipe } from '@angular/common';\nimport { ChangeDetectorRef, Component, OnChanges, QueryList, SimpleChanges, ViewChildren } from '@angular/core';\nimport { ControlContainer, NgForm } from '@angular/forms';\n\nimport { PoDynamicFormField } from '../po-dynamic-form-field.interface';\nimport { PoDynamicFormFieldValidation } from '../po-dynamic-form-validation/po-dynamic-form-field-validation.interface';\nimport { PoDynamicFormValidationService } from '../po-dynamic-form-validation/po-dynamic-form-validation.service';\nimport { PoDynamicFormFieldsBaseComponent } from './po-dynamic-form-fields-base.component';\n\n/**\n * @docsPrivate\n *\n * @description\n *\n * Componente de criação dos campos dinâmicos.\n */\n@Component({\n  selector: 'po-dynamic-form-fields',\n  templateUrl: 'po-dynamic-form-fields.component.html',\n  viewProviders: [{ provide: ControlContainer, useExisting: NgForm }],\n  providers: [PoDynamicFormValidationService]\n})\nexport class PoDynamicFormFieldsComponent extends PoDynamicFormFieldsBaseComponent implements OnChanges {\n  @ViewChildren('component') components: QueryList<{ name: string; focus: () => void }>;\n\n  private previousValue = {};\n\n  constructor(\n    titleCasePipe: TitleCasePipe,\n    private validationService: PoDynamicFormValidationService,\n    private changes: ChangeDetectorRef,\n    private form: NgForm\n  ) {\n    super(titleCasePipe);\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.fields) {\n      this.visibleFields = this.getVisibleFields();\n\n      if (changes.fields.previousValue && this.hasContainer()) {\n        this.hasChangeContainer(changes.fields.previousValue, changes.fields.currentValue);\n      }\n\n      if (!changes.fields.previousValue || !changes.fields.currentValue) {\n        this.setContainerFields();\n      }\n    }\n\n    if (changes.value) {\n      this.updatePreviousValue();\n    }\n  }\n\n  focus(property: string) {\n    const foundComponent = this.components.find(component => component.name === property);\n    if (foundComponent) {\n      foundComponent.focus();\n    }\n  }\n\n  isDisabled(field: PoDynamicFormField): boolean {\n    return field.disabled || this.disabledForm;\n  }\n\n  async onChangeField(visibleField: PoDynamicFormField, objectValue?: any) {\n    const { property } = visibleField;\n    const isBooleanType = visibleField.type === 'boolean';\n    const isChangedValueField = this.previousValue[property] !== this.value[property];\n\n    if (visibleField.optionsService) {\n      this.objectValue.emit(objectValue);\n    }\n\n    // verifica se o formulario esta dirty para não disparar o validate ao carregar a tela.\n    if ((this.form.dirty || isBooleanType) && isChangedValueField) {\n      const { changedField, changedFieldIndex } = this.getField(property);\n\n      if (changedField.validate) {\n        await this.validateField(changedField, changedFieldIndex, visibleField);\n      }\n\n      this.triggerValidationOnForm(changedFieldIndex);\n    }\n\n    this.updatePreviousValue();\n  }\n\n  //emite o valor a cada caractere digitado no input\n  onChangeFieldModel(visibleField: PoDynamicFormField) {\n    if (this.validateOnInput) {\n      const { property } = visibleField;\n      const { changedFieldIndex } = this.getField(property);\n      this.triggerValidationOnForm(changedFieldIndex);\n    }\n  }\n\n  updatePreviousValue() {\n    this.previousValue = JSON.parse(JSON.stringify(this.value));\n  }\n\n  trackBy(index) {\n    return index;\n  }\n\n  private applyFieldValidation(index: number, validatedField: PoDynamicFormFieldValidation) {\n    const field = this.fields[index];\n\n    this.fields[index] = { ...field, ...validatedField.field };\n    this.updateFields();\n\n    if (validatedField.hasOwnProperty('value')) {\n      this.value[field.property] = validatedField.value;\n    }\n\n    this.changes.detectChanges();\n\n    if (validatedField.focus) {\n      this.focus(field.property);\n    }\n  }\n\n  private getField(property: string) {\n    const changedFieldIndex = this.fields.findIndex(field => field.property === property);\n    const changedField = this.fields[changedFieldIndex];\n\n    return { changedField, changedFieldIndex };\n  }\n\n  private triggerValidationOnForm(changedFieldIndex: number) {\n    const isValidatableField = this.validateFields?.length\n      ? this.validateFieldsChecker(this.validateFields, this.fields[changedFieldIndex].property)\n      : true;\n    const hasValidationForm = this.validate && isValidatableField && this.formValidate.observers.length;\n\n    if (hasValidationForm) {\n      const updatedField = this.fields[changedFieldIndex];\n      this.formValidate.emit(updatedField);\n    }\n  }\n\n  private updateFields() {\n    this.fieldsChange.emit(this.fields);\n    this.visibleFields = this.getVisibleFields();\n    this.setContainerFields();\n  }\n\n  private validateFieldsChecker(validateFields: Array<string>, propertyField: PoDynamicFormField['property']): boolean {\n    return validateFields.some(validateFieldItem => validateFieldItem === propertyField);\n  }\n\n  private async validateField(field: PoDynamicFormField, fieldIndex: number, visibleField: PoDynamicFormField) {\n    const value = this.value[field.property];\n\n    const previousDisabled = visibleField.disabled;\n    visibleField.disabled = true;\n    this.changes.detectChanges();\n\n    try {\n      const validatedField = await this.validationService.sendFieldChange(field, value).toPromise();\n      this.applyFieldValidation(fieldIndex, validatedField);\n    } catch {\n      visibleField.disabled = previousDisabled;\n    }\n  }\n\n  private hasChangeContainer(previous: Array<PoDynamicFormField>, current: Array<PoDynamicFormField>): void {\n    const prevArray = previous.map((item, index) => ({\n      container: item.container || null,\n      property: item.property,\n      index,\n      order: item.order,\n      visible: item.visible ?? true\n    }));\n\n    const currArray = current.map((item, index) => ({\n      container: item.container || null,\n      property: item.property,\n      index,\n      order: item.order,\n      visible: item.visible ?? true\n    }));\n\n    const prevContainers = prevArray.filter(item => item.container);\n    const currContainers = currArray.filter(item => item.container);\n\n    const prevOrder = prevArray.filter(item => item.order);\n    const currOrder = currArray.filter(item => item.order);\n\n    const prevVisibleTrue = prevArray.filter(item => item.visible === true);\n    const currVisibleTrue = currArray.filter(item => item.visible === true);\n\n    const prevVisibleFalse = prevArray.filter(item => !item.visible);\n    const currVisibleFalse = currArray.filter(item => !item.visible);\n\n    // Verifica mudança na quantidade de containers\n    if (prevContainers.length !== currContainers.length) {\n      this.setContainerFields();\n      return;\n    }\n\n    // Verifica mudança na quantidade de order\n    if (prevOrder.length !== currOrder.length) {\n      this.setContainerFields();\n      return;\n    }\n\n    // Verifica mudança na quantidade de visible\n    if (prevVisibleTrue.length !== currVisibleTrue.length) {\n      this.setContainerFields();\n      return;\n    }\n\n    // Verifica mudança na quantidade de visible\n    if (prevVisibleFalse.length !== currVisibleFalse.length) {\n      this.setContainerFields();\n      return;\n    }\n\n    if (currContainers.length) {\n      this.handleChangesContainer(prevContainers, currContainers, 'container');\n    }\n\n    if (currOrder.length) {\n      this.handleChangesContainer(prevOrder, currOrder, 'order');\n    }\n\n    if (currVisibleTrue.length) {\n      this.handleChangesContainer(prevVisibleTrue, currVisibleTrue, 'visible');\n    }\n\n    if (currVisibleFalse.length) {\n      this.handleChangesContainer(prevVisibleFalse, currVisibleFalse, 'visible');\n    }\n\n    //atualiza container sem mudança na estrutura da interface\n    const result = this.diffObjectsArray(previous, this.getVisibleFields());\n    this.containerFields = this.updateFieldContainer(result, this.containerFields);\n  }\n\n  private updateFieldContainer(changes, containerFields) {\n    const mapchanges = new Map(changes.map(obj => [obj.property, obj]));\n\n    containerFields.forEach(subArray => {\n      subArray.forEach((subItem, index) => {\n        const item: any = mapchanges.get(subItem.property);\n        if (item) {\n          subArray[index] = { ...subItem, ...item };\n        }\n      });\n    });\n\n    return containerFields;\n  }\n\n  private diffObjectsArray(oldArray, newArray) {\n    const differences = [];\n\n    newArray.forEach(newObj => {\n      const oldObj = oldArray.find(o => o.property === newObj.property);\n\n      if (!oldObj) {\n        // Se o objeto é novo, adiciona todo o objeto com a propriedade \"property\"\n        differences.push({ ...newObj });\n      } else {\n        // Verificar se há diferenças nas propriedades\n        const diff = { property: newObj.property };\n        let hasDifferences = false;\n\n        for (const key in newObj) {\n          if (newObj[key] !== oldObj[key]) {\n            diff[key] = newObj[key];\n            hasDifferences = true;\n          }\n        }\n\n        if (hasDifferences) {\n          differences.push(diff);\n        }\n      }\n    });\n\n    //retorna mudanças nos fields para atualização do containerFields\n    return differences;\n  }\n\n  private hasContainer() {\n    return this.visibleFields && this.visibleFields.some(field => field.container);\n  }\n\n  private handleChangesContainer(prevContainers, currContainers, key) {\n    for (let i = 0; i < prevContainers.length; i++) {\n      const prev = prevContainers[i];\n      const curr = currContainers[i];\n\n      //Verifica se container mudou de posição\n      if (prev[key] === curr[key] && prev.index !== curr.index) {\n        this.setContainerFields();\n        return;\n      }\n      //Verifica se foi apenas mudança da string em caso do container ou valor no order\n      if (prev[key] !== curr[key] && prev.index === curr.index) {\n        if (key === 'order') {\n          this.setContainerFields();\n          return;\n        }\n        this.containerFields.forEach(subItem =>\n          subItem.forEach(item => {\n            if (item.property === curr.property) {\n              item[key] = curr[key];\n            }\n          })\n        );\n      }\n      //verifica se manteve o mesmo número de container, mas alterou property do container\n      if (prev[key] !== curr[key] && prev.property !== curr.property) {\n        this.setContainerFields();\n        return;\n      }\n    }\n  }\n}\n","<div class=\"po-row\" [class.po-dynamic]=\"hasContainers\" *ngIf=\"visibleFields && visibleFields.length > 0\">\n  <ng-container\n    *ngTemplateOutlet=\"\n      hasContainers ? poContentContainer : poContent;\n      context: { $implicit: hasContainers ? containerFields : visibleFields }\n    \"\n  ></ng-container>\n</div>\n\n<ng-template #poContent let-fields>\n  <ng-container *ngFor=\"let field of fields; trackBy: trackBy\">\n    <po-divider *ngIf=\"field?.divider?.trim()\" class=\"po-sm-12\" [p-label]=\"field.divider\"> </po-divider>\n\n    <po-datepicker\n      #component\n      *ngIf=\"compareTo(field.control, 'datepicker')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-clean]=\"field.clean\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-error-pattern]=\"field.errorMessage\"\n      [p-auto-focus]=\"field.focus\"\n      [p-format]=\"field.format\"\n      [p-help]=\"field.help\"\n      [p-iso-format]=\"field.isoFormat\"\n      [p-label]=\"field.label\"\n      [p-locale]=\"field.locale\"\n      [p-max-date]=\"field.maxValue\"\n      [p-min-date]=\"field.minValue\"\n      [p-no-autocomplete]=\"field.noAutocomplete\"\n      [p-optional]=\"field.optional\"\n      [p-readonly]=\"field.readonly\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      (p-change)=\"onChangeField(field)\"\n      [p-placeholder]=\"field.placeholder\"\n    >\n    </po-datepicker>\n\n    <po-datepicker-range\n      #component\n      *ngIf=\"compareTo(field.control, 'datepickerrange')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-clean]=\"field.clean\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-auto-focus]=\"field.focus\"\n      [p-help]=\"field.help\"\n      [p-label]=\"field.label\"\n      [p-literals]=\"field.literals\"\n      [p-max-date]=\"field.maxValue\"\n      [p-min-date]=\"field.minValue\"\n      [p-no-autocomplete]=\"field.noAutocomplete\"\n      [p-optional]=\"field.optional\"\n      [p-readonly]=\"field.readonly\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      (p-change)=\"onChangeField(field)\"\n    >\n    </po-datepicker-range>\n\n    <po-input\n      #component\n      *ngIf=\"compareTo(field.control, 'input')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-clean]=\"field.clean\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-error-pattern]=\"field.errorMessage\"\n      [p-auto-focus]=\"field.focus\"\n      [p-help]=\"field.help\"\n      [p-label]=\"field.label\"\n      [p-mask-format-model]=\"field.maskFormatModel\"\n      [p-mask]=\"field.mask\"\n      [p-maxlength]=\"field.maxLength\"\n      [p-minlength]=\"field.minLength\"\n      [p-no-autocomplete]=\"field.noAutocomplete\"\n      [p-optional]=\"field.optional\"\n      [p-pattern]=\"field.pattern\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      (p-change)=\"onChangeField(field)\"\n      (p-change-model)=\"onChangeFieldModel(field)\"\n      [p-icon]=\"field.icon\"\n      [p-placeholder]=\"field.placeholder\"\n      [p-readonly]=\"field.readonly\"\n    >\n    </po-input>\n\n    <po-number\n      #component\n      *ngIf=\"compareTo(field.control, 'number')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-clean]=\"field.clean\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-error-pattern]=\"field.errorMessage\"\n      [p-auto-focus]=\"field.focus\"\n      [p-help]=\"field.help\"\n      [p-label]=\"field.label\"\n      [p-min]=\"field.minValue\"\n      [p-max]=\"field.maxValue\"\n      [p-maxlength]=\"field.maxLength\"\n      [p-minlength]=\"field.minLength\"\n      [p-no-autocomplete]=\"field.noAutocomplete\"\n      [p-optional]=\"field.optional\"\n      [p-step]=\"field.step\"\n      [p-readonly]=\"field.readonly\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      (p-change)=\"onChangeField(field)\"\n      (p-change-model)=\"onChangeFieldModel(field)\"\n      [p-icon]=\"field.icon\"\n      [p-placeholder]=\"field.placeholder\"\n    >\n    </po-number>\n\n    <po-decimal\n      #component\n      *ngIf=\"compareTo(field.control, 'decimal')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-clean]=\"field.clean\"\n      [p-error-pattern]=\"field.errorMessage\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-decimals-length]=\"field.decimalsLength\"\n      [p-thousand-maxlength]=\"field.thousandMaxlength\"\n      [p-icon]=\"field.icon\"\n      [p-auto-focus]=\"field.focus\"\n      [p-help]=\"field.help\"\n      [p-label]=\"field.label\"\n      [p-locale]=\"field.locale\"\n      [p-min]=\"field.minValue\"\n      [p-max]=\"field.maxValue\"\n      [p-maxlength]=\"field.maxLength\"\n      [p-minlength]=\"field.minLength\"\n      [p-no-autocomplete]=\"field.noAutocomplete\"\n      [p-optional]=\"field.optional\"\n      [p-readonly]=\"field.readonly\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      (p-change)=\"onChangeField(field)\"\n      (p-change-model)=\"onChangeFieldModel(field)\"\n      [p-placeholder]=\"field.placeholder\"\n    >\n    </po-decimal>\n\n    <po-select\n      #component\n      *ngIf=\"compareTo(field.control, 'select')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-field-label]=\"field.fieldLabel\"\n      [p-field-value]=\"field.fieldValue\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-help]=\"field.help\"\n      [p-label]=\"field.label\"\n      [p-optional]=\"field.optional\"\n      [p-options]=\"field.options\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      (p-change)=\"onChangeField(field)\"\n      [p-placeholder]=\"field.placeholder\"\n      [p-readonly]=\"field.readonly\"\n    >\n    </po-select>\n\n    <po-radio-group\n      #component\n      *ngIf=\"compareTo(field.control, 'radioGroup')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-columns]=\"field.columns || 3\"\n      [p-auto-focus]=\"field.focus\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-help]=\"field.help\"\n      [p-label]=\"field.label\"\n      [p-optional]=\"field.optional\"\n      [p-options]=\"field.options\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      (p-change)=\"onChangeField(field)\"\n    >\n    </po-radio-group>\n\n    <po-switch\n      #component\n      *ngIf=\"compareTo(field.control, 'switch')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-format-model]=\"field.formatModel\"\n      [p-help]=\"field.help\"\n      [p-label]=\"field.label\"\n      [p-label-off]=\"field.booleanFalse\"\n      [p-label-on]=\"field.booleanTrue\"\n      [p-label-position]=\"field.labelPosition\"\n      [p-hide-label-status]=\"field.hideLabelStatus\"\n      (p-change)=\"onChangeField(field)\"\n    >\n    </po-switch>\n\n    <po-checkbox\n      #component\n      *ngIf=\"compareTo(field.control, 'checkbox')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-auto-focus]=\"field.focus\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-label]=\"field.label\"\n      [p-size]=\"field.size\"\n      (p-change)=\"onChangeField(field)\"\n    >\n    </po-checkbox>\n\n    <po-combo\n      #component\n      *ngIf=\"compareTo(field.control, 'combo')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      p-emit-object-value\n      [p-auto-focus]=\"field.focus\"\n      [p-clean]=\"field.clean\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-field-label]=\"field.fieldLabel\"\n      [p-field-value]=\"field.fieldValue\"\n      [p-filter-params]=\"field.params\"\n      [p-filter-service]=\"field.optionsService\"\n      [p-help]=\"field.help\"\n      [p-infinite-scroll]=\"field.infiniteScroll\"\n      [p-infinite-scroll-distance]=\"field.infiniteScrollDistance || 100\"\n      [p-label]=\"field.label\"\n      [p-literals]=\"field.literals\"\n      [p-options]=\"field.options\"\n      [p-optional]=\"field.optional\"\n      [p-sort]=\"field.sort\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      (p-change)=\"onChangeField(field, $event)\"\n      [p-icon]=\"field.icon\"\n      [p-placeholder]=\"field.placeholder\"\n      [p-filter-minlength]=\"field.filterMinlength\"\n      [p-filter-mode]=\"field.filterMode\"\n      [p-disabled-init-filter]=\"field.disabledInitFilter\"\n      [p-disabled-tab-filter]=\"field.disabledTabFilter\"\n      [p-debounce-time]=\"field.debounceTime\"\n      [p-change-on-enter]=\"field.changeOnEnter\"\n    >\n    </po-combo>\n\n    <po-lookup\n      #component\n      *ngIf=\"compareTo(field.control, 'lookup')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      p-field-label=\"label\"\n      p-field-value=\"value\"\n      [ngClass]=\"field.componentClass\"\n      [p-clean]=\"field.clean\"\n      [p-columns]=\"field.columns\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-field-label]=\"field.fieldLabel || 'label'\"\n      [p-field-value]=\"field.fieldValue || 'value'\"\n      [p-filter-params]=\"field.params\"\n      [p-filter-service]=\"field.searchService\"\n      [p-auto-focus]=\"field.focus\"\n      [p-auto-height]=\"field.autoHeight\"\n      [p-help]=\"field.help\"\n      [p-field-format]=\"field.format\"\n      [p-infinite-scroll]=\"field.infiniteScroll\"\n      [p-label]=\"field.label\"\n      [p-literals]=\"field.literals\"\n      [p-multiple]=\"field.multiple\"\n      [p-no-autocomplete]=\"field.noAutocomplete\"\n      [p-optional]=\"field.optional\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      (p-change)=\"onChangeField(field)\"\n      [p-placeholder]=\"field.placeholder\"\n      [p-advanced-filters]=\"field.advancedFilters\"\n      (p-change-visible-columns)=\"field.changeVisibleColumns?.($event)\"\n      (p-restore-column-manager)=\"field.columnRestoreManager?.($event)\"\n    >\n    </po-lookup>\n\n    <po-checkbox-group\n      #component\n      *ngIf=\"compareTo(field.control, 'checkboxGroup')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-columns]=\"field.columns || 3\"\n      [p-auto-focus]=\"field.focus\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-help]=\"field.help\"\n      [p-label]=\"field.label\"\n      [p-optional]=\"field.optional\"\n      [p-options]=\"field.options\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      (p-change)=\"onChangeField(field)\"\n    >\n    </po-checkbox-group>\n\n    <po-multiselect\n      #component\n      *ngIf=\"compareTo(field.control, 'multiselect')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-auto-focus]=\"field.focus\"\n      [p-auto-height]=\"field.autoHeight\"\n      [p-help]=\"field.help\"\n      [p-label]=\"field.label\"\n      [p-literals]=\"field.literals\"\n      [p-optional]=\"field.optional\"\n      [p-options]=\"field.options\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      (p-change)=\"onChangeField(field)\"\n      [p-placeholder]=\"field.placeholder\"\n      [p-field-label]=\"field.fieldLabel\"\n      [p-field-value]=\"field.fieldValue\"\n      [p-filter-service]=\"field.optionsService\"\n      [p-filter-mode]=\"field.filterMode\"\n      [p-debounce-time]=\"field.debounceTime\"\n      [p-sort]=\"field.sort\"\n      [p-placeholder-search]=\"field.placeholderSearch\"\n      [p-hide-search]=\"field.hideSearch\"\n      [p-hide-select-all]=\"field.hideSelectAll\"\n    >\n    </po-multiselect>\n\n    <po-textarea\n      #component\n      *ngIf=\"compareTo(field.control, 'textarea')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-auto-focus]=\"field.focus\"\n      [p-help]=\"field.help\"\n      [p-label]=\"field.label\"\n      [p-maxlength]=\"field.maxLength\"\n      [p-minlength]=\"field.minLength\"\n      [p-optional]=\"field.optional\"\n      [p-readonly]=\"field.readonly\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      [p-rows]=\"field.rows\"\n      (p-change)=\"onChangeField(field)\"\n      (p-change-model)=\"onChangeFieldModel(field)\"\n      [p-placeholder]=\"field.placeholder\"\n    >\n    </po-textarea>\n\n    <po-password\n      #component\n      *ngIf=\"compareTo(field.control, 'password')\"\n      [name]=\"field.property\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-clean]=\"field.clean\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-error-pattern]=\"field.errorMessage\"\n      [p-auto-focus]=\"field.focus\"\n      [p-help]=\"field.help\"\n      [p-hide-password-peek]=\"field.hidePasswordPeek\"\n      [p-icon]=\"field.icon\"\n      [p-label]=\"field.label\"\n      [p-maxlength]=\"field.maxLength\"\n      [p-minlength]=\"field.minLength\"\n      [p-no-autocomplete]=\"field.noAutocomplete\"\n      [p-optional]=\"field.optional\"\n      [p-pattern]=\"field.pattern\"\n      [p-readonly]=\"field.readonly\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      (p-change)=\"onChangeField(field)\"\n      (p-change-model)=\"onChangeFieldModel(field)\"\n      [p-placeholder]=\"field.placeholder\"\n    >\n    </po-password>\n\n    <po-upload\n      #component\n      *ngIf=\"compareTo(field.control, 'upload')\"\n      [(ngModel)]=\"value[field.property]\"\n      [ngClass]=\"field.componentClass\"\n      [p-auto-upload]=\"field.autoUpload\"\n      [p-directory]=\"field.directory\"\n      [p-disabled]=\"isDisabled(field)\"\n      [p-drag-drop]=\"field.dragDrop\"\n      [p-drag-drop-height]=\"field.dragDropHeight\"\n      [p-restrictions]=\"field.restrictions\"\n      [p-form-field]=\"field.formField\"\n      [p-headers]=\"field.headers\"\n      [p-help]=\"field.help\"\n      [p-hide-restrictions-info]=\"field.hideRestrictionsInfo\"\n      [p-hide-select-button]=\"field.hideSelectButton\"\n      [p-hide-send-button]=\"field.hideSendButton\"\n      [p-multiple]=\"field.multiple\"\n      [p-label]=\"field.label\"\n      [p-literals]=\"field.literals\"\n      [name]=\"field.property\"\n      (p-error)=\"field.onError($event)\"\n      (p-success)=\"field.onSuccess($event)\"\n      (p-upload)=\"field.onUpload($event)\"\n      [p-optional]=\"field.optional\"\n      [p-required]=\"field.required\"\n      [p-show-required]=\"field.showRequired\"\n      (p-change)=\"onChangeField(field)\"\n      (p-change-model)=\"onChangeFieldModel(field)\"\n      [p-url]=\"field.url\"\n    >\n    </po-upload>\n  </ng-container>\n</ng-template>\n\n<ng-template #poContentContainer let-fields>\n  <po-dynamic-container [p-fields]=\"fields\" [p-content]=\"poContent\"></po-dynamic-container>\n</ng-template>\n"]}