ngx-sp-infra 1.4.95 → 1.4.97

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.
@@ -1,4 +1,7 @@
1
1
  import { UntypedFormGroup, UntypedFormArray } from '@angular/forms';
2
+ /**
3
+ * @summary Contém diversos métodos de utilidade para formulários
4
+ */
2
5
  export class FormUtils {
3
6
  /** Verifica se um campo é inválido (Template Driven) */
4
7
  static isInvalidFieldTemplate(control) {
@@ -12,7 +15,7 @@ export class FormUtils {
12
15
  /** Verifica se um campo é inválido ou se possui algum erro customizado (Data Driven) */
13
16
  static isInvalidFieldError(control) {
14
17
  if (control) {
15
- if ((!control.valid && (control.dirty || control.touched)) || control.errors) {
18
+ if (!control.valid && (control.dirty || control.touched)) {
16
19
  return true;
17
20
  }
18
21
  else {
@@ -53,5 +56,53 @@ export class FormUtils {
53
56
  ? config[validatorName]
54
57
  : `Este validador - ${validatorName} - não foi implementado`);
55
58
  }
59
+ /**
60
+ * @summary Mapeia os valores de um formulário reativo para um objeto de modelo.
61
+ *
62
+ * @description
63
+ * O método `mapFormToModel` recebe um objeto de modelo e um `FormGroup` do Angular,
64
+ * e retorna um novo objeto que combina as propriedades do modelo original com os valores
65
+ * atuais do formulário. Este método é útil para atualizar dinamicamente as propriedades
66
+ * de um modelo com base nos valores inseridos pelo usuário em um formulário.
67
+ *
68
+ * Se o objeto `record` ou o `formGroup` forem nulos ou indefinidos, o método retornará `null`.
69
+ * Caso contrário, o método retorna um novo objeto que inclui todas as propriedades
70
+ * do objeto original, sobrescrevendo-as com os valores atuais do formulário, se disponíveis.
71
+ *
72
+ * @param {object} record - O objeto de modelo original que será atualizado com os valores do formulário.
73
+ * @param {FormGroup} formGroup - O `FormGroup` contendo os valores inseridos pelo usuário.
74
+ * @returns {object | null} - Um novo objeto combinando o modelo original e os valores do formulário, ou `null` se `record` ou `formGroup` forem nulos ou indefinidos.
75
+ *
76
+ * @example
77
+ * // Suponha que você tenha um objeto de modelo `person` e um `FormGroup` chamado `personForm`.
78
+ * const person = {
79
+ * name: 'John Doe',
80
+ * age: 30,
81
+ * email: 'john.doe@example.com'
82
+ * };
83
+ *
84
+ * const personForm: FormGroup = this.formBuilder.group({
85
+ * name: ['Jane Doe'],
86
+ * age: [25],
87
+ * email: ['jane.doe@example.com']
88
+ * });
89
+ *
90
+ * const updatedPerson = this.mapFormToModel(person, personForm);
91
+ * // `updatedPerson` agora contém:
92
+ * // {
93
+ * // name: 'Jane Doe',
94
+ * // age: 25,
95
+ * // email: 'jane.doe@example.com'
96
+ * // }
97
+ */
98
+ mapFormToModel(record, formGroup) {
99
+ if ((record === null || record === undefined) || (formGroup === null || formGroup === undefined)) {
100
+ return null;
101
+ }
102
+ return {
103
+ ...record,
104
+ ...formGroup.value
105
+ };
106
+ }
56
107
  }
57
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS11dGlscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1zcC1pbmZyYS9zcmMvbGliL3V0aWxzL2Zvcm0tdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUE4QixnQkFBZ0IsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRWhHLE1BQU0sT0FBTyxTQUFTO0lBRXBCLHdEQUF3RDtJQUN4RCxNQUFNLENBQUMsc0JBQXNCLENBQUMsT0FBa0I7UUFDOUMsTUFBTSxHQUFHLEdBQVEsQ0FBQyxPQUFPLENBQUMsS0FBSyxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssSUFBSSxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUM7UUFFdEUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQTtJQUM1QixDQUFDO0lBRUQsb0RBQW9EO0lBQ3BELE1BQU0sQ0FBQyxjQUFjLENBQUMsT0FBK0I7UUFDbkQsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsS0FBSyxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssSUFBSSxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2xGLENBQUM7SUFFRCx3RkFBd0Y7SUFDeEYsTUFBTSxDQUFDLG1CQUFtQixDQUFDLE9BQStCO1FBQ3hELElBQUksT0FBTyxFQUFFLENBQUM7WUFDWixJQUFJLENBQUMsQ0FBQyxPQUFPLENBQUMsS0FBSyxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssSUFBSSxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUMsSUFBSSxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUM7Z0JBQUMsT0FBTyxJQUFJLENBQUE7WUFBQyxDQUFDO2lCQUN4RixDQUFDO2dCQUFDLE9BQU8sS0FBSyxDQUFBO1lBQUMsQ0FBQztRQUN2QixDQUFDO2FBQ0ksQ0FBQztZQUFDLE9BQU8sS0FBSyxDQUFBO1FBQUMsQ0FBQztJQUN2QixDQUFDO0lBRUQsMkNBQTJDO0lBQzNDLE1BQU0sQ0FBQyxjQUFjLENBQUMsU0FBOEM7UUFDbEUsTUFBTSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxFQUFFO1lBQzlDLE1BQU0sT0FBTyxHQUFHLFNBQVMsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7WUFFckMsT0FBTyxFQUFFLFdBQVcsRUFBRSxDQUFDO1lBQ3ZCLE9BQU8sRUFBRSxhQUFhLEVBQUUsQ0FBQztZQUV6QixJQUFJLE9BQU8sWUFBWSxnQkFBZ0IsSUFBSSxPQUFPLFlBQVksZ0JBQWdCLEVBQUUsQ0FBQztnQkFDL0UsSUFBSSxDQUFDLGNBQWMsQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUMvQixDQUFDO1FBRUgsQ0FBQyxDQUFDLENBQUM7SUFFTCxDQUFDO0lBRUQsOERBQThEO0lBQzlELE1BQU0sQ0FBQyxlQUFlLENBQUMsU0FBaUIsRUFBRSxhQUFxQixFQUFFLGNBQW9CLEVBQUUsa0JBQTJCO1FBQ2hILE1BQU0sTUFBTSxHQUFTO1lBQ25CLFVBQVUsRUFBRSwyQkFBMkI7WUFDdkMsV0FBVyxFQUFFLHFDQUFxQyxjQUFjLENBQUMsY0FBYyxjQUFjO1lBQzdGLFdBQVcsRUFBRSxxQ0FBcUMsY0FBYyxDQUFDLGNBQWMsY0FBYztZQUM3RixLQUFLLEVBQUUsaUNBQWlDLGNBQWMsQ0FBQyxHQUFHLEdBQUc7WUFDN0QsS0FBSyxFQUFFLGlDQUFpQyxjQUFjLENBQUMsR0FBRyxHQUFHO1lBQzdELGVBQWUsRUFBRSxRQUFRLFNBQVMsaUJBQWlCO1lBQ25ELG9CQUFvQixFQUFFLFFBQVEsU0FBUywwQkFBMEI7WUFDakUsV0FBVyxFQUFFLDJCQUEyQjtZQUN4QyxPQUFPLEVBQUUsNEJBQTRCO1NBQ3RDLENBQUM7UUFFRixPQUFPLENBQUMsa0JBQWtCO1lBQ3hCLENBQUMsQ0FBQyxrQkFBa0I7WUFDcEIsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxhQUFhLENBQUM7Z0JBQ3JCLENBQUMsQ0FBQyxNQUFNLENBQUMsYUFBYSxDQUFDO2dCQUN2QixDQUFDLENBQUMsb0JBQW9CLGFBQWEseUJBQXlCLENBQUMsQ0FBQztJQUNwRSxDQUFDO0NBRUYiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBYnN0cmFjdENvbnRyb2wsIE5nQ29udHJvbCwgVW50eXBlZEZvcm1Hcm91cCwgVW50eXBlZEZvcm1BcnJheSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuXHJcbmV4cG9ydCBjbGFzcyBGb3JtVXRpbHMge1xyXG5cclxuICAvKiogVmVyaWZpY2Egc2UgdW0gY2FtcG8gw6kgaW52w6FsaWRvIChUZW1wbGF0ZSBEcml2ZW4pICovXHJcbiAgc3RhdGljIGlzSW52YWxpZEZpZWxkVGVtcGxhdGUoY29udHJvbDogTmdDb250cm9sKTogYm9vbGVhbiB7XHJcbiAgICBjb25zdCByZXQ6IGFueSA9ICFjb250cm9sLnZhbGlkICYmIChjb250cm9sLmRpcnR5IHx8IGNvbnRyb2wudG91Y2hlZCk7XHJcbiAgXHJcbiAgICByZXR1cm4gKHJldCA/IHJldCA6IGZhbHNlKVxyXG4gIH1cclxuICBcclxuICAvKiogVmVyaWZpY2Egc2UgdW0gY2FtcG8gw6kgaW52w6FsaWRvIChEYXRhIERyaXZlbikgKi9cclxuICBzdGF0aWMgaXNJbnZhbGlkRmllbGQoY29udHJvbDogQWJzdHJhY3RDb250cm9sIHwgbnVsbCk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuIChjb250cm9sID8gIWNvbnRyb2wudmFsaWQgJiYgKGNvbnRyb2wuZGlydHkgfHwgY29udHJvbC50b3VjaGVkKSA6IGZhbHNlKTtcclxuICB9XHJcblxyXG4gIC8qKiBWZXJpZmljYSBzZSB1bSBjYW1wbyDDqSBpbnbDoWxpZG8gb3Ugc2UgcG9zc3VpIGFsZ3VtIGVycm8gY3VzdG9taXphZG8gKERhdGEgRHJpdmVuKSAqL1xyXG4gIHN0YXRpYyBpc0ludmFsaWRGaWVsZEVycm9yKGNvbnRyb2w6IEFic3RyYWN0Q29udHJvbCB8IG51bGwpOiBib29sZWFuIHtcclxuICAgIGlmIChjb250cm9sKSB7XHJcbiAgICAgIGlmICgoIWNvbnRyb2wudmFsaWQgJiYgKGNvbnRyb2wuZGlydHkgfHwgY29udHJvbC50b3VjaGVkKSkgfHwgY29udHJvbC5lcnJvcnMpIHsgcmV0dXJuIHRydWUgfVxyXG4gICAgICBlbHNlIHsgcmV0dXJuIGZhbHNlIH1cclxuICAgIH1cclxuICAgIGVsc2UgeyByZXR1cm4gZmFsc2UgfVxyXG4gIH1cclxuXHJcbiAgLyoqIFZhbGlkYSB0b2RvcyBvcyBjYW1wb3MgZG8gZm9ybXVsw6FyaW8gKi9cclxuICBzdGF0aWMgdmFsaWRhdGVGaWVsZHMoZm9ybUdyb3VwOiBVbnR5cGVkRm9ybUdyb3VwIHwgVW50eXBlZEZvcm1BcnJheSk6IHZvaWQge1xyXG4gICAgT2JqZWN0LmtleXMoZm9ybUdyb3VwLmNvbnRyb2xzKS5mb3JFYWNoKGZpZWxkID0+IHtcclxuICAgICAgY29uc3QgY29udHJvbCA9IGZvcm1Hcm91cC5nZXQoZmllbGQpO1xyXG4gIFxyXG4gICAgICBjb250cm9sPy5tYXJrQXNEaXJ0eSgpO1xyXG4gICAgICBjb250cm9sPy5tYXJrQXNUb3VjaGVkKCk7XHJcbiAgICAgIFxyXG4gICAgICBpZiAoY29udHJvbCBpbnN0YW5jZW9mIFVudHlwZWRGb3JtR3JvdXAgfHwgY29udHJvbCBpbnN0YW5jZW9mIFVudHlwZWRGb3JtQXJyYXkpIHtcclxuICAgICAgICB0aGlzLnZhbGlkYXRlRmllbGRzKGNvbnRyb2wpO1xyXG4gICAgICB9XHJcbiAgXHJcbiAgICB9KTtcclxuICBcclxuICB9ICAgICBcclxuICAgICAgXHJcbiAgLyoqIE9idMOpbSBhIG1lbnNhZ2VtIGRlIGVycm8gY29uZm9ybWUgbyB2YWxpZGFkb3IgdXRpbGl6YWRvICovXHJcbiAgc3RhdGljIGdldEVycm9yTWVzc2FnZShmaWVsZE5hbWU6IHN0cmluZywgdmFsaWRhdG9yTmFtZTogc3RyaW5nLCB2YWxpZGF0b3JWYWx1ZT86IGFueSwgY3VzdG9tRXJyb3JNZXNzYWdlPzogc3RyaW5nKTogc3RyaW5nIHtcclxuICAgIGNvbnN0IGNvbmZpZyA6IGFueSA9IHtcclxuICAgICAgJ3JlcXVpcmVkJzogYEVzdGUgY2FtcG8gw6kgb2JyaWdhdMOzcmlvLmAsXHJcbiAgICAgICdtaW5sZW5ndGgnOiBgRXN0ZSBjYW1wbyBkZXZlIHBvc3N1aXIgbm8gbcOtbmltbyAke3ZhbGlkYXRvclZhbHVlLnJlcXVpcmVkTGVuZ3RofSBjYXJhY3RlcmVzLmAsXHJcbiAgICAgICdtYXhsZW5ndGgnOiBgRXN0ZSBjYW1wbyBkZXZlIHBvc3N1aXIgbm8gbcOheGltbyAke3ZhbGlkYXRvclZhbHVlLnJlcXVpcmVkTGVuZ3RofSBjYXJhY3RlcmVzLmAsXHJcbiAgICAgICdtaW4nOiBgRXN0ZSBjYW1wbyBkZXZlIHNlciBubyBtw61uaW1vICR7dmFsaWRhdG9yVmFsdWUubWlufS5gLFxyXG4gICAgICAnbWF4JzogYEVzdGUgY2FtcG8gZGV2ZSBzZXIgbm8gbcOheGltbyAke3ZhbGlkYXRvclZhbHVlLm1heH0uYCxcclxuICAgICAgJ2NwY25wakludmFsaWQnOiBgRXN0ZSAke2ZpZWxkTmFtZX0gZXN0w6EgaW52w6FsaWRvLmAsXHJcbiAgICAgICdjcGNucGpJbnZhbGlkRGlnaXQnOiBgRXN0ZSAke2ZpZWxkTmFtZX0gdGVtIHVtIGTDrWdpdG8gaW52w6FsaWRvLmAsXHJcbiAgICAgICdpbmNvcnJlY3QnOiBgRXN0ZSBjYW1wbyBlc3TDoSBpbnbDoWxpZG8uYCxcclxuICAgICAgJ2VtYWlsJzogYEVzdGUgZS1tYWlsIGVzdMOhIGludsOhbGlkby5gXHJcbiAgICB9O1xyXG5cclxuICAgIHJldHVybiAoY3VzdG9tRXJyb3JNZXNzYWdlXHJcbiAgICAgID8gY3VzdG9tRXJyb3JNZXNzYWdlXHJcbiAgICAgIDogY29uZmlnW3ZhbGlkYXRvck5hbWVdXHJcbiAgICAgICAgPyBjb25maWdbdmFsaWRhdG9yTmFtZV1cclxuICAgICAgICA6IGBFc3RlIHZhbGlkYWRvciAtICR7dmFsaWRhdG9yTmFtZX0gLSBuw6NvIGZvaSBpbXBsZW1lbnRhZG9gKTtcclxuICB9XHJcblxyXG59XHJcbiJdfQ==
108
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-utils.js","sourceRoot":"","sources":["../../../../../projects/ngx-sp-infra/src/lib/utils/form-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl, NgControl, UntypedFormGroup, UntypedFormArray, FormGroup } from '@angular/forms';\r\n\r\n\r\n/**\r\n * @summary Contém diversos métodos de utilidade para formulários\r\n */\r\nexport class FormUtils {\r\n\r\n  /** Verifica se um campo é inválido (Template Driven) */\r\n  static isInvalidFieldTemplate(control: NgControl): boolean {\r\n    const ret: any = !control.valid && (control.dirty || control.touched);\r\n  \r\n    return (ret ? ret : false)\r\n  }\r\n  \r\n  /** Verifica se um campo é inválido (Data Driven) */\r\n  static isInvalidField(control: AbstractControl | null): boolean {\r\n    return (control ? !control.valid && (control.dirty || control.touched) : false);\r\n  }\r\n\r\n  /** Verifica se um campo é inválido ou se possui algum erro customizado (Data Driven) */\r\n  static isInvalidFieldError(control: AbstractControl | null): boolean {\r\n    if (control) {\r\n      if (!control.valid && (control.dirty || control.touched)) { return true }\r\n      else { return false }\r\n    }\r\n    else { return false }\r\n  }\r\n\r\n  /** Valida todos os campos do formulário */\r\n  static validateFields(formGroup: UntypedFormGroup | UntypedFormArray): void {\r\n    Object.keys(formGroup.controls).forEach(field => {\r\n      const control = formGroup.get(field);\r\n  \r\n      control?.markAsDirty();\r\n      control?.markAsTouched();\r\n      \r\n      if (control instanceof UntypedFormGroup || control instanceof UntypedFormArray) {\r\n        this.validateFields(control);\r\n      }\r\n  \r\n    });\r\n  \r\n  }     \r\n      \r\n  /** Obtém a mensagem de erro conforme o validador utilizado */\r\n  static getErrorMessage(fieldName: string, validatorName: string, validatorValue?: any, customErrorMessage?: string): string {\r\n    const config : any = {\r\n      'required': `Este campo é obrigatório.`,\r\n      'minlength': `Este campo deve possuir no mínimo ${validatorValue.requiredLength} caracteres.`,\r\n      'maxlength': `Este campo deve possuir no máximo ${validatorValue.requiredLength} caracteres.`,\r\n      'min': `Este campo deve ser no mínimo ${validatorValue.min}.`,\r\n      'max': `Este campo deve ser no máximo ${validatorValue.max}.`,\r\n      'cpcnpjInvalid': `Este ${fieldName} está inválido.`,\r\n      'cpcnpjInvalidDigit': `Este ${fieldName} tem um dígito inválido.`,\r\n      'incorrect': `Este campo está inválido.`,\r\n      'email': `Este e-mail está inválido.`\r\n    };\r\n\r\n    return (customErrorMessage\r\n      ? customErrorMessage\r\n      : config[validatorName]\r\n        ? config[validatorName]\r\n        : `Este validador - ${validatorName} - não foi implementado`);\r\n  }\r\n\r\n\r\n\r\n  /**\r\n   * @summary Mapeia os valores de um formulário reativo para um objeto de modelo.\r\n   *\r\n   * @description\r\n   * O método `mapFormToModel` recebe um objeto de modelo e um `FormGroup` do Angular, \r\n   * e retorna um novo objeto que combina as propriedades do modelo original com os valores \r\n   * atuais do formulário. Este método é útil para atualizar dinamicamente as propriedades \r\n   * de um modelo com base nos valores inseridos pelo usuário em um formulário.\r\n   * \r\n   * Se o objeto `record` ou o `formGroup` forem nulos ou indefinidos, o método retornará `null`.\r\n   * Caso contrário, o método retorna um novo objeto que inclui todas as propriedades \r\n   * do objeto original, sobrescrevendo-as com os valores atuais do formulário, se disponíveis.\r\n   *\r\n   * @param {object} record - O objeto de modelo original que será atualizado com os valores do formulário.\r\n   * @param {FormGroup} formGroup - O `FormGroup` contendo os valores inseridos pelo usuário.\r\n   * @returns {object | null} - Um novo objeto combinando o modelo original e os valores do formulário, ou `null` se `record` ou `formGroup` forem nulos ou indefinidos.\r\n   *\r\n   * @example\r\n   * // Suponha que você tenha um objeto de modelo `person` e um `FormGroup` chamado `personForm`.\r\n   * const person = {\r\n   *   name: 'John Doe',\r\n   *   age: 30,\r\n   *   email: 'john.doe@example.com'\r\n   * };\r\n   * \r\n   * const personForm: FormGroup = this.formBuilder.group({\r\n   *   name: ['Jane Doe'],\r\n   *   age: [25],\r\n   *   email: ['jane.doe@example.com']\r\n   * });\r\n   * \r\n   * const updatedPerson = this.mapFormToModel(person, personForm);\r\n   * // `updatedPerson` agora contém:\r\n   * // {\r\n   * //   name: 'Jane Doe',\r\n   * //   age: 25,\r\n   * //   email: 'jane.doe@example.com'\r\n   * // }\r\n  */\r\n  public mapFormToModel(record: object, formGroup: FormGroup): object | null {\r\n    if ((record === null || record === undefined) || (formGroup === null || formGroup === undefined)) { return null; }\r\n    \r\n    return {\r\n      ...record,\r\n      ...formGroup.value\r\n    };\r\n  }\r\n\r\n}\r\n"]}
@@ -1011,6 +1011,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
1011
1011
  type: Input
1012
1012
  }] } });
1013
1013
 
1014
+ /**
1015
+ * @summary Contém diversos métodos de utilidade para formulários
1016
+ */
1014
1017
  class FormUtils {
1015
1018
  /** Verifica se um campo é inválido (Template Driven) */
1016
1019
  static isInvalidFieldTemplate(control) {
@@ -1024,7 +1027,7 @@ class FormUtils {
1024
1027
  /** Verifica se um campo é inválido ou se possui algum erro customizado (Data Driven) */
1025
1028
  static isInvalidFieldError(control) {
1026
1029
  if (control) {
1027
- if ((!control.valid && (control.dirty || control.touched)) || control.errors) {
1030
+ if (!control.valid && (control.dirty || control.touched)) {
1028
1031
  return true;
1029
1032
  }
1030
1033
  else {
@@ -1065,6 +1068,54 @@ class FormUtils {
1065
1068
  ? config[validatorName]
1066
1069
  : `Este validador - ${validatorName} - não foi implementado`);
1067
1070
  }
1071
+ /**
1072
+ * @summary Mapeia os valores de um formulário reativo para um objeto de modelo.
1073
+ *
1074
+ * @description
1075
+ * O método `mapFormToModel` recebe um objeto de modelo e um `FormGroup` do Angular,
1076
+ * e retorna um novo objeto que combina as propriedades do modelo original com os valores
1077
+ * atuais do formulário. Este método é útil para atualizar dinamicamente as propriedades
1078
+ * de um modelo com base nos valores inseridos pelo usuário em um formulário.
1079
+ *
1080
+ * Se o objeto `record` ou o `formGroup` forem nulos ou indefinidos, o método retornará `null`.
1081
+ * Caso contrário, o método retorna um novo objeto que inclui todas as propriedades
1082
+ * do objeto original, sobrescrevendo-as com os valores atuais do formulário, se disponíveis.
1083
+ *
1084
+ * @param {object} record - O objeto de modelo original que será atualizado com os valores do formulário.
1085
+ * @param {FormGroup} formGroup - O `FormGroup` contendo os valores inseridos pelo usuário.
1086
+ * @returns {object | null} - Um novo objeto combinando o modelo original e os valores do formulário, ou `null` se `record` ou `formGroup` forem nulos ou indefinidos.
1087
+ *
1088
+ * @example
1089
+ * // Suponha que você tenha um objeto de modelo `person` e um `FormGroup` chamado `personForm`.
1090
+ * const person = {
1091
+ * name: 'John Doe',
1092
+ * age: 30,
1093
+ * email: 'john.doe@example.com'
1094
+ * };
1095
+ *
1096
+ * const personForm: FormGroup = this.formBuilder.group({
1097
+ * name: ['Jane Doe'],
1098
+ * age: [25],
1099
+ * email: ['jane.doe@example.com']
1100
+ * });
1101
+ *
1102
+ * const updatedPerson = this.mapFormToModel(person, personForm);
1103
+ * // `updatedPerson` agora contém:
1104
+ * // {
1105
+ * // name: 'Jane Doe',
1106
+ * // age: 25,
1107
+ * // email: 'jane.doe@example.com'
1108
+ * // }
1109
+ */
1110
+ mapFormToModel(record, formGroup) {
1111
+ if ((record === null || record === undefined) || (formGroup === null || formGroup === undefined)) {
1112
+ return null;
1113
+ }
1114
+ return {
1115
+ ...record,
1116
+ ...formGroup.value
1117
+ };
1118
+ }
1068
1119
  }
1069
1120
 
1070
1121
  class FieldErrorMessageComponent {