@senior-gestao-pessoas/payroll-core 9.4.0-beccc0e0-72b8-4a99-8127-32ad8ca6ee41 → 9.4.0-db1d034b-8b09-472f-9726-7fd71af961f4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/senior-gestao-pessoas-payroll-core.umd.js +921 -761
- package/bundles/senior-gestao-pessoas-payroll-core.umd.js.map +1 -1
- package/bundles/senior-gestao-pessoas-payroll-core.umd.min.js +16 -1
- package/bundles/senior-gestao-pessoas-payroll-core.umd.min.js.map +1 -1
- package/components/historical-pix-account/historical-pix-account-base.d.ts +25 -0
- package/components/historical-pix-account/historical-pix-account-form/historical-pix-account-form.component.d.ts +8 -40
- package/components/historical-pix-account/historical-pix-account.component.d.ts +23 -6
- package/components/historical-pix-account/historical-pix-account.service.d.ts +1 -0
- package/components/historical-pix-account-list/historical-pix-account-list.component.d.ts +9 -1
- package/components/shared/index.d.ts +1 -0
- package/components/shared/shared-state.service.d.ts +14 -0
- package/esm2015/components/historical-pix-account/historical-pix-account-base.js +150 -0
- package/esm2015/components/historical-pix-account/historical-pix-account-form/historical-pix-account-form.component.js +29 -187
- package/esm2015/components/historical-pix-account/historical-pix-account.component.js +79 -18
- package/esm2015/components/historical-pix-account/historical-pix-account.module.js +5 -1
- package/esm2015/components/historical-pix-account/historical-pix-account.service.js +8 -1
- package/esm2015/components/historical-pix-account-list/historical-pix-account-list.component.js +38 -5
- package/esm2015/components/shared/index.js +2 -0
- package/esm2015/components/shared/shared-state.service.js +36 -0
- package/esm2015/public_api.js +2 -1
- package/esm2015/senior-gestao-pessoas-payroll-core.js +3 -2
- package/esm5/components/historical-pix-account/historical-pix-account-base.js +163 -0
- package/esm5/components/historical-pix-account/historical-pix-account-form/historical-pix-account-form.component.js +53 -201
- package/esm5/components/historical-pix-account/historical-pix-account.component.js +122 -48
- package/esm5/components/historical-pix-account/historical-pix-account.module.js +5 -1
- package/esm5/components/historical-pix-account/historical-pix-account.service.js +8 -1
- package/esm5/components/historical-pix-account-list/historical-pix-account-list.component.js +43 -5
- package/esm5/components/shared/index.js +2 -0
- package/esm5/components/shared/shared-state.service.js +37 -0
- package/esm5/public_api.js +2 -1
- package/esm5/senior-gestao-pessoas-payroll-core.js +3 -2
- package/fesm2015/senior-gestao-pessoas-payroll-core.js +576 -457
- package/fesm2015/senior-gestao-pessoas-payroll-core.js.map +1 -1
- package/fesm5/senior-gestao-pessoas-payroll-core.js +917 -758
- package/fesm5/senior-gestao-pessoas-payroll-core.js.map +1 -1
- package/package.json +1 -1
- package/public_api.d.ts +1 -0
- package/senior-gestao-pessoas-payroll-core.d.ts +2 -1
- package/senior-gestao-pessoas-payroll-core.metadata.json +1 -1
|
@@ -0,0 +1,25 @@
|
|
|
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
|
+
onChangePixKeyType(item: any): void;
|
|
15
|
+
onClearPixKeyType(): void;
|
|
16
|
+
setDefaultCpfPixKey(): void;
|
|
17
|
+
protected createFormGroupBase(): void;
|
|
18
|
+
protected setValidatorsAccordingList(pixAccountList: object[], index?: number, isEditMode?: boolean): void;
|
|
19
|
+
protected beforeSetPixKeyTypeValidator(): void;
|
|
20
|
+
protected setPixKeyValidators(isEditMode: boolean): void;
|
|
21
|
+
protected validatePercentageValid(listValue: number[]): void;
|
|
22
|
+
private validateDuplicatePixKeyTypeBankAccount;
|
|
23
|
+
paramsForm: FormGroup;
|
|
24
|
+
defaultCpfNumber: string;
|
|
25
|
+
}
|
|
@@ -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
|
-
|
|
5
|
-
|
|
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
|
-
|
|
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
|
-
|
|
74
|
-
|
|
75
|
-
beforeSetPixKeyTypeValidator(): void;
|
|
76
|
-
private validateDuplicatePixKeyTypeBankAccount;
|
|
43
|
+
paramsForm: FormGroup;
|
|
44
|
+
defaultCpfNumber: string;
|
|
77
45
|
}
|
|
@@ -3,11 +3,15 @@ import { FormGroup, FormBuilder } from "@angular/forms";
|
|
|
3
3
|
import { TranslateService } from "@ngx-translate/core";
|
|
4
4
|
import { CustomFieldsComponent, NumberLocaleOptions } from "@seniorsistemas/angular-components";
|
|
5
5
|
import { MessageService } from "primeng/api";
|
|
6
|
-
|
|
6
|
+
import { SharedStateService } from "../shared/shared-state.service";
|
|
7
|
+
import { HistoricakPixAccountBase } from "./historical-pix-account-base";
|
|
8
|
+
import { HistoricalPixAccountService } from "./historical-pix-account.service";
|
|
9
|
+
export declare class HistoricalPixAccountComponent extends HistoricakPixAccountBase implements OnInit, OnDestroy, AfterViewInit, OnChanges {
|
|
7
10
|
private translateService;
|
|
8
11
|
private cd;
|
|
9
|
-
private formBuilder;
|
|
10
12
|
private messageService;
|
|
13
|
+
private sharedStateService;
|
|
14
|
+
private service;
|
|
11
15
|
customFields: CustomFieldsComponent;
|
|
12
16
|
formGroup: FormGroup;
|
|
13
17
|
fieldFormGroup: string;
|
|
@@ -22,10 +26,10 @@ export declare class HistoricalPixAccountComponent implements OnInit, OnDestroy,
|
|
|
22
26
|
customEntity: string;
|
|
23
27
|
customService: string;
|
|
24
28
|
withSideBar: boolean;
|
|
25
|
-
paramsForm: FormGroup;
|
|
26
|
-
defaultCpfNumber: string;
|
|
27
29
|
permission: object;
|
|
28
30
|
listDataReciever: any[];
|
|
31
|
+
addExistentHistoricData: any[];
|
|
32
|
+
getListPixAccount: object[];
|
|
29
33
|
isViewModeActive: EventEmitter<any>;
|
|
30
34
|
isEditModeActive: EventEmitter<any>;
|
|
31
35
|
isDeleteModeActive: EventEmitter<any>;
|
|
@@ -43,28 +47,39 @@ export declare class HistoricalPixAccountComponent implements OnInit, OnDestroy,
|
|
|
43
47
|
msgTotalLimitByPercentage: string;
|
|
44
48
|
listData: object[];
|
|
45
49
|
listDataNoPage: object[];
|
|
50
|
+
showButtonView: boolean;
|
|
51
|
+
showEditMode: boolean;
|
|
52
|
+
activeIndex: number;
|
|
53
|
+
hasRecordsPix: boolean;
|
|
54
|
+
firstPix: number;
|
|
55
|
+
maxValuePercentage: number;
|
|
56
|
+
hideFields: import("rxjs").Observable<boolean>;
|
|
57
|
+
suggestions: any[];
|
|
46
58
|
cols: {
|
|
47
59
|
label: any;
|
|
48
60
|
field: string;
|
|
61
|
+
orderBy: string;
|
|
49
62
|
}[];
|
|
50
63
|
actions: (rowData: any, key: any) => {
|
|
51
64
|
visible: boolean;
|
|
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, messageService: MessageService, 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
|
+
filterPixKeyType(event: any): void;
|
|
61
75
|
onLazyLoad(event?: any): void;
|
|
62
76
|
/**
|
|
63
77
|
* Um Bug de CSS que acontece nas linhas da tabela, que resolve só atualizando qualquer parte do CSS da pagina.
|
|
64
78
|
*/
|
|
65
79
|
private refreshCssInIE11;
|
|
66
80
|
add(): void;
|
|
67
|
-
|
|
81
|
+
addPix(): void;
|
|
82
|
+
deletePix(index: number): void;
|
|
68
83
|
private deleteAnnuityItem;
|
|
69
84
|
getHistoricalPixAccountList(): object[];
|
|
70
85
|
addItemInList($event: any): void;
|
|
@@ -77,6 +92,8 @@ export declare class HistoricalPixAccountComponent implements OnInit, OnDestroy,
|
|
|
77
92
|
displayDateChange: string;
|
|
78
93
|
addListData: object[];
|
|
79
94
|
visible: boolean;
|
|
95
|
+
paramsForm: FormGroup;
|
|
96
|
+
defaultCpfNumber: string;
|
|
80
97
|
close(): void;
|
|
81
98
|
getFormattedTelephoneNumber(telephoneNumber: string): string;
|
|
82
99
|
getFormattedCpf(cpf: string): string;
|
|
@@ -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,11 +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>;
|
|
24
28
|
isOnlyEdit: EventEmitter<any>;
|
|
25
29
|
enableView: EventEmitter<any>;
|
|
30
|
+
isEditJudicialDependentPix: EventEmitter<any>;
|
|
26
31
|
private lastRecord;
|
|
27
32
|
private ngUnsubscribe;
|
|
33
|
+
private _subscription;
|
|
28
34
|
initParameters: any;
|
|
29
35
|
loading: boolean;
|
|
30
36
|
parameters: any;
|
|
@@ -32,7 +38,7 @@ export declare class HistoricalPixAccountListComponent implements OnInit, OnDest
|
|
|
32
38
|
label: any;
|
|
33
39
|
field: string;
|
|
34
40
|
}[];
|
|
35
|
-
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);
|
|
36
42
|
ngOnInit(): void;
|
|
37
43
|
ngOnDestroy(): void;
|
|
38
44
|
ngAfterViewInit(): void;
|
|
@@ -45,6 +51,8 @@ export declare class HistoricalPixAccountListComponent implements OnInit, OnDest
|
|
|
45
51
|
add(): void;
|
|
46
52
|
private isNotAllowMessage;
|
|
47
53
|
private onGridLoad;
|
|
54
|
+
private unsubscribe;
|
|
55
|
+
hideFieldsOnAdd$: Subject<boolean>;
|
|
48
56
|
private readonly isAllowToAddHistorical;
|
|
49
57
|
private readonly isAllowToDeleteHistorical;
|
|
50
58
|
private readonly isAllowToViewHistorical;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './shared-state.service';
|
|
@@ -0,0 +1,14 @@
|
|
|
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
|
+
setHideField(value: boolean): void;
|
|
11
|
+
setShowButton(value: boolean): void;
|
|
12
|
+
setSaveButton(value: boolean): void;
|
|
13
|
+
setShowEditMode(value: boolean): void;
|
|
14
|
+
}
|
|
@@ -0,0 +1,150 @@
|
|
|
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.00;
|
|
11
|
+
this.isShowPixKeyFieldValidatorMessage = false;
|
|
12
|
+
this.formBuilder = formBuilder;
|
|
13
|
+
this.createFormGroupBase();
|
|
14
|
+
}
|
|
15
|
+
phoneMask(event) {
|
|
16
|
+
console.log("phoneMaskEvent", event);
|
|
17
|
+
FormatUtilsService.formatTelephoneInputEvent(event);
|
|
18
|
+
}
|
|
19
|
+
onChangePixKeyType(item) {
|
|
20
|
+
console.log("onChangePixKeyType", item);
|
|
21
|
+
if (item.key) {
|
|
22
|
+
this.pixKeyType = item.key;
|
|
23
|
+
this.isShowPixKeyFieldValidatorMessage = true;
|
|
24
|
+
this.pixAccountFormGroup.get("pixKey").reset();
|
|
25
|
+
this.setPixKeyValidators(true);
|
|
26
|
+
if (item.key === "CPF") {
|
|
27
|
+
this.setDefaultCpfPixKey();
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
onClearPixKeyType() {
|
|
32
|
+
this.isShowPixKeyFieldValidatorMessage = false;
|
|
33
|
+
this.pixAccountFormGroup.get("pixKey").reset();
|
|
34
|
+
}
|
|
35
|
+
setDefaultCpfPixKey() {
|
|
36
|
+
if (this._defaultCpfNumber) {
|
|
37
|
+
this.pixAccountFormGroup.get("pixKey").setValue(this._defaultCpfNumber);
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
const sheetDocument = this._paramsForm.get("sheetDocument");
|
|
41
|
+
if (sheetDocument) {
|
|
42
|
+
const cpf = sheetDocument.get("cpfNumber").value;
|
|
43
|
+
if (cpf) {
|
|
44
|
+
this.pixAccountFormGroup.get("pixKey").setValue(cpf);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
createFormGroupBase() {
|
|
50
|
+
this.pixAccountFormGroup = this.formBuilder.group({
|
|
51
|
+
id: this.formBuilder.control(null),
|
|
52
|
+
index: this.formBuilder.control(null),
|
|
53
|
+
employee: this.formBuilder.control({ value: { tableId: null }, disabled: true }),
|
|
54
|
+
dateChange: this.formBuilder.control(null),
|
|
55
|
+
pixKeyType: this.formBuilder.control(null, Validators.required),
|
|
56
|
+
pixKey: this.formBuilder.control(null),
|
|
57
|
+
percentage: this.formBuilder.control(null, Validators.compose([
|
|
58
|
+
...this.initialValidatorOfPercentage,
|
|
59
|
+
Validators.max(this.maxValuePercentage),
|
|
60
|
+
])),
|
|
61
|
+
externalId: this.formBuilder.control(null),
|
|
62
|
+
customFields: this.formBuilder.control(null),
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
setValidatorsAccordingList(pixAccountList, index = null, isEditMode = true) {
|
|
66
|
+
console.log("setValidatorsAccordingList", pixAccountList, index, isEditMode);
|
|
67
|
+
this.pixAccountList = pixAccountList && pixAccountList.length ? [...pixAccountList] : [];
|
|
68
|
+
const percentageIncluded = [];
|
|
69
|
+
this.pixAccountList.forEach((field, key) => {
|
|
70
|
+
if (field["percentage"] && key !== index) {
|
|
71
|
+
percentageIncluded.push(field["percentage"]);
|
|
72
|
+
}
|
|
73
|
+
});
|
|
74
|
+
this.beforeSetPixKeyTypeValidator();
|
|
75
|
+
this.setPixKeyValidators(isEditMode);
|
|
76
|
+
this.validatePercentageValid(percentageIncluded);
|
|
77
|
+
}
|
|
78
|
+
beforeSetPixKeyTypeValidator() {
|
|
79
|
+
const pixKeyType = this.pixAccountFormGroup.get("pixKeyType");
|
|
80
|
+
console.log("beforeSetPixKeyTypeValidator", this.pixAccountList, pixKeyType);
|
|
81
|
+
if (this.pixAccountList && this.pixAccountList.length && pixKeyType) {
|
|
82
|
+
pixKeyType.setValidators(Validators.compose([
|
|
83
|
+
Validators.required,
|
|
84
|
+
this.validateDuplicatePixKeyTypeBankAccount(this.pixAccountList),
|
|
85
|
+
]));
|
|
86
|
+
}
|
|
87
|
+
else {
|
|
88
|
+
pixKeyType.setValidators(Validators.required);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
setPixKeyValidators(isEditMode) {
|
|
92
|
+
const pixKey = this.pixAccountFormGroup.get("pixKey");
|
|
93
|
+
console.log("setPixKeyValidators", this.pixKeyType, isEditMode);
|
|
94
|
+
if (this.pixKeyType) {
|
|
95
|
+
switch (this.pixKeyType) {
|
|
96
|
+
case "TELEPHONE":
|
|
97
|
+
pixKey.setValidators(Validators.compose([Validators.required, GenericValidator.isValidPhoneNumber]));
|
|
98
|
+
break;
|
|
99
|
+
case "EMAIL":
|
|
100
|
+
pixKey.setValidators(Validators.compose([Validators.required, GenericValidator.isValidEmail]));
|
|
101
|
+
break;
|
|
102
|
+
case "CPF":
|
|
103
|
+
pixKey.setValidators(Validators.compose([Validators.required, GenericValidator.isValidCpf]));
|
|
104
|
+
break;
|
|
105
|
+
case "CNPJ":
|
|
106
|
+
pixKey.setValidators(Validators.compose([Validators.required, GenericValidator.isValidCnpj]));
|
|
107
|
+
break;
|
|
108
|
+
case "RANDOM_KEY":
|
|
109
|
+
pixKey.setValidators(Validators.required);
|
|
110
|
+
break;
|
|
111
|
+
default:
|
|
112
|
+
pixKey.setValidators(null);
|
|
113
|
+
}
|
|
114
|
+
if (isEditMode) {
|
|
115
|
+
pixKey.enable();
|
|
116
|
+
}
|
|
117
|
+
pixKey.updateValueAndValidity();
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
validatePercentageValid(listValue) {
|
|
121
|
+
const percentage = this.pixAccountFormGroup.get("percentage");
|
|
122
|
+
this.maxValuePercentage = listValue.reduce((acc, val) => acc - val, 100.00);
|
|
123
|
+
console.log("validatePercentageValid", this.maxValuePercentage);
|
|
124
|
+
percentage.setValidators(Validators.compose([
|
|
125
|
+
...this.initialValidatorOfPercentage,
|
|
126
|
+
Validators.max(this.maxValuePercentage),
|
|
127
|
+
]));
|
|
128
|
+
percentage.updateValueAndValidity();
|
|
129
|
+
}
|
|
130
|
+
validateDuplicatePixKeyTypeBankAccount(listCompare) {
|
|
131
|
+
return (control) => {
|
|
132
|
+
const value = control && control.value;
|
|
133
|
+
const isDuplicate = listCompare.some(field => value && field["pixKeyType"].key === 'BANK_ACCOUNT' && value.key === 'BANK_ACCOUNT');
|
|
134
|
+
return isDuplicate ? { pixKeyTypeBankAccountDuplicate: true } : null;
|
|
135
|
+
};
|
|
136
|
+
}
|
|
137
|
+
get paramsForm() {
|
|
138
|
+
return this._paramsForm;
|
|
139
|
+
}
|
|
140
|
+
set paramsForm(value) {
|
|
141
|
+
this._paramsForm = value;
|
|
142
|
+
}
|
|
143
|
+
get defaultCpfNumber() {
|
|
144
|
+
return this._defaultCpfNumber;
|
|
145
|
+
}
|
|
146
|
+
set defaultCpfNumber(value) {
|
|
147
|
+
this._defaultCpfNumber = value;
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
//# 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 { AbstractControl, FormBuilder, FormGroup, ValidatorFn, Validators } from \"@angular/forms\";\nimport { GenericValidator } from \"../utils/generic-validators\";\nimport { FormatUtilsService } from \"../utils/format-utils/format-utils.service\";\n\nexport 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.00;\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        console.log(\"phoneMaskEvent\", event);\n\n        FormatUtilsService.formatTelephoneInputEvent(event);\n    }\n\n    public onChangePixKeyType(item: any): void {\n        console.log(\"onChangePixKeyType\", item);\n\n        if (item.key) {\n            this.pixKeyType = item.key;\n            this.isShowPixKeyFieldValidatorMessage = true;\n            this.pixAccountFormGroup.get(\"pixKey\").reset();\n            this.setPixKeyValidators(true);\n\n            if (item.key === \"CPF\") {\n                this.setDefaultCpfPixKey();\n            }\n        }\n    }\n\n    public onClearPixKeyType(): void {\n        this.isShowPixKeyFieldValidatorMessage = false;\n        this.pixAccountFormGroup.get(\"pixKey\").reset();\n    }\n\n    public setDefaultCpfPixKey(): void {\n        if (this._defaultCpfNumber) {\n            this.pixAccountFormGroup.get(\"pixKey\").setValue(this._defaultCpfNumber);\n        } else {\n            const sheetDocument = this._paramsForm.get(\"sheetDocument\");\n            if (sheetDocument) {\n                const cpf = sheetDocument.get(\"cpfNumber\").value;\n                if (cpf) {\n                    this.pixAccountFormGroup.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(null, Validators.compose([\n                ...this.initialValidatorOfPercentage,\n                Validators.max(this.maxValuePercentage),\n            ])),\n            externalId: this.formBuilder.control(null),\n            customFields: this.formBuilder.control(null),\n        });\n    }\n\n    protected setValidatorsAccordingList(pixAccountList: object[], index: number = null, isEditMode: boolean = true): void {\n        console.log(\"setValidatorsAccordingList\", pixAccountList, index, isEditMode);\n\n        this.pixAccountList = pixAccountList && pixAccountList.length ? [...pixAccountList] : [];\n        const percentageIncluded: number[] = [];\n\n        this.pixAccountList.forEach((field: any, key) => {\n            if (field[\"percentage\"] && key !== index) {\n                percentageIncluded.push(field[\"percentage\"]);\n            }\n        });\n\n        this.beforeSetPixKeyTypeValidator();\n        this.setPixKeyValidators(isEditMode);\n        this.validatePercentageValid(percentageIncluded);\n    }\n\n    protected beforeSetPixKeyTypeValidator(): void {\n        const pixKeyType = this.pixAccountFormGroup.get(\"pixKeyType\");\n\n        console.log(\"beforeSetPixKeyTypeValidator\", this.pixAccountList, pixKeyType);\n\n        if (this.pixAccountList && this.pixAccountList.length && pixKeyType) {\n            pixKeyType.setValidators(Validators.compose([\n                Validators.required,\n                this.validateDuplicatePixKeyTypeBankAccount(this.pixAccountList),\n            ]));\n        } else {\n            pixKeyType.setValidators(Validators.required);\n        }\n    }\n\n    protected setPixKeyValidators(isEditMode: boolean): void {\n        const pixKey = this.pixAccountFormGroup.get(\"pixKey\");\n\n        console.log(\"setPixKeyValidators\", this.pixKeyType, isEditMode);\n\n        if (this.pixKeyType) {\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.setValidators(null);\n            }\n\n            if (isEditMode) {\n                pixKey.enable();\n            }\n\n            pixKey.updateValueAndValidity();\n        }\n    }\n\n    protected validatePercentageValid(listValue: number[]): void {\n        const percentage = this.pixAccountFormGroup.get(\"percentage\");\n        this.maxValuePercentage = listValue.reduce((acc, val) => acc - val, 100.00);\n\n        console.log(\"validatePercentageValid\", this.maxValuePercentage);\n\n        percentage.setValidators(Validators.compose([\n            ...this.initialValidatorOfPercentage,\n            Validators.max(this.maxValuePercentage),\n        ]));\n        percentage.updateValueAndValidity();\n    }\n\n    private validateDuplicatePixKeyTypeBankAccount(listCompare: object[]) {\n        return (control: AbstractControl): Validators => {\n            const value = control && control.value;\n            const isDuplicate = listCompare.some(field =>\n                value && field[\"pixKeyType\"].key === 'BANK_ACCOUNT' && value.key === 'BANK_ACCOUNT'\n            );\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"]}
|