@senior-gestao-pessoas/payroll-core 9.4.0-f9d3c09b-0079-4f7c-94cf-dd79338e7089 → 9.5.0-01923a3e-20f4-4cb3-9565-a0584abd00d1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (42) hide show
  1. package/bundles/senior-gestao-pessoas-payroll-core.umd.js +1214 -770
  2. package/bundles/senior-gestao-pessoas-payroll-core.umd.js.map +1 -1
  3. package/bundles/senior-gestao-pessoas-payroll-core.umd.min.js +16 -1
  4. package/bundles/senior-gestao-pessoas-payroll-core.umd.min.js.map +1 -1
  5. package/components/historical-pix-account/historical-pix-account-base.d.ts +27 -0
  6. package/components/historical-pix-account/historical-pix-account-form/historical-pix-account-form.component.d.ts +8 -40
  7. package/components/historical-pix-account/historical-pix-account.component.d.ts +36 -8
  8. package/components/historical-pix-account/historical-pix-account.service.d.ts +1 -0
  9. package/components/historical-pix-account-list/historical-pix-account-list.component.d.ts +10 -1
  10. package/components/shared/index.d.ts +1 -0
  11. package/components/shared/shared-state.service.d.ts +17 -0
  12. package/components/utils/format-utils/format-utils.service.d.ts +30 -3
  13. package/esm2015/components/historical-pix-account/historical-pix-account-base.js +173 -0
  14. package/esm2015/components/historical-pix-account/historical-pix-account-form/historical-pix-account-form.component.js +29 -187
  15. package/esm2015/components/historical-pix-account/historical-pix-account.component.js +245 -20
  16. package/esm2015/components/historical-pix-account/historical-pix-account.module.js +5 -1
  17. package/esm2015/components/historical-pix-account/historical-pix-account.service.js +8 -1
  18. package/esm2015/components/historical-pix-account-list/historical-pix-account-list.component.js +45 -4
  19. package/esm2015/components/shared/index.js +2 -0
  20. package/esm2015/components/shared/shared-state.service.js +41 -0
  21. package/esm2015/components/utils/format-utils/format-utils.service.js +88 -5
  22. package/esm2015/public_api.js +2 -1
  23. package/esm2015/senior-gestao-pessoas-payroll-core.js +3 -2
  24. package/esm5/components/historical-pix-account/historical-pix-account-base.js +186 -0
  25. package/esm5/components/historical-pix-account/historical-pix-account-form/historical-pix-account-form.component.js +53 -201
  26. package/esm5/components/historical-pix-account/historical-pix-account.component.js +287 -49
  27. package/esm5/components/historical-pix-account/historical-pix-account.module.js +5 -1
  28. package/esm5/components/historical-pix-account/historical-pix-account.service.js +8 -1
  29. package/esm5/components/historical-pix-account-list/historical-pix-account-list.component.js +50 -4
  30. package/esm5/components/shared/index.js +2 -0
  31. package/esm5/components/shared/shared-state.service.js +42 -0
  32. package/esm5/components/utils/format-utils/format-utils.service.js +88 -5
  33. package/esm5/public_api.js +2 -1
  34. package/esm5/senior-gestao-pessoas-payroll-core.js +3 -2
  35. package/fesm2015/senior-gestao-pessoas-payroll-core.js +880 -477
  36. package/fesm2015/senior-gestao-pessoas-payroll-core.js.map +1 -1
  37. package/fesm5/senior-gestao-pessoas-payroll-core.js +1210 -767
  38. package/fesm5/senior-gestao-pessoas-payroll-core.js.map +1 -1
  39. package/package.json +2 -32
  40. package/public_api.d.ts +1 -0
  41. package/senior-gestao-pessoas-payroll-core.d.ts +2 -1
  42. package/senior-gestao-pessoas-payroll-core.metadata.json +1 -1
@@ -0,0 +1,27 @@
1
+ import { FormBuilder, FormGroup, ValidatorFn } from "@angular/forms";
2
+ export declare abstract class HistoricakPixAccountBase {
3
+ protected formBuilder: FormBuilder;
4
+ protected _paramsForm: FormGroup;
5
+ protected _defaultCpfNumber: string;
6
+ initialValidatorOfPercentage: ValidatorFn[];
7
+ pixAccountList: object[];
8
+ maxValuePercentage: number;
9
+ pixKeyType: string;
10
+ pixAccountFormGroup: FormGroup;
11
+ isShowPixKeyFieldValidatorMessage: boolean;
12
+ constructor(formBuilder: FormBuilder);
13
+ phoneMask(event: any): void;
14
+ cpfMask(event: any): void;
15
+ cnpjMask(event: any): void;
16
+ onChangePixKeyType(item: any, form?: FormGroup): void;
17
+ onClearPixKeyType(form?: FormGroup): void;
18
+ setDefaultCpfPixKey(form?: FormGroup): void;
19
+ protected createFormGroupBase(): void;
20
+ protected setValidatorsAccordingList(pixAccountList: object[], index?: number | null, isEditMode?: boolean, form?: FormGroup): void;
21
+ protected beforeSetPixKeyTypeValidator(form: FormGroup): void;
22
+ protected setPixKeyValidators(isEditMode: boolean, form: FormGroup): void;
23
+ protected validatePercentageValid(listValue: number[], form: FormGroup): void;
24
+ private validateDuplicatePixKeyTypeBankAccount;
25
+ paramsForm: FormGroup;
26
+ defaultCpfNumber: string;
27
+ }
@@ -1,39 +1,32 @@
1
1
  import { OnInit, EventEmitter, ChangeDetectorRef, OnDestroy, AfterViewInit } from "@angular/core";
2
2
  import { FormGroup, FormBuilder } from "@angular/forms";
3
3
  import { NumberLocaleOptions, CustomFieldsComponent } from "@seniorsistemas/angular-components";
4
- export declare class HistoricalPixAccountFormComponent implements OnInit, OnDestroy, AfterViewInit {
5
- private formBuilder;
4
+ import { SharedStateService } from "../../shared/shared-state.service";
5
+ import { HistoricakPixAccountBase } from "../historical-pix-account-base";
6
+ export declare class HistoricalPixAccountFormComponent extends HistoricakPixAccountBase implements OnInit, OnDestroy, AfterViewInit {
6
7
  private cd;
8
+ private sharedStateService;
7
9
  customFields: CustomFieldsComponent;
8
10
  currency: NumberLocaleOptions;
9
11
  customEntity: string;
10
12
  customService: string;
11
13
  withSideBar: boolean;
12
14
  isEditMode: boolean;
13
- paramsForm: FormGroup;
14
- defaultCpfNumber: string;
15
15
  visibleChange: EventEmitter<boolean>;
16
16
  pixAccountItemToList: EventEmitter<any>;
17
17
  private _visible;
18
18
  private ngUnsubscribe;
19
19
  private employeeId;
20
- private pixAccountList;
21
- private initialValidatorOfPercentage;
22
20
  labelBtnAdd: string;
23
- pixAccountFormGroup: FormGroup;
24
- maxValuePercentage: number;
25
21
  visibleBtnSave: boolean;
26
22
  isView: boolean;
27
- pixKeyType: string;
28
23
  isShowPixKeyFieldValidatorMessage: boolean;
29
- constructor(formBuilder: FormBuilder, cd: ChangeDetectorRef);
24
+ hideFields: import("rxjs").Observable<boolean>;
25
+ constructor(formBuilder: FormBuilder, cd: ChangeDetectorRef, sharedStateService: SharedStateService);
30
26
  ngOnInit(): void;
31
27
  ngAfterViewInit(): void;
32
28
  ngOnDestroy(): void;
33
29
  private registerSubjects;
34
- private createFormGroup;
35
- onChangePixKeyType(item: any): void;
36
- onClearPixKeyType(): void;
37
30
  visible: boolean;
38
31
  isEditAndViewValue: any;
39
32
  private formatPixKeyTelephoneNumber;
@@ -45,33 +38,8 @@ export declare class HistoricalPixAccountFormComponent implements OnInit, OnDest
45
38
  readonly percentagePlaceholder: string;
46
39
  readonly optionsPercentage: object;
47
40
  private getOptions;
48
- /**
49
- * O Input que recebe a lista do component pai e chama o método de validação passando a lista recebida.
50
- * @param pixAccountList
51
- */
52
41
  getListPixAccount: object[];
53
- /**
54
- * Recebe a lista de registros já inseridos na tabela adiciona em uma variável os valores que serão usados para
55
- * a validação dos campos "percentage" e "pixAccount".
56
- * Quando tem index significa que está em uma edição, os valores na posição do registro da edição (index) não serão adicionados
57
- * no array de comparação dos validators.
58
- * @param pixAccountList
59
- * @param index
60
- */
61
- private setValidatorsAccordingList;
62
- /**
63
- * Antes de setar o validator prepara as variáveis necessária para que seja feita a validação do campo.
64
- */
65
- setPixKeyValidators(isEditMode: boolean): void;
66
- /**
67
- * Este método calcula as parcentagens que já foram inseridas, e seta a diferença para chegar em
68
- * 100% na validação do campo "percentage" como um novo maxValue;
69
- * @param listValue
70
- */
71
- private validatePercentageValid;
72
42
  isViewMode: boolean;
73
- phoneMask(event: any): void;
74
- setDefaultCpfPixKey(): void;
75
- beforeSetPixKeyTypeValidator(): void;
76
- private validateDuplicatePixKeyTypeBankAccount;
43
+ paramsForm: FormGroup;
44
+ defaultCpfNumber: string;
77
45
  }
@@ -2,13 +2,16 @@ import { OnInit, ChangeDetectorRef, AfterViewInit, OnDestroy, EventEmitter, OnCh
2
2
  import { FormGroup, FormBuilder } from "@angular/forms";
3
3
  import { TranslateService } from "@ngx-translate/core";
4
4
  import { CustomFieldsComponent, NumberLocaleOptions } from "@seniorsistemas/angular-components";
5
- import { MessageService } from "primeng/api";
6
- export declare class HistoricalPixAccountComponent implements OnInit, OnDestroy, AfterViewInit, OnChanges {
5
+ import { SharedStateService } from "../shared/shared-state.service";
6
+ import { HistoricakPixAccountBase } from "./historical-pix-account-base";
7
+ import { HistoricalPixAccountService } from "./historical-pix-account.service";
8
+ export declare class HistoricalPixAccountComponent extends HistoricakPixAccountBase implements OnInit, OnDestroy, AfterViewInit, OnChanges {
7
9
  private translateService;
8
10
  private cd;
9
- private formBuilder;
10
- private messageService;
11
+ private sharedStateService;
12
+ private service;
11
13
  customFields: CustomFieldsComponent;
14
+ dataListPix: any;
12
15
  formGroup: FormGroup;
13
16
  fieldFormGroup: string;
14
17
  _dateChange: string;
@@ -22,13 +25,15 @@ export declare class HistoricalPixAccountComponent implements OnInit, OnDestroy,
22
25
  customEntity: string;
23
26
  customService: string;
24
27
  withSideBar: boolean;
25
- paramsForm: FormGroup;
26
- defaultCpfNumber: string;
27
28
  permission: object;
28
29
  listDataReciever: any[];
30
+ addExistentHistoricData: any[];
31
+ getListPixAccount: object[];
32
+ isEditModeForSave: boolean;
29
33
  isViewModeActive: EventEmitter<any>;
30
34
  isEditModeActive: EventEmitter<any>;
31
35
  isDeleteModeActive: EventEmitter<any>;
36
+ isValidChangeForm: EventEmitter<boolean>;
32
37
  private listFromApp;
33
38
  private visibleChange;
34
39
  private ngUnsubscribe;
@@ -43,6 +48,14 @@ export declare class HistoricalPixAccountComponent implements OnInit, OnDestroy,
43
48
  msgTotalLimitByPercentage: string;
44
49
  listData: object[];
45
50
  listDataNoPage: object[];
51
+ showButtonView: boolean;
52
+ showEditMode: boolean;
53
+ hasRecordsPix: boolean;
54
+ hideFields: import("rxjs").Observable<boolean>;
55
+ suggestions: any[];
56
+ formGroupByRow: {
57
+ [index: number]: FormGroup;
58
+ };
46
59
  cols: {
47
60
  label: any;
48
61
  field: string;
@@ -52,24 +65,37 @@ export declare class HistoricalPixAccountComponent implements OnInit, OnDestroy,
52
65
  label: any;
53
66
  command: () => void;
54
67
  }[];
55
- constructor(translateService: TranslateService, cd: ChangeDetectorRef, formBuilder: FormBuilder, messageService: MessageService);
68
+ constructor(translateService: TranslateService, cd: ChangeDetectorRef, formBuilder: FormBuilder, sharedStateService: SharedStateService, service: HistoricalPixAccountService);
56
69
  ngOnInit(): void;
57
70
  ngOnChanges(changes: SimpleChanges): void;
58
71
  private createFormGroup;
59
72
  ngOnDestroy(): void;
60
73
  ngAfterViewInit(): void;
74
+ private emitFormValidity;
75
+ filterPixKeyType(event: any): void;
76
+ createPixRowFormGroup(): FormGroup;
77
+ onPixKeyInput(event: any, index: number): void;
78
+ onBlurPixCpfAndCnpj(index: number): void;
79
+ getFormattedPixKey(type: string, value: string): string;
80
+ syncPixDataToParentForm(): void;
81
+ syncResetPixFormToParent(): void;
61
82
  onLazyLoad(event?: any): void;
62
83
  /**
63
84
  * Um Bug de CSS que acontece nas linhas da tabela, que resolve só atualizando qualquer parte do CSS da pagina.
64
85
  */
65
86
  private refreshCssInIE11;
66
87
  add(): void;
67
- private isNotAllowMessage;
88
+ addPix(): void;
89
+ deletePix(index: number): void;
90
+ private rebuildFormGroupMap;
91
+ onPixKeyTypeChange(item: any, index: number): void;
92
+ onPixKeyTypeClear(index: number): void;
68
93
  private deleteAnnuityItem;
69
94
  getHistoricalPixAccountList(): object[];
70
95
  addItemInList($event: any): void;
71
96
  private getNumberPageByIndex;
72
97
  private verifyTotalPercentage;
98
+ onSyncValue(field: string, index: number): void;
73
99
  readonly scopedActions: any;
74
100
  readonly recordsMessage: string;
75
101
  readonly getTooltipAndDisableButtonAdd: string;
@@ -77,6 +103,8 @@ export declare class HistoricalPixAccountComponent implements OnInit, OnDestroy,
77
103
  displayDateChange: string;
78
104
  addListData: object[];
79
105
  visible: boolean;
106
+ paramsForm: FormGroup;
107
+ defaultCpfNumber: string;
80
108
  close(): void;
81
109
  getFormattedTelephoneNumber(telephoneNumber: string): string;
82
110
  getFormattedCpf(cpf: string): string;
@@ -5,4 +5,5 @@ export declare class HistoricalPixAccountService {
5
5
  private http;
6
6
  constructor(http: HttpClientService);
7
7
  query(path: string, body: object, service?: ServiceType): Observable<any>;
8
+ enumQuery(): Observable<any>;
8
9
  }
@@ -3,7 +3,9 @@ import { ActivatedRoute, Router } from "@angular/router";
3
3
  import { TranslateService } from "@ngx-translate/core";
4
4
  import { CustomFieldsComponent } from "@seniorsistemas/angular-components";
5
5
  import { ConfirmationService, MessageService } from "primeng/api";
6
+ import { Subject } from "rxjs";
6
7
  import { HistoricalPixAccountListService } from "./historical-pix-account-list.service";
8
+ import { SharedStateService } from "../shared/shared-state.service";
7
9
  export declare class HistoricalPixAccountListComponent implements OnInit, OnDestroy, AfterViewInit {
8
10
  private confirmationService;
9
11
  private translateService;
@@ -12,6 +14,7 @@ export declare class HistoricalPixAccountListComponent implements OnInit, OnDest
12
14
  private router;
13
15
  private messageService;
14
16
  private historicalPixAccountListService;
17
+ private sharedStateService;
15
18
  customFields: CustomFieldsComponent;
16
19
  permission: object;
17
20
  employeeId: string;
@@ -20,10 +23,14 @@ export declare class HistoricalPixAccountListComponent implements OnInit, OnDest
20
23
  endPoint: string;
21
24
  keyPayload: string;
22
25
  withSidebar: boolean;
26
+ hideField: boolean;
23
27
  isOnlyView: EventEmitter<any>;
28
+ isOnlyEdit: EventEmitter<any>;
24
29
  enableView: EventEmitter<any>;
30
+ isEditJudicialDependentPix: EventEmitter<any>;
25
31
  private lastRecord;
26
32
  private ngUnsubscribe;
33
+ private _subscription;
27
34
  initParameters: any;
28
35
  loading: boolean;
29
36
  parameters: any;
@@ -31,7 +38,7 @@ export declare class HistoricalPixAccountListComponent implements OnInit, OnDest
31
38
  label: any;
32
39
  field: string;
33
40
  }[];
34
- constructor(confirmationService: ConfirmationService, translateService: TranslateService, activatedRoute: ActivatedRoute, cd: ChangeDetectorRef, router: Router, messageService: MessageService, historicalPixAccountListService: HistoricalPixAccountListService);
41
+ constructor(confirmationService: ConfirmationService, translateService: TranslateService, activatedRoute: ActivatedRoute, cd: ChangeDetectorRef, router: Router, messageService: MessageService, historicalPixAccountListService: HistoricalPixAccountListService, sharedStateService: SharedStateService);
35
42
  ngOnInit(): void;
36
43
  ngOnDestroy(): void;
37
44
  ngAfterViewInit(): void;
@@ -44,6 +51,8 @@ export declare class HistoricalPixAccountListComponent implements OnInit, OnDest
44
51
  add(): void;
45
52
  private isNotAllowMessage;
46
53
  private onGridLoad;
54
+ private unsubscribe;
55
+ hideFieldsOnAdd$: Subject<boolean>;
47
56
  private readonly isAllowToAddHistorical;
48
57
  private readonly isAllowToDeleteHistorical;
49
58
  private readonly isAllowToViewHistorical;
@@ -0,0 +1 @@
1
+ export * from './shared-state.service';
@@ -0,0 +1,17 @@
1
+ export declare class SharedStateService {
2
+ private hideFieldSubject;
3
+ hideField$: import("rxjs").Observable<boolean>;
4
+ private showButtonSubject;
5
+ showButton$: import("rxjs").Observable<boolean>;
6
+ private saveButtonSubject;
7
+ saveButton$: import("rxjs").Observable<boolean>;
8
+ private showEditMode;
9
+ showEditMode$: import("rxjs").Observable<boolean>;
10
+ private activeValidatorsOnEditModalOpen;
11
+ activeValidatorsOnEditModalOpen$: import("rxjs").Observable<void>;
12
+ setHideField(value: boolean): void;
13
+ setShowButton(value: boolean): void;
14
+ setSaveButton(value: boolean): void;
15
+ setShowEditMode(value: boolean): void;
16
+ triggerActiveValidatorsOnEditModalOpen(): void;
17
+ }
@@ -4,30 +4,57 @@ export declare class FormatUtilsService {
4
4
  * @param cpf CPF
5
5
  */
6
6
  static getFormattedCpf(cpf: string): string;
7
+ /**
8
+ * Retorna o CPF formatado
9
+ * @param cpf CPF
10
+ */
11
+ static getFormattedCpfEdited(cpf: string): string;
7
12
  /**
8
13
  * Retorna o CNPJ formatado
9
14
  * @param cnpj CNPJ
10
15
  */
11
16
  static getFormattedCnpj(cnpj: string): string;
17
+ /**
18
+ * Retorna o CNPJ formatado
19
+ * @param cnpj CNPJ
20
+ */
21
+ static getFormattedCnpjEdited(cnpj: string): string;
12
22
  /**
13
23
  * Retorna a mascara do CPF/CNPJ
14
24
  * @param key Valores possíveis são CPF ou CNPJ
15
25
  */
16
26
  static getCpfCnpjMask(key: string): "" | "999.999.999-99" | "99.999.999/9999-99";
27
+ /**
28
+ * Método para formatar o número de inscrição do cliente.
29
+ * @param subscriptionNumber
30
+ * @param pixKeyType
31
+ * @returns
32
+ */
33
+ static getFormattedSubscriptionNumber(subscriptionNumber: string, pixKeyType: any): string;
17
34
  /**
18
35
  * Metódo para formatar o número de telefone.
19
36
  * @param telephoneNumber String contendo o número de telefone.
20
37
  * @returns String formatada com o número de telefone.
21
38
  */
22
39
  static getFormattedTelephoneNumber(telephoneNumber: string): string;
40
+ /**
41
+ * Metódo para formatar a porcentagem para 2 casas decimais.
42
+ * @param value Número a ser formatado.
43
+ */
44
+ static getFormattedPercentage(value: string): string;
23
45
  /**
24
46
  * Metódo para formatar o número de telefone de um campo Input.
25
47
  * @param event Evento do Input do campo de telefone.
26
48
  */
27
49
  static formatTelephoneInputEvent(event: any): void;
28
50
  /**
29
- * Metódo para formatar a porcentagem para 2 casas decimais.
30
- * @param value Número a ser formatado.
51
+ * Formata o campo de input de CPF em tempo real.
52
+ * @param event Evento do input
31
53
  */
32
- static getFormattedPercentage(value: string): string;
54
+ static formatCpfInputEvent(event: any): void;
55
+ /**
56
+ * Formata o campo de input de CNPJ em tempo real.
57
+ * @param event Evento do input
58
+ */
59
+ static formatCnpjInputEvent(event: any): void;
33
60
  }
@@ -0,0 +1,173 @@
1
+ import { FormGroup, Validators, } from "@angular/forms";
2
+ import { GenericValidator } from "../utils/generic-validators";
3
+ import { FormatUtilsService } from "../utils/format-utils/format-utils.service";
4
+ export class HistoricakPixAccountBase {
5
+ constructor(formBuilder) {
6
+ this._paramsForm = new FormGroup({});
7
+ this._defaultCpfNumber = null;
8
+ this.initialValidatorOfPercentage = [Validators.required, Validators.min(0.01)];
9
+ this.pixAccountList = [];
10
+ this.maxValuePercentage = 100.0;
11
+ this.isShowPixKeyFieldValidatorMessage = false;
12
+ this.formBuilder = formBuilder;
13
+ this.createFormGroupBase();
14
+ }
15
+ phoneMask(event) {
16
+ FormatUtilsService.formatTelephoneInputEvent(event);
17
+ }
18
+ cpfMask(event) {
19
+ FormatUtilsService.formatCpfInputEvent(event);
20
+ }
21
+ cnpjMask(event) {
22
+ FormatUtilsService.formatCnpjInputEvent(event);
23
+ }
24
+ onChangePixKeyType(item, form) {
25
+ if (!item || !item.key)
26
+ return;
27
+ this.pixKeyType = item.key;
28
+ const targetForm = (typeof form !== 'undefined' && form !== null)
29
+ ? form
30
+ : this.pixAccountFormGroup;
31
+ this.isShowPixKeyFieldValidatorMessage = true;
32
+ const pixKeyControl = targetForm.get("pixKey");
33
+ if (pixKeyControl) {
34
+ pixKeyControl.reset();
35
+ }
36
+ this.setPixKeyValidators(true, targetForm);
37
+ if (item.key === "CPF") {
38
+ this.setDefaultCpfPixKey(targetForm);
39
+ }
40
+ }
41
+ onClearPixKeyType(form) {
42
+ var targetForm = (typeof form !== 'undefined' && form !== null)
43
+ ? form
44
+ : this.pixAccountFormGroup;
45
+ this.isShowPixKeyFieldValidatorMessage = false;
46
+ if (targetForm.get("pixKey")) {
47
+ targetForm.get("pixKey").reset();
48
+ }
49
+ }
50
+ setDefaultCpfPixKey(form) {
51
+ var targetForm = (typeof form !== 'undefined' && form !== null)
52
+ ? form
53
+ : this.pixAccountFormGroup;
54
+ if (this._defaultCpfNumber) {
55
+ if (targetForm.get("pixKey")) {
56
+ targetForm.get("pixKey").setValue(this._defaultCpfNumber);
57
+ }
58
+ }
59
+ else {
60
+ var sheetDocument = this._paramsForm.get("sheetDocument");
61
+ if (sheetDocument && sheetDocument.get("cpfNumber")) {
62
+ var cpf = sheetDocument.get("cpfNumber").value;
63
+ if (cpf && targetForm.get("pixKey")) {
64
+ targetForm.get("pixKey").setValue(cpf);
65
+ }
66
+ }
67
+ }
68
+ }
69
+ createFormGroupBase() {
70
+ this.pixAccountFormGroup = this.formBuilder.group({
71
+ id: this.formBuilder.control(null),
72
+ index: this.formBuilder.control(null),
73
+ employee: this.formBuilder.control({ value: { tableId: null }, disabled: true }),
74
+ dateChange: this.formBuilder.control(null),
75
+ pixKeyType: this.formBuilder.control(null, Validators.required),
76
+ pixKey: this.formBuilder.control(null),
77
+ percentage: this.formBuilder.control(null, Validators.compose([
78
+ ...this.initialValidatorOfPercentage,
79
+ Validators.max(this.maxValuePercentage),
80
+ ])),
81
+ externalId: this.formBuilder.control(null),
82
+ customFields: this.formBuilder.control(null),
83
+ });
84
+ }
85
+ setValidatorsAccordingList(pixAccountList, index = null, isEditMode = true, form) {
86
+ var targetForm = (typeof form !== 'undefined' && form !== null)
87
+ ? form
88
+ : this.pixAccountFormGroup;
89
+ this.pixAccountList = (pixAccountList && pixAccountList.length > 0)
90
+ ? [].concat(pixAccountList)
91
+ : [];
92
+ var percentageIncluded = [];
93
+ for (var i = 0; i < this.pixAccountList.length; i++) {
94
+ var field = this.pixAccountList[i];
95
+ if (field && field.percentage && i !== index) {
96
+ percentageIncluded.push(field.percentage);
97
+ }
98
+ }
99
+ this.beforeSetPixKeyTypeValidator(targetForm);
100
+ this.setPixKeyValidators(isEditMode, targetForm);
101
+ this.validatePercentageValid(percentageIncluded, targetForm);
102
+ }
103
+ beforeSetPixKeyTypeValidator(form) {
104
+ const control = form.get("pixKeyType");
105
+ if (this.pixAccountList && this.pixAccountList.length) {
106
+ control.setValidators(Validators.compose([
107
+ Validators.required,
108
+ this.validateDuplicatePixKeyTypeBankAccount(this.pixAccountList),
109
+ ]));
110
+ }
111
+ else {
112
+ control.setValidators(Validators.required);
113
+ }
114
+ control.updateValueAndValidity();
115
+ }
116
+ setPixKeyValidators(isEditMode, form) {
117
+ const pixKey = form.get("pixKey");
118
+ switch (this.pixKeyType) {
119
+ case "TELEPHONE":
120
+ pixKey.setValidators(Validators.compose([Validators.required, GenericValidator.isValidPhoneNumber]));
121
+ break;
122
+ case "EMAIL":
123
+ pixKey.setValidators(Validators.compose([Validators.required, GenericValidator.isValidEmail]));
124
+ break;
125
+ case "CPF":
126
+ pixKey.setValidators(Validators.compose([Validators.required, GenericValidator.isValidCpf]));
127
+ break;
128
+ case "CNPJ":
129
+ pixKey.setValidators(Validators.compose([Validators.required, GenericValidator.isValidCnpj]));
130
+ break;
131
+ case "RANDOM_KEY":
132
+ pixKey.setValidators(Validators.required);
133
+ break;
134
+ default:
135
+ pixKey.clearValidators();
136
+ }
137
+ if (isEditMode) {
138
+ pixKey.enable();
139
+ }
140
+ pixKey.updateValueAndValidity();
141
+ }
142
+ validatePercentageValid(listValue, form) {
143
+ const percentage = form.get("percentage");
144
+ this.maxValuePercentage = listValue.reduce((acc, val) => acc - val, 100.0);
145
+ percentage.setValidators(Validators.compose([
146
+ ...this.initialValidatorOfPercentage,
147
+ Validators.max(this.maxValuePercentage),
148
+ ]));
149
+ percentage.updateValueAndValidity();
150
+ }
151
+ validateDuplicatePixKeyTypeBankAccount(listCompare) {
152
+ return (control) => {
153
+ const value = control.value;
154
+ const isDuplicate = listCompare.some((field) => value &&
155
+ field.pixKeyType.key === "BANK_ACCOUNT" &&
156
+ value.key === "BANK_ACCOUNT");
157
+ return isDuplicate ? { pixKeyTypeBankAccountDuplicate: true } : null;
158
+ };
159
+ }
160
+ get paramsForm() {
161
+ return this._paramsForm;
162
+ }
163
+ set paramsForm(value) {
164
+ this._paramsForm = value;
165
+ }
166
+ get defaultCpfNumber() {
167
+ return this._defaultCpfNumber;
168
+ }
169
+ set defaultCpfNumber(value) {
170
+ this._defaultCpfNumber = value;
171
+ }
172
+ }
173
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"historical-pix-account-base.js","sourceRoot":"ng://@senior-gestao-pessoas/payroll-core/","sources":["components/historical-pix-account/historical-pix-account-base.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AbstractControl,\n    FormBuilder,\n    FormGroup,\n    ValidatorFn,\n    Validators,\n  } from \"@angular/forms\";\n  import { GenericValidator } from \"../utils/generic-validators\";\n  import { FormatUtilsService } from \"../utils/format-utils/format-utils.service\";\n\n  export abstract class HistoricakPixAccountBase {\n    protected formBuilder: FormBuilder;\n    protected _paramsForm: FormGroup = new FormGroup({});\n    protected _defaultCpfNumber: string = null;\n\n    public initialValidatorOfPercentage: ValidatorFn[] = [Validators.required, Validators.min(0.01)];\n    public pixAccountList: object[] = [];\n    public maxValuePercentage = 100.0;\n    public pixKeyType: string;\n    public pixAccountFormGroup: FormGroup;\n    public isShowPixKeyFieldValidatorMessage = false;\n\n    constructor(formBuilder: FormBuilder) {\n      this.formBuilder = formBuilder;\n      this.createFormGroupBase();\n    }\n\n    public phoneMask(event: any): void {\n        FormatUtilsService.formatTelephoneInputEvent(event);\n    }\n\n    public cpfMask(event: any): void {\n        FormatUtilsService.formatCpfInputEvent(event);\n    }\n\n    public cnpjMask(event: any): void {\n        FormatUtilsService.formatCnpjInputEvent(event);\n    }\n\n    public onChangePixKeyType(item: any, form?: FormGroup): void {\n        if (!item || !item.key) return;\n\n        this.pixKeyType = item.key;\n\n        const targetForm = (typeof form !== 'undefined' && form !== null)\n          ? form\n          : this.pixAccountFormGroup;\n\n        this.isShowPixKeyFieldValidatorMessage = true;\n\n        const pixKeyControl = targetForm.get(\"pixKey\");\n        if (pixKeyControl) {\n            pixKeyControl.reset();\n        }\n\n        this.setPixKeyValidators(true, targetForm);\n\n        if (item.key === \"CPF\") {\n          this.setDefaultCpfPixKey(targetForm);\n        }\n    }\n\n    public onClearPixKeyType(form?: FormGroup): void {\n        var targetForm = (typeof form !== 'undefined' && form !== null)\n          ? form\n          : this.pixAccountFormGroup;\n\n        this.isShowPixKeyFieldValidatorMessage = false;\n\n        if (targetForm.get(\"pixKey\")) {\n          targetForm.get(\"pixKey\").reset();\n        }\n      }\n\n      public setDefaultCpfPixKey(form?: FormGroup): void {\n        var targetForm = (typeof form !== 'undefined' && form !== null)\n          ? form\n          : this.pixAccountFormGroup;\n\n        if (this._defaultCpfNumber) {\n          if (targetForm.get(\"pixKey\")) {\n            targetForm.get(\"pixKey\").setValue(this._defaultCpfNumber);\n          }\n        } else {\n          var sheetDocument = this._paramsForm.get(\"sheetDocument\");\n          if (sheetDocument && sheetDocument.get(\"cpfNumber\")) {\n            var cpf = sheetDocument.get(\"cpfNumber\").value;\n            if (cpf && targetForm.get(\"pixKey\")) {\n              targetForm.get(\"pixKey\").setValue(cpf);\n            }\n          }\n        }\n    }\n\n    protected createFormGroupBase(): void {\n      this.pixAccountFormGroup = this.formBuilder.group({\n        id: this.formBuilder.control(null),\n        index: this.formBuilder.control(null),\n        employee: this.formBuilder.control({ value: { tableId: null }, disabled: true }),\n        dateChange: this.formBuilder.control(null),\n        pixKeyType: this.formBuilder.control(null, Validators.required),\n        pixKey: this.formBuilder.control(null),\n        percentage: this.formBuilder.control(\n          null,\n          Validators.compose([\n            ...this.initialValidatorOfPercentage,\n            Validators.max(this.maxValuePercentage),\n          ])\n        ),\n        externalId: this.formBuilder.control(null),\n        customFields: this.formBuilder.control(null),\n      });\n    }\n\n    protected setValidatorsAccordingList(\n        pixAccountList: object[],\n        index: number | null = null,\n        isEditMode: boolean = true,\n        form?: FormGroup\n      ): void {\n        var targetForm = (typeof form !== 'undefined' && form !== null)\n          ? form\n          : this.pixAccountFormGroup;\n\n        this.pixAccountList = (pixAccountList && pixAccountList.length > 0)\n          ? [].concat(pixAccountList)\n          : [];\n\n        var percentageIncluded: number[] = [];\n\n        for (var i = 0; i < this.pixAccountList.length; i++) {\n          var field: any = this.pixAccountList[i];\n          if (field && field.percentage && i !== index) {\n            percentageIncluded.push(field.percentage);\n          }\n        }\n\n        this.beforeSetPixKeyTypeValidator(targetForm);\n        this.setPixKeyValidators(isEditMode, targetForm);\n        this.validatePercentageValid(percentageIncluded, targetForm);\n    }\n\n    protected beforeSetPixKeyTypeValidator(form: FormGroup): void {\n      const control = form.get(\"pixKeyType\");\n\n      if (this.pixAccountList && this.pixAccountList.length) {\n        control.setValidators(\n          Validators.compose([\n            Validators.required,\n            this.validateDuplicatePixKeyTypeBankAccount(this.pixAccountList),\n          ])\n        );\n      } else {\n        control.setValidators(Validators.required);\n      }\n      control.updateValueAndValidity();\n    }\n\n    protected setPixKeyValidators(isEditMode: boolean, form: FormGroup): void {\n      const pixKey = form.get(\"pixKey\");\n      switch (this.pixKeyType) {\n        case \"TELEPHONE\":\n          pixKey.setValidators(Validators.compose([Validators.required, GenericValidator.isValidPhoneNumber]));\n          break;\n        case \"EMAIL\":\n          pixKey.setValidators(Validators.compose([Validators.required, GenericValidator.isValidEmail]));\n          break;\n        case \"CPF\":\n          pixKey.setValidators(Validators.compose([Validators.required, GenericValidator.isValidCpf]));\n          break;\n        case \"CNPJ\":\n          pixKey.setValidators(Validators.compose([Validators.required, GenericValidator.isValidCnpj]));\n          break;\n        case \"RANDOM_KEY\":\n          pixKey.setValidators(Validators.required);\n          break;\n        default:\n          pixKey.clearValidators();\n      }\n\n      if (isEditMode) {\n        pixKey.enable();\n      }\n\n      pixKey.updateValueAndValidity();\n    }\n\n    protected validatePercentageValid(listValue: number[], form: FormGroup): void {\n      const percentage = form.get(\"percentage\");\n      this.maxValuePercentage = listValue.reduce((acc, val) => acc - val, 100.0);\n\n      percentage.setValidators(\n        Validators.compose([\n          ...this.initialValidatorOfPercentage,\n          Validators.max(this.maxValuePercentage),\n        ])\n      );\n\n      percentage.updateValueAndValidity();\n    }\n\n    private validateDuplicatePixKeyTypeBankAccount(listCompare: object[]) {\n      return (control: AbstractControl): { [key: string]: any } | null => {\n        const value = control.value;\n        const isDuplicate = listCompare.some(\n          (field: any) =>\n            value &&\n            field.pixKeyType.key === \"BANK_ACCOUNT\" &&\n            value.key === \"BANK_ACCOUNT\"\n        );\n        return isDuplicate ? { pixKeyTypeBankAccountDuplicate: true } : null;\n      };\n    }\n\n    public get paramsForm(): FormGroup {\n      return this._paramsForm;\n    }\n\n    public set paramsForm(value: FormGroup) {\n      this._paramsForm = value;\n    }\n\n    public get defaultCpfNumber(): string {\n      return this._defaultCpfNumber;\n    }\n\n    public set defaultCpfNumber(value: string) {\n      this._defaultCpfNumber = value;\n    }\n  }\n"]}