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 (
|
|
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,
|
|
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 (
|
|
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 {
|