iptdevs-design-system 3.1.4396 → 3.2.1
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/esm2020/lib/cod/cod-form/cod-form.component.mjs +34 -21
- package/esm2020/lib/cod/logic/calculate-quotes.service.mjs +73 -53
- package/esm2020/lib/cod/modal-referred/modal-referred.component.mjs +2 -2
- package/esm2020/lib/cod/steps/cod-form-step-five/cod-form-step-five.component.mjs +18 -24
- package/esm2020/lib/cod/steps/cod-form-step-four/cod-form-step-four.component.mjs +85 -76
- package/esm2020/lib/cod/steps/cod-form-step-one/cod-form-step-one.component.mjs +225 -92
- package/esm2020/lib/cod/steps/cod-form-step-three/cod-form-step-three.component.mjs +14 -18
- package/esm2020/lib/cod/steps/cod-form-step-two/cod-form-step-two.component.mjs +95 -70
- package/esm2020/lib/cod-self-managed/cod-form-self-managed/cod-self-managed.component.mjs +190 -22
- package/esm2020/lib/cod-self-managed/cod-self-managed.module.mjs +28 -4
- package/esm2020/lib/cod-self-managed/logic/calculate-quotes.service.mjs +99 -0
- package/esm2020/lib/cod-self-managed/logic/cod-self-managed-controls.mjs +16 -44
- package/esm2020/lib/cod-self-managed/logic/cod-self-managed-steps.mjs +1 -1
- package/esm2020/lib/cod-self-managed/steps/cod-form-step-four/cod-self-form-step-four.component.mjs +244 -7
- package/esm2020/lib/cod-self-managed/steps/cod-form-step-one/cod-self-form-step-one.component.mjs +102 -18
- package/esm2020/lib/cod-self-managed/steps/cod-form-step-three/cod-self-form-step-three.component.mjs +255 -7
- package/esm2020/lib/cod-self-managed/steps/cod-form-step-two/cod-self-form-step-two.component.mjs +144 -32
- package/esm2020/lib/components/atoms/button/button.component.mjs +2 -2
- package/esm2020/lib/components/atoms/datalist/datalist.component.mjs +26 -17
- package/esm2020/lib/components/atoms/input/input.component.mjs +2 -2
- package/esm2020/lib/components/atoms/level-button/level-button.component.mjs +2 -2
- package/esm2020/lib/components/atoms/loader/loader.component.mjs +2 -2
- package/esm2020/lib/components/atoms/select/select.component.mjs +10 -8
- package/esm2020/lib/components/components.module.mjs +54 -8
- package/esm2020/lib/components/forms/create-user-form/create-user-form.component.mjs +3 -3
- package/esm2020/lib/components/forms/update-user-form/update-user-form.component.mjs +843 -0
- package/esm2020/lib/components/molecules/card-course/card-course.component.mjs +95 -0
- package/esm2020/lib/components/molecules/card-select-course/card-select-course.component.mjs +52 -0
- package/esm2020/lib/components/molecules/sidenav/sidenav.component.mjs +5 -5
- package/esm2020/lib/core/core.module.mjs +9 -3
- package/esm2020/lib/core/models/academic/academic.component.mjs +1 -1
- package/esm2020/lib/core/models/announcement/announcement-user-rq.model.mjs +2 -0
- package/esm2020/lib/core/models/announcement/announcement-user-rs.model.mjs +3 -0
- package/esm2020/lib/core/models/attendance/attendance.interface.mjs +1 -1
- package/esm2020/lib/core/models/budget/budget.model.mjs +1 -1
- package/esm2020/lib/core/models/cod/cod-rq.model.mjs +1 -1
- package/esm2020/lib/core/models/commercial/commercial.model.mjs +1 -1
- package/esm2020/lib/core/models/course/course-rq.model.mjs +1 -1
- package/esm2020/lib/core/models/course/courses.model.mjs +1 -1
- package/esm2020/lib/core/models/epayco/epayco.interfaces.mjs +2 -0
- package/esm2020/lib/core/models/notes/INotesTemplate.mjs +1 -1
- package/esm2020/lib/core/models/notes/notes.interface.mjs +1 -1
- package/esm2020/lib/core/models/parameters/parameters-rs.model.mjs +1 -1
- package/esm2020/lib/core/models/payment/payment-rq.model.mjs +1 -1
- package/esm2020/lib/core/models/student/student.interface.mjs +1 -1
- package/esm2020/lib/core/models/terms/terms-rs.model.mjs +2 -0
- package/esm2020/lib/core/models/transfer/transfer.model.mjs +2 -0
- package/esm2020/lib/core/models/user/user-rq.model.mjs +1 -1
- package/esm2020/lib/core/models/user/user-rs.model.mjs +3 -1
- package/esm2020/lib/core/pipes/course-pipes/schedule-form.pipe.mjs +47 -0
- package/esm2020/lib/core/pipes/course-pipes/time-form.pipe.mjs +34 -0
- package/esm2020/lib/core/pipes/course-pipes/type-level.pipe.mjs +57 -0
- package/esm2020/lib/core/pipes/parameter-pipes/gender-display.pipe.mjs +22 -0
- package/esm2020/lib/core/pipes/pipe.module.mjs +37 -0
- package/esm2020/lib/core/services/academic-service/academic.service.mjs +64 -1
- package/esm2020/lib/core/services/announcement/announcement.service.mjs +57 -0
- package/esm2020/lib/core/services/attendance-service/attendance.service.mjs +31 -1
- package/esm2020/lib/core/services/budget-service/budget-service.mjs +297 -1
- package/esm2020/lib/core/services/certificate-service/certificate.service.mjs +21 -1
- package/esm2020/lib/core/services/commercial-service/comercial.service.mjs +95 -1
- package/esm2020/lib/core/services/course-service/course-service.model.mjs +96 -1
- package/esm2020/lib/core/services/ePayco/epayco.service.mjs +37 -0
- package/esm2020/lib/core/services/notes-service/notes.service.mjs +6 -1
- package/esm2020/lib/core/services/parameters-service/parameters.service.mjs +13 -1
- package/esm2020/lib/core/services/user-service/user-service.mjs +55 -1
- package/esm2020/public-api.mjs +13 -1
- package/fesm2015/iptdevs-design-system.mjs +4357 -1296
- package/fesm2015/iptdevs-design-system.mjs.map +1 -1
- package/fesm2020/iptdevs-design-system.mjs +7080 -4043
- package/fesm2020/iptdevs-design-system.mjs.map +1 -1
- package/lib/cod/cod-form/cod-form.component.d.ts +7 -2
- package/lib/cod/logic/calculate-quotes.service.d.ts +3 -0
- package/lib/cod/steps/cod-form-step-five/cod-form-step-five.component.d.ts +4 -4
- package/lib/cod/steps/cod-form-step-four/cod-form-step-four.component.d.ts +6 -9
- package/lib/cod/steps/cod-form-step-one/cod-form-step-one.component.d.ts +9 -7
- package/lib/cod/steps/cod-form-step-three/cod-form-step-three.component.d.ts +4 -4
- package/lib/cod/steps/cod-form-step-two/cod-form-step-two.component.d.ts +8 -5
- package/lib/cod-self-managed/cod-form-self-managed/cod-self-managed.component.d.ts +31 -7
- package/lib/cod-self-managed/cod-self-managed.module.d.ts +7 -1
- package/lib/cod-self-managed/logic/calculate-quotes.service.d.ts +16 -0
- package/lib/cod-self-managed/steps/cod-form-step-four/cod-self-form-step-four.component.d.ts +46 -2
- package/lib/cod-self-managed/steps/cod-form-step-one/cod-self-form-step-one.component.d.ts +17 -5
- package/lib/cod-self-managed/steps/cod-form-step-three/cod-self-form-step-three.component.d.ts +48 -3
- package/lib/cod-self-managed/steps/cod-form-step-two/cod-self-form-step-two.component.d.ts +43 -9
- package/lib/components/atoms/datalist/datalist.component.d.ts +7 -3
- package/lib/components/atoms/select/select.component.d.ts +2 -1
- package/lib/components/components.module.d.ts +14 -5
- package/lib/components/forms/update-user-form/update-user-form.component.d.ts +87 -0
- package/lib/components/molecules/card-course/card-course.component.d.ts +21 -0
- package/lib/components/molecules/card-select-course/card-select-course.component.d.ts +13 -0
- package/lib/core/models/academic/academic.component.d.ts +143 -1
- package/lib/core/models/announcement/announcement-user-rq.model.d.ts +12 -0
- package/lib/core/models/announcement/announcement-user-rs.model.d.ts +7 -0
- package/lib/core/models/attendance/attendance.interface.d.ts +146 -0
- package/lib/core/models/budget/budget.model.d.ts +554 -0
- package/lib/core/models/cod/cod-rq.model.d.ts +193 -0
- package/lib/core/models/commercial/commercial.model.d.ts +91 -0
- package/lib/core/models/course/course-rq.model.d.ts +296 -22
- package/lib/core/models/course/courses.model.d.ts +51 -0
- package/lib/core/models/epayco/epayco.interfaces.d.ts +6 -0
- package/lib/core/models/notes/INotesTemplate.d.ts +57 -0
- package/lib/core/models/notes/notes.interface.d.ts +13 -0
- package/lib/core/models/parameters/parameters-rs.model.d.ts +78 -1
- package/lib/core/models/payment/payment-rq.model.d.ts +168 -0
- package/lib/core/models/student/student.interface.d.ts +18 -0
- package/lib/core/models/terms/terms-rs.model.d.ts +435 -0
- package/lib/core/models/transfer/transfer.model.d.ts +89 -0
- package/lib/core/models/user/user-rq.model.d.ts +78 -0
- package/lib/core/models/user/user-rs.model.d.ts +11 -0
- package/lib/core/pipes/course-pipes/schedule-form.pipe.d.ts +7 -0
- package/lib/core/pipes/course-pipes/time-form.pipe.d.ts +9 -0
- package/lib/core/pipes/course-pipes/type-level.pipe.d.ts +7 -0
- package/lib/core/pipes/parameter-pipes/gender-display.pipe.d.ts +7 -0
- package/lib/core/pipes/pipe.module.d.ts +11 -0
- package/lib/core/services/academic-service/academic.service.d.ts +18 -3
- package/lib/core/services/announcement/announcement.service.d.ts +18 -0
- package/lib/core/services/attendance-service/attendance.service.d.ts +7 -1
- package/lib/core/services/budget-service/budget-service.d.ts +57 -3
- package/lib/core/services/certificate-service/certificate.service.d.ts +5 -0
- package/lib/core/services/commercial-service/comercial.service.d.ts +23 -2
- package/lib/core/services/course-service/course-service.model.d.ts +22 -1
- package/lib/core/services/ePayco/epayco.service.d.ts +17 -0
- package/lib/core/services/notes-service/notes.service.d.ts +2 -1
- package/lib/core/services/parameters-service/parameters.service.d.ts +3 -0
- package/lib/core/services/user-service/user-service.d.ts +12 -1
- package/package.json +1 -1
- package/public-api.d.ts +11 -0
|
@@ -1,15 +1,263 @@
|
|
|
1
|
-
import { Component } from '@angular/core';
|
|
1
|
+
import { Component, EventEmitter, Output } from '@angular/core';
|
|
2
|
+
import { Validators } from '@angular/forms';
|
|
3
|
+
//import services
|
|
4
|
+
import { CodSelfManagedControls } from './../../logic/cod-self-managed-controls';
|
|
2
5
|
import { CodSelfManagedSteps } from '../../logic/cod-self-managed-steps';
|
|
6
|
+
import Swal from 'sweetalert2';
|
|
3
7
|
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "@angular/forms";
|
|
9
|
+
import * as i2 from "primeng/api";
|
|
10
|
+
import * as i3 from "../../../core/services/commercial-service/comercial.service";
|
|
11
|
+
import * as i4 from "./../../../core/utils/base-service/base.service";
|
|
12
|
+
import * as i5 from "./../../logic/cod-self-managed-controls";
|
|
13
|
+
import * as i6 from "./../../logic/calculate-quotes.service";
|
|
14
|
+
import * as i7 from "@angular/common";
|
|
15
|
+
import * as i8 from "../../../components/atoms/input/input.component";
|
|
16
|
+
import * as i9 from "../../../components/atoms/loader/loader.component";
|
|
17
|
+
import * as i10 from "../../../components/atoms/select/select.component";
|
|
18
|
+
import * as i11 from "primeng/tooltip";
|
|
19
|
+
import * as i12 from "primeng/button";
|
|
20
|
+
import * as i13 from "primeng/toast";
|
|
21
|
+
import * as i14 from "primeng/radiobutton";
|
|
22
|
+
import * as i15 from "primeng/table";
|
|
4
23
|
export class CodSelfFormStepThreeComponent extends CodSelfManagedSteps {
|
|
5
|
-
constructor() {
|
|
24
|
+
constructor(fb, messageService, commercialService, baseService, codFormControls, calculateQuotesService) {
|
|
6
25
|
super();
|
|
26
|
+
this.fb = fb;
|
|
27
|
+
this.messageService = messageService;
|
|
28
|
+
this.commercialService = commercialService;
|
|
29
|
+
this.baseService = baseService;
|
|
30
|
+
this.codFormControls = codFormControls;
|
|
31
|
+
this.calculateQuotesService = calculateQuotesService;
|
|
32
|
+
this.completed = new EventEmitter();
|
|
33
|
+
this.financingData = new EventEmitter();
|
|
34
|
+
this.controls = new CodSelfManagedControls().controls[2];
|
|
35
|
+
this.messageInfo = "Selecciona un plan de pagos";
|
|
36
|
+
this.visible = false;
|
|
37
|
+
this.paymentMethods = [
|
|
38
|
+
{ code: '1', name: 'Financiado' },
|
|
39
|
+
{ code: '2', name: 'Contado' },
|
|
40
|
+
];
|
|
41
|
+
this.feeResponse = false;
|
|
42
|
+
this.thereArePlans = false;
|
|
43
|
+
this.isFinancing = false;
|
|
44
|
+
this.dataFinancingMaster = [];
|
|
45
|
+
this.dataFinancing = [];
|
|
46
|
+
this.selectedRow = null;
|
|
47
|
+
this.errorMessage = 'Faltan campos por llenar.';
|
|
48
|
+
this.isLoadingSelectLevels = false;
|
|
49
|
+
this.initForm();
|
|
50
|
+
}
|
|
51
|
+
initForm() {
|
|
52
|
+
this.codSelfFormStepThree = this.fb.group({
|
|
53
|
+
program_price: [{ value: '', disabled: true }, [Validators.required]],
|
|
54
|
+
payment_date: ['', [Validators.required]],
|
|
55
|
+
payment_method: ['', [Validators.required]],
|
|
56
|
+
quota_times: [{ value: '', disabled: true }, [Validators.required]],
|
|
57
|
+
total_price: [{ value: '', disabled: true }, [Validators.required]],
|
|
58
|
+
paid_level: ['', [Validators.required]],
|
|
59
|
+
quota_price: ['', [Validators.required]],
|
|
60
|
+
fee_number: ['', [Validators.required]],
|
|
61
|
+
selectedRow: [null],
|
|
62
|
+
});
|
|
63
|
+
this.listenPaymentMethodField();
|
|
64
|
+
}
|
|
65
|
+
ngOnInit() {
|
|
66
|
+
this.startLocalStorageWork();
|
|
67
|
+
const currentDate = new Date().toISOString().split('T')[0];
|
|
68
|
+
this.codSelfFormStepThree.controls['payment_date'].setValue(currentDate);
|
|
69
|
+
this.codSelfFormStepThree.get('payment_method')?.valueChanges.subscribe(() => {
|
|
70
|
+
this.selectedRow = null;
|
|
71
|
+
this.codSelfFormStepThree.controls['selectedRow'].setValue(null);
|
|
72
|
+
this.codSelfFormStepThree.controls['fee_number'].setValue(null);
|
|
73
|
+
this.codSelfFormStepThree.controls['quota_price'].setValue(null);
|
|
74
|
+
this.codSelfFormStepThree.controls['paid_level'].setValue(null);
|
|
75
|
+
this.codSelfFormStepThree.controls['selectedRow'].setValue(null);
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
startLocalStorageWork() {
|
|
79
|
+
this.controls.forEach(control => {
|
|
80
|
+
let localStorageValue = this.readAndWriteLS(3, control.name);
|
|
81
|
+
this.codSelfFormStepThree.controls[control.name].setValue(localStorageValue.value);
|
|
82
|
+
this.listenFormChanges(3, control.name, this.codSelfFormStepThree.controls[control.name].valueChanges);
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
listenPaymentMethodField() {
|
|
86
|
+
const control = this.codSelfFormStepThree.get('payment_method');
|
|
87
|
+
control?.valueChanges.subscribe((change) => {
|
|
88
|
+
// Financiado
|
|
89
|
+
if (change === '1') {
|
|
90
|
+
// Poner validaciones
|
|
91
|
+
this.codSelfFormStepThree.controls['program_price'].setValidators([Validators.required]);
|
|
92
|
+
this.codSelfFormStepThree.controls['payment_date'].setValidators([Validators.required]);
|
|
93
|
+
this.codSelfFormStepThree.controls['quota_times'].setValidators([Validators.required]);
|
|
94
|
+
this.codSelfFormStepThree.controls['total_price'].setValidators([Validators.required]);
|
|
95
|
+
this.updateValueAndValidity();
|
|
96
|
+
this.updateGlobalControls(change);
|
|
97
|
+
}
|
|
98
|
+
// de contado
|
|
99
|
+
if (change === '2') {
|
|
100
|
+
// Quitar las validaciones
|
|
101
|
+
this.codSelfFormStepThree.controls['program_price'].setValidators([Validators.required]);
|
|
102
|
+
this.codSelfFormStepThree.controls['payment_date'].setValidators([Validators.required]);
|
|
103
|
+
this.codSelfFormStepThree.controls['quota_times'].clearValidators();
|
|
104
|
+
this.codSelfFormStepThree.controls['total_price'].setValidators([Validators.required]);
|
|
105
|
+
this.updateValueAndValidity();
|
|
106
|
+
this.updateGlobalControls(change);
|
|
107
|
+
}
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
updateGlobalControls(change) {
|
|
111
|
+
let controls = this.controls.filter(control => control.name !== 'payment_method');
|
|
112
|
+
controls.forEach(control => {
|
|
113
|
+
if (change === '1')
|
|
114
|
+
this.codFormControls.changeValue(3, control.name, true);
|
|
115
|
+
if (change === '2') {
|
|
116
|
+
if (control.name === 'quota_times')
|
|
117
|
+
this.codFormControls.changeValue(3, control.name, false);
|
|
118
|
+
}
|
|
119
|
+
});
|
|
120
|
+
}
|
|
121
|
+
onReject() {
|
|
122
|
+
this.messageService.clear('confirm');
|
|
123
|
+
this.visible = false;
|
|
124
|
+
}
|
|
125
|
+
showConfirm() {
|
|
126
|
+
if (!this.visible) {
|
|
127
|
+
this.messageService.add({ key: 'confirm', sticky: true, severity: 'success', summary: 'Can you send me the report?', life: 5000 });
|
|
128
|
+
this.visible = true;
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
selectPaymentMethod(paymentMethod) {
|
|
132
|
+
this.feeResponse = true;
|
|
133
|
+
this.thereArePlans = false;
|
|
134
|
+
if (paymentMethod !== '') {
|
|
135
|
+
const request = {
|
|
136
|
+
token: this.baseService.getUserToken(),
|
|
137
|
+
course_type: Number(this.localStorageCOD.getCodFormData(2, 'course_type')),
|
|
138
|
+
agreement: Number(this.localStorageCOD.getCodFormData(1, 'agreement_by_category')),
|
|
139
|
+
course_modality: Number(this.localStorageCOD.getCodFormData(2, 'course_modality')),
|
|
140
|
+
payment_method: parseInt(paymentMethod)
|
|
141
|
+
};
|
|
142
|
+
this.commercialService.ObtainCodPricesCodSelfManaged(request).subscribe((response) => {
|
|
143
|
+
if (response.data != null) {
|
|
144
|
+
this.dataPrices = response.data;
|
|
145
|
+
this.feeResponse = false;
|
|
146
|
+
this.thereArePlans = true;
|
|
147
|
+
}
|
|
148
|
+
else {
|
|
149
|
+
this.thereArePlans = false;
|
|
150
|
+
this.feeResponse = false;
|
|
151
|
+
Swal.fire({
|
|
152
|
+
position: 'center',
|
|
153
|
+
icon: 'warning',
|
|
154
|
+
title: '<p style="font-family: Poppins"">Oops.. no hay planes de pagos, \n en el curso elegido.</p>',
|
|
155
|
+
showConfirmButton: false,
|
|
156
|
+
timer: 3000,
|
|
157
|
+
});
|
|
158
|
+
this.clearInputPayment();
|
|
159
|
+
}
|
|
160
|
+
});
|
|
161
|
+
this.codSelfFormStepThree.controls['payment_method'].setValue(paymentMethod);
|
|
162
|
+
}
|
|
163
|
+
else {
|
|
164
|
+
this.codSelfFormStepThree.controls['payment_method'].setValue(null);
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
clearInputPayment() {
|
|
168
|
+
this.codSelfFormStepThree.controls['program_price'].setValue(null);
|
|
169
|
+
this.codSelfFormStepThree.controls['quota_times'].setValue(null);
|
|
170
|
+
this.codSelfFormStepThree.controls['total_price'].setValue(null);
|
|
171
|
+
}
|
|
172
|
+
back() {
|
|
173
|
+
this.completed.emit(1);
|
|
174
|
+
}
|
|
175
|
+
sendForm() {
|
|
176
|
+
this.completed.emit(3);
|
|
177
|
+
}
|
|
178
|
+
showTable() {
|
|
179
|
+
this.isLoadingSelectLevels = true;
|
|
180
|
+
this.isFinancing = true;
|
|
181
|
+
this.financingData.emit(null);
|
|
182
|
+
const total_price = this.codSelfFormStepThree.controls['total_price'].value;
|
|
183
|
+
if ((total_price === 'null') || this.codSelfFormStepThree.invalid) {
|
|
184
|
+
Swal.fire({
|
|
185
|
+
title: 'Error table',
|
|
186
|
+
text: 'Debes ingresar el monto total de la matrícula y la cuota inicial',
|
|
187
|
+
icon: 'error'
|
|
188
|
+
});
|
|
189
|
+
return;
|
|
190
|
+
}
|
|
191
|
+
// Calcular cuotas
|
|
192
|
+
this.dataFinancing = [];
|
|
193
|
+
let params = {
|
|
194
|
+
date: new Date(this.codSelfFormStepThree.controls['payment_date'].value),
|
|
195
|
+
quotaValues: Number(this.codSelfFormStepThree.controls['quota_price'].value),
|
|
196
|
+
quotaTimes: Number(this.codSelfFormStepThree.controls['fee_number'].value),
|
|
197
|
+
totalPrice: this.codSelfFormStepThree.controls['total_price'].value,
|
|
198
|
+
};
|
|
199
|
+
this.dataFinancingMaster = this.calculateQuotesService.calculateQuotes(params);
|
|
200
|
+
if (this.dataFinancingMaster.length > 1) {
|
|
201
|
+
const enrollmentValue = this.dataFinancingMaster[0][1];
|
|
202
|
+
const firstQuotaValue = this.dataFinancingMaster[1][1];
|
|
203
|
+
this.totalInitialPaymentSpan = parseFloat(enrollmentValue.replace(/[^\d.-]/g, '')) + parseFloat(firstQuotaValue.replace(/[^\d.-]/g, ''));
|
|
204
|
+
const enrollmentValueTwo = parseFloat(this.dataFinancingMaster[0][1].replace(/[^\d.-]/g, ''));
|
|
205
|
+
const firstQuotaValueTwo = parseFloat(this.dataFinancingMaster[1][1].replace(/[^\d.-]/g, ''));
|
|
206
|
+
this.totalInitialPayment = enrollmentValueTwo + firstQuotaValueTwo;
|
|
207
|
+
const totalInitialPaymentInteger = Math.round(this.totalInitialPayment);
|
|
208
|
+
const formattedTotalInitialPayment = new Intl.NumberFormat('en-US', { style: 'currency', currency: 'USD', minimumFractionDigits: 0 }).format(totalInitialPaymentInteger);
|
|
209
|
+
const combinedRecord = [
|
|
210
|
+
this.dataFinancingMaster[0][0],
|
|
211
|
+
formattedTotalInitialPayment,
|
|
212
|
+
this.dataFinancingMaster[0][2]
|
|
213
|
+
];
|
|
214
|
+
this.dataFinancing = [combinedRecord, ...this.dataFinancingMaster.slice(2)];
|
|
215
|
+
}
|
|
216
|
+
this.isFinancing = true;
|
|
217
|
+
this.financingData.emit(this.dataFinancingMaster);
|
|
218
|
+
this.isLoadingSelectLevels = false;
|
|
219
|
+
}
|
|
220
|
+
selectLevels(dataPayment, rowIndex) {
|
|
221
|
+
rowIndex;
|
|
222
|
+
if (this.codSelfFormStepThree.get('payment_method')?.value == 1) {
|
|
223
|
+
this.selectedRow = rowIndex;
|
|
224
|
+
this.codSelfFormStepThree.controls['selectedRow'].setValue(rowIndex);
|
|
225
|
+
this.codSelfFormStepThree.controls['quota_times'].setValue(dataPayment.code);
|
|
226
|
+
this.codSelfFormStepThree.controls['total_price'].setValue(dataPayment.enrollment);
|
|
227
|
+
this.codSelfFormStepThree.controls['program_price'].setValue(dataPayment.financed_price);
|
|
228
|
+
this.codSelfFormStepThree.controls['paid_level'].setValue(dataPayment.paid_level - 1);
|
|
229
|
+
this.codSelfFormStepThree.controls['fee_number'].setValue(dataPayment.fee_number);
|
|
230
|
+
this.codSelfFormStepThree.controls['quota_price'].setValue(dataPayment.quota_price);
|
|
231
|
+
this.updateValueAndValidity();
|
|
232
|
+
this.showTable();
|
|
233
|
+
}
|
|
234
|
+
else if (this.codSelfFormStepThree.get('payment_method')?.value == 2) {
|
|
235
|
+
this.selectedRow = rowIndex;
|
|
236
|
+
this.codSelfFormStepThree.controls['selectedRow'].setValue(rowIndex);
|
|
237
|
+
this.codSelfFormStepThree.controls['quota_times'].setValue(dataPayment.code);
|
|
238
|
+
this.codSelfFormStepThree.controls['total_price'].setValue(dataPayment.enrollment);
|
|
239
|
+
this.codSelfFormStepThree.controls['program_price'].setValue(dataPayment.normal_price);
|
|
240
|
+
this.codSelfFormStepThree.controls['paid_level'].setValue(dataPayment.paid_level - 1);
|
|
241
|
+
this.codSelfFormStepThree.controls['fee_number'].setValue(dataPayment.fee_number);
|
|
242
|
+
this.codSelfFormStepThree.controls['quota_price'].setValue(dataPayment.quota_price);
|
|
243
|
+
this.updateValueAndValidity();
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
updateValueAndValidity() {
|
|
247
|
+
this.codSelfFormStepThree.controls['program_price'].updateValueAndValidity();
|
|
248
|
+
this.codSelfFormStepThree.controls['payment_date'].updateValueAndValidity();
|
|
249
|
+
this.codSelfFormStepThree.controls['quota_times'].updateValueAndValidity();
|
|
250
|
+
this.codSelfFormStepThree.controls['total_price'].updateValueAndValidity();
|
|
7
251
|
}
|
|
8
252
|
}
|
|
9
|
-
CodSelfFormStepThreeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.7", ngImport: i0, type: CodSelfFormStepThreeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
10
|
-
CodSelfFormStepThreeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.7", type: CodSelfFormStepThreeComponent, selector: "app-cod-self-form-step-three", usesInheritance: true, ngImport: i0, template: "<span>step 3</span>\n", styles: [""] });
|
|
253
|
+
CodSelfFormStepThreeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.7", ngImport: i0, type: CodSelfFormStepThreeComponent, deps: [{ token: i1.FormBuilder }, { token: i2.MessageService }, { token: i3.CommercialService }, { token: i4.BaseService }, { token: i5.CodSelfManagedControls }, { token: i6.CalculateQuotesService }], target: i0.ɵɵFactoryTarget.Component });
|
|
254
|
+
CodSelfFormStepThreeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.7", type: CodSelfFormStepThreeComponent, selector: "app-cod-self-form-step-three", outputs: { completed: "completed", financingData: "financingData" }, usesInheritance: true, ngImport: i0, template: "<div class=\"container-main\">\n <div class=\"container-form\">\n <h2>Pagos</h2>\n <p-toast position=\"top-center\" key=\"confirm\" (onClose)=\"onReject()\" [baseZIndex]=\"10\">\n <ng-template let-message pTemplate=\"message\">\n <div class=\"flex flex-column align-items-start\" style=\"flex: 1\">\n <div class=\"flex align-items-center gap-2\">\n <img src=\"./assets/logos/reading.png\" style=\"width: 65px;\" shape=\"circle\" />\n <span class=\"font-bold text-900\">Jacob</span>\n </div>\n <div class=\"font-medium text-lg my-3 text-900\">{{ messageInfo }}</div>\n </div>\n </ng-template>\n </p-toast>\n <i class=\"pi pi-exclamation-circle cursor-pointer w-auto\" (click)=\"showConfirm()\" pTooltip=\"Mas info.\" tooltipPosition=\"bottom\"></i>\n <div class=\"animate__animated animate__slideInRight ng-star-inserted\">\n <div class=\"container__body__select flex justify-content-center flex-wrap\">\n\n <form autocomplete=\"off\" [formGroup]=\"codSelfFormStepThree\" class=\"grid mt-2 flex flex-column align-items-center\">\n\n <div class=\"container_selects col-12\">\n <ipt-select\n [initialValue]=\"codSelfFormStepThree.controls['payment_method'].value\"\n [control]=\"codSelfFormStepThree.controls['payment_method']\"\n (eventSelect)=\"selectPaymentMethod($event)\"\n [data]=\"paymentMethods\"\n [defaultText]=\"'M\u00E9todo de pago'\"\n ></ipt-select>\n <ipt-loader *ngIf=\"feeResponse\"></ipt-loader>\n\n <div class=\"col-12\" *ngIf=\"thereArePlans\">\n <p-table\n [value]=\"dataPrices\"\n [tableStyle]=\"{'min-width': '100%'}\"\n [rowHover]=\"true\"\n >\n <ng-template pTemplate=\"caption\">\n <div class=\"flex align-items-center\">\n Click en niveles a cancelar\n </div>\n </ng-template>\n <ng-template pTemplate=\"header\">\n <tr>\n <th class=\"bg-blue-200 text-center font-medium pt-2 pb-2\"></th>\n <th class=\"bg-blue-200 text-center font-medium pt-2 pb-2\">Cancelar</th>\n <th class=\"bg-blue-200 text-center font-medium pt-2 pb-2\">Cuotas</th>\n </tr>\n </ng-template>\n <ng-template pTemplate=\"body\" let-data let-rowIndex=\"rowIndex\">\n <tr [class.selected-row]=\"selectedRow === rowIndex\" (click)=\"selectLevels(data, rowIndex)\">\n <td class=\"pt-0 pb-0 text-center\">\n <p-radioButton [value]=\"rowIndex\" formControlName=\"selectedRow\"></p-radioButton>\n </td>\n <td class=\"pt-1 pb-1\">{{ data.paid_level }} {{ data.paid_level == 1 ? \"Nivel\" : \"Niveles\"}}</td>\n <td class=\"pt-1 pb-1 text-center\">{{ data.fee_number }}</td>\n </tr>\n </ng-template>\n </p-table>\n </div>\n </div>\n\n <div class=\"container_selects col-12\">\n <ipt-input\n [inputType]=\"'text'\"\n [placeHolder]=\"'Monto total de la matr\u00EDcula'\"\n [control]=\"codSelfFormStepThree.controls['total_price']\"\n [withPipe]=\"true\"\n ></ipt-input>\n </div>\n\n <div class=\"container_selects col-12\">\n <ipt-input\n [withPipe]=\"true\"\n [inputType]=\"'text'\"\n [control]=\"codSelfFormStepThree.controls['program_price']\"\n [placeHolder]=\"'Valor total del programa'\"\n ></ipt-input>\n </div>\n\n <div class=\"flex justify-content-center flex-wrap m-2\">\n </div>\n\n <!-- Tabla de financiaci\u00F3n -->\n <div class=\"col-12\" *ngIf=\"codSelfFormStepThree.controls['payment_method'].value === '1' && isFinancing\">\n <div class=\"flex gap-1 md:gap-4 xl:gap-8 m-1 p-2 border-round bg-blue-500 text-white\">\n <div class=\"container_icon flex mr-4 justify-content-center align-items-start mt-1\">\n <i class=\"pi pi-info-circle cursor-pointer w-auto mb-4\" pTooltip=\"Mas info.\" tooltipPosition=\"bottom\"></i>\n </div>\n <div class=\"flex flex-column container_info_span flex align-items-center justify-content-center\">\n <span><strong>NOTA:</strong> Deber\u00E1 pagar la matr\u00EDcula y la primera cuota <strong>(total: ${{ totalInitialPaymentSpan }})</strong> para completar el proceso de inscripci\u00F3n.</span><br>\n <span>Recuerda que las fechas cambian de acuerdo a la fecha que comienza el plan</span>\n </div>\n </div>\n\n <p-table\n *ngIf=\"!isLoadingSelectLevels\"\n [value]=\"dataFinancing\"\n [tableStyle]=\"{'min-width': '100%'}\"\n [rowHover]=\"true\"\n >\n <ng-template pTemplate=\"caption\">\n <div class=\"flex align-items-center\">\n C\u00E1lculo de cuotas\n </div>\n </ng-template>\n <ng-template pTemplate=\"header\">\n <tr>\n <th class=\"bg-blue-200 text-center font-medium pt-2 pb-2\">#</th>\n <th class=\"bg-blue-200 text-center font-medium pt-2 pb-2\">Valor</th>\n <th class=\"bg-blue-200 text-center font-medium pt-2 pb-2\">Fecha</th>\n </tr>\n </ng-template>\n <ng-template pTemplate=\"body\" let-data>\n <tr>\n <td class=\"p-0 text-center text-sm\">{{ data[0] }}</td>\n <td class=\"p-0 text-center text-sm\">{{ data[1] }}</td>\n <td class=\"p-0 text-center text-sm\">{{ data[2] }}</td>\n </tr>\n </ng-template>\n </p-table>\n <ipt-loader *ngIf=\"isLoadingSelectLevels\"></ipt-loader>\n </div>\n\n </form>\n </div>\n\n <div class=\"flex justify-content-between mt-3 align-items-center gap-3\">\n <!-- <span *ngIf=\"codSelfFormStepOne.invalid && codSelfFormStepOne.touched\" class=\"text-red-500 font-bold text-center mt-1 py-2 bg-red-100 w-full border-round-xl\">{{ errorMessage }}</span> -->\n <button\n pButton\n icon=\"pi pi-arrow-left\"\n type=\"submit\"\n (click)=\"back()\"\n ></button>\n\n <button\n pButton\n icon=\"pi pi-arrow-right\"\n [disabled]=\"!codSelfFormStepThree.valid\"\n (click)=\"sendForm()\"\n ></button>\n </div>\n </div>\n </div>\n</div>\n", styles: [".error-message{font-size:x-small;color:red}:host ::ng-deep .p-toast{width:20rem!important}.container-form{margin:5%;border-radius:3px;border:1px solid #2563eb;box-shadow:#3c40434d 0 1px 2px,#3c404326 0 2px 6px 2px;padding:1rem}:host ::ng-deep .p-datatable.p-datatable-hoverable-rows .p-datatable-tbody>tr:not(.p-highlight):hover{color:#1c77f7!important}.selected-row{background-color:#bfdbfe!important;color:#1c77f7!important}tr{cursor:pointer}td,.header-reports-advisers{font-family:Poppins,sans-serif}:host ::ng-deep .p-datatable .p-datatable-header{background:#f8f9fa;color:#f8f9fa;border:none;padding:1rem;font-weight:700;background-color:#1c77f7;border-radius:10px 10px 0 0}:host ::ng-deep .p-datatable{position:relative;border-radius:10px;border:1px solid #1c77f7}:host ::ng-deep .p-datatable>.p-datatable-wrapper{border-radius:0 0 10px 10px}.container_selects{width:16rem}.p-datatable .p-datatable-tbody>tr>td{padding:.1rem .5rem}:host ::ng-deep .p-datatable .p-datatable-tbody>tr>td{padding:0rem!important}\n"], dependencies: [{ kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i8.InputComponent, selector: "ipt-input", inputs: ["inputType", "placeHolder", "validateText", "withPipe", "list", "iconUrl", "control", "prefix", "thousands", "decimal", "disabledSel"], outputs: ["dateSelected"] }, { kind: "component", type: i9.LoaderComponent, selector: "ipt-loader", inputs: ["message", "isDialog"] }, { kind: "component", type: i10.SelectComponent, selector: "ipt-select", inputs: ["isRequired", "data", "defaultText", "selectCode", "disabledSel", "initialValue", "label", "control"], outputs: ["eventSelect"] }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i11.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "fitContent", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "directive", type: i12.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "component", type: i13.Toast, selector: "p-toast", inputs: ["key", "autoZIndex", "baseZIndex", "style", "styleClass", "position", "preventOpenDuplicates", "preventDuplicates", "showTransformOptions", "hideTransformOptions", "showTransitionOptions", "hideTransitionOptions", "breakpoints"], outputs: ["onClose"] }, { kind: "directive", type: i2.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "component", type: i14.RadioButton, selector: "p-radioButton", inputs: ["value", "formControlName", "name", "disabled", "label", "tabindex", "inputId", "ariaLabelledBy", "ariaLabel", "style", "styleClass", "labelStyleClass"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "component", type: i15.Table, selector: "p-table", inputs: ["frozenColumns", "frozenValue", "style", "styleClass", "tableStyle", "tableStyleClass", "paginator", "pageLinks", "rowsPerPageOptions", "alwaysShowPaginator", "paginatorPosition", "paginatorDropdownAppendTo", "paginatorDropdownScrollHeight", "currentPageReportTemplate", "showCurrentPageReport", "showJumpToPageDropdown", "showJumpToPageInput", "showFirstLastIcon", "showPageLinks", "defaultSortOrder", "sortMode", "resetPageOnSort", "selectionMode", "selectionPageOnly", "contextMenuSelection", "contextMenuSelectionMode", "dataKey", "metaKeySelection", "rowSelectable", "rowTrackBy", "lazy", "lazyLoadOnInit", "compareSelectionBy", "csvSeparator", "exportFilename", "filters", "globalFilterFields", "filterDelay", "filterLocale", "expandedRowKeys", "editingRowKeys", "rowExpandMode", "scrollable", "scrollDirection", "rowGroupMode", "scrollHeight", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "virtualScrollDelay", "frozenWidth", "responsive", "contextMenu", "resizableColumns", "columnResizeMode", "reorderableColumns", "loading", "loadingIcon", "showLoader", "rowHover", "customSort", "showInitialSortBadge", "autoLayout", "exportFunction", "exportHeader", "stateKey", "stateStorage", "editMode", "groupRowsBy", "groupRowsByOrder", "responsiveLayout", "breakpoint", "virtualRowHeight", "value", "columns", "first", "rows", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection", "selectAll"], outputs: ["selectAllChange", "selectionChange", "contextMenuSelectionChange", "onRowSelect", "onRowUnselect", "onPage", "onSort", "onFilter", "onLazyLoad", "onRowExpand", "onRowCollapse", "onContextMenuSelect", "onColResize", "onColReorder", "onRowReorder", "onEditInit", "onEditComplete", "onEditCancel", "onHeaderCheckboxToggle", "sortFunction", "firstChange", "rowsChange", "onStateSave", "onStateRestore"] }] });
|
|
11
255
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.7", ngImport: i0, type: CodSelfFormStepThreeComponent, decorators: [{
|
|
12
256
|
type: Component,
|
|
13
|
-
args: [{ selector: 'app-cod-self-form-step-three', template: "<span>
|
|
14
|
-
}], ctorParameters: function () { return []; }
|
|
15
|
-
|
|
257
|
+
args: [{ selector: 'app-cod-self-form-step-three', template: "<div class=\"container-main\">\n <div class=\"container-form\">\n <h2>Pagos</h2>\n <p-toast position=\"top-center\" key=\"confirm\" (onClose)=\"onReject()\" [baseZIndex]=\"10\">\n <ng-template let-message pTemplate=\"message\">\n <div class=\"flex flex-column align-items-start\" style=\"flex: 1\">\n <div class=\"flex align-items-center gap-2\">\n <img src=\"./assets/logos/reading.png\" style=\"width: 65px;\" shape=\"circle\" />\n <span class=\"font-bold text-900\">Jacob</span>\n </div>\n <div class=\"font-medium text-lg my-3 text-900\">{{ messageInfo }}</div>\n </div>\n </ng-template>\n </p-toast>\n <i class=\"pi pi-exclamation-circle cursor-pointer w-auto\" (click)=\"showConfirm()\" pTooltip=\"Mas info.\" tooltipPosition=\"bottom\"></i>\n <div class=\"animate__animated animate__slideInRight ng-star-inserted\">\n <div class=\"container__body__select flex justify-content-center flex-wrap\">\n\n <form autocomplete=\"off\" [formGroup]=\"codSelfFormStepThree\" class=\"grid mt-2 flex flex-column align-items-center\">\n\n <div class=\"container_selects col-12\">\n <ipt-select\n [initialValue]=\"codSelfFormStepThree.controls['payment_method'].value\"\n [control]=\"codSelfFormStepThree.controls['payment_method']\"\n (eventSelect)=\"selectPaymentMethod($event)\"\n [data]=\"paymentMethods\"\n [defaultText]=\"'M\u00E9todo de pago'\"\n ></ipt-select>\n <ipt-loader *ngIf=\"feeResponse\"></ipt-loader>\n\n <div class=\"col-12\" *ngIf=\"thereArePlans\">\n <p-table\n [value]=\"dataPrices\"\n [tableStyle]=\"{'min-width': '100%'}\"\n [rowHover]=\"true\"\n >\n <ng-template pTemplate=\"caption\">\n <div class=\"flex align-items-center\">\n Click en niveles a cancelar\n </div>\n </ng-template>\n <ng-template pTemplate=\"header\">\n <tr>\n <th class=\"bg-blue-200 text-center font-medium pt-2 pb-2\"></th>\n <th class=\"bg-blue-200 text-center font-medium pt-2 pb-2\">Cancelar</th>\n <th class=\"bg-blue-200 text-center font-medium pt-2 pb-2\">Cuotas</th>\n </tr>\n </ng-template>\n <ng-template pTemplate=\"body\" let-data let-rowIndex=\"rowIndex\">\n <tr [class.selected-row]=\"selectedRow === rowIndex\" (click)=\"selectLevels(data, rowIndex)\">\n <td class=\"pt-0 pb-0 text-center\">\n <p-radioButton [value]=\"rowIndex\" formControlName=\"selectedRow\"></p-radioButton>\n </td>\n <td class=\"pt-1 pb-1\">{{ data.paid_level }} {{ data.paid_level == 1 ? \"Nivel\" : \"Niveles\"}}</td>\n <td class=\"pt-1 pb-1 text-center\">{{ data.fee_number }}</td>\n </tr>\n </ng-template>\n </p-table>\n </div>\n </div>\n\n <div class=\"container_selects col-12\">\n <ipt-input\n [inputType]=\"'text'\"\n [placeHolder]=\"'Monto total de la matr\u00EDcula'\"\n [control]=\"codSelfFormStepThree.controls['total_price']\"\n [withPipe]=\"true\"\n ></ipt-input>\n </div>\n\n <div class=\"container_selects col-12\">\n <ipt-input\n [withPipe]=\"true\"\n [inputType]=\"'text'\"\n [control]=\"codSelfFormStepThree.controls['program_price']\"\n [placeHolder]=\"'Valor total del programa'\"\n ></ipt-input>\n </div>\n\n <div class=\"flex justify-content-center flex-wrap m-2\">\n </div>\n\n <!-- Tabla de financiaci\u00F3n -->\n <div class=\"col-12\" *ngIf=\"codSelfFormStepThree.controls['payment_method'].value === '1' && isFinancing\">\n <div class=\"flex gap-1 md:gap-4 xl:gap-8 m-1 p-2 border-round bg-blue-500 text-white\">\n <div class=\"container_icon flex mr-4 justify-content-center align-items-start mt-1\">\n <i class=\"pi pi-info-circle cursor-pointer w-auto mb-4\" pTooltip=\"Mas info.\" tooltipPosition=\"bottom\"></i>\n </div>\n <div class=\"flex flex-column container_info_span flex align-items-center justify-content-center\">\n <span><strong>NOTA:</strong> Deber\u00E1 pagar la matr\u00EDcula y la primera cuota <strong>(total: ${{ totalInitialPaymentSpan }})</strong> para completar el proceso de inscripci\u00F3n.</span><br>\n <span>Recuerda que las fechas cambian de acuerdo a la fecha que comienza el plan</span>\n </div>\n </div>\n\n <p-table\n *ngIf=\"!isLoadingSelectLevels\"\n [value]=\"dataFinancing\"\n [tableStyle]=\"{'min-width': '100%'}\"\n [rowHover]=\"true\"\n >\n <ng-template pTemplate=\"caption\">\n <div class=\"flex align-items-center\">\n C\u00E1lculo de cuotas\n </div>\n </ng-template>\n <ng-template pTemplate=\"header\">\n <tr>\n <th class=\"bg-blue-200 text-center font-medium pt-2 pb-2\">#</th>\n <th class=\"bg-blue-200 text-center font-medium pt-2 pb-2\">Valor</th>\n <th class=\"bg-blue-200 text-center font-medium pt-2 pb-2\">Fecha</th>\n </tr>\n </ng-template>\n <ng-template pTemplate=\"body\" let-data>\n <tr>\n <td class=\"p-0 text-center text-sm\">{{ data[0] }}</td>\n <td class=\"p-0 text-center text-sm\">{{ data[1] }}</td>\n <td class=\"p-0 text-center text-sm\">{{ data[2] }}</td>\n </tr>\n </ng-template>\n </p-table>\n <ipt-loader *ngIf=\"isLoadingSelectLevels\"></ipt-loader>\n </div>\n\n </form>\n </div>\n\n <div class=\"flex justify-content-between mt-3 align-items-center gap-3\">\n <!-- <span *ngIf=\"codSelfFormStepOne.invalid && codSelfFormStepOne.touched\" class=\"text-red-500 font-bold text-center mt-1 py-2 bg-red-100 w-full border-round-xl\">{{ errorMessage }}</span> -->\n <button\n pButton\n icon=\"pi pi-arrow-left\"\n type=\"submit\"\n (click)=\"back()\"\n ></button>\n\n <button\n pButton\n icon=\"pi pi-arrow-right\"\n [disabled]=\"!codSelfFormStepThree.valid\"\n (click)=\"sendForm()\"\n ></button>\n </div>\n </div>\n </div>\n</div>\n", styles: [".error-message{font-size:x-small;color:red}:host ::ng-deep .p-toast{width:20rem!important}.container-form{margin:5%;border-radius:3px;border:1px solid #2563eb;box-shadow:#3c40434d 0 1px 2px,#3c404326 0 2px 6px 2px;padding:1rem}:host ::ng-deep .p-datatable.p-datatable-hoverable-rows .p-datatable-tbody>tr:not(.p-highlight):hover{color:#1c77f7!important}.selected-row{background-color:#bfdbfe!important;color:#1c77f7!important}tr{cursor:pointer}td,.header-reports-advisers{font-family:Poppins,sans-serif}:host ::ng-deep .p-datatable .p-datatable-header{background:#f8f9fa;color:#f8f9fa;border:none;padding:1rem;font-weight:700;background-color:#1c77f7;border-radius:10px 10px 0 0}:host ::ng-deep .p-datatable{position:relative;border-radius:10px;border:1px solid #1c77f7}:host ::ng-deep .p-datatable>.p-datatable-wrapper{border-radius:0 0 10px 10px}.container_selects{width:16rem}.p-datatable .p-datatable-tbody>tr>td{padding:.1rem .5rem}:host ::ng-deep .p-datatable .p-datatable-tbody>tr>td{padding:0rem!important}\n"] }]
|
|
258
|
+
}], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i2.MessageService }, { type: i3.CommercialService }, { type: i4.BaseService }, { type: i5.CodSelfManagedControls }, { type: i6.CalculateQuotesService }]; }, propDecorators: { completed: [{
|
|
259
|
+
type: Output
|
|
260
|
+
}], financingData: [{
|
|
261
|
+
type: Output
|
|
262
|
+
}] } });
|
|
263
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cod-self-form-step-three.component.js","sourceRoot":"","sources":["../../../../../../../design-system/src/lib/cod-self-managed/steps/cod-form-step-three/cod-self-form-step-three.component.ts","../../../../../../../design-system/src/lib/cod-self-managed/steps/cod-form-step-three/cod-self-form-step-three.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Output, OnInit } from '@angular/core';\nimport { FormGroup, Validators, FormBuilder } from '@angular/forms';\n\n//import services\nimport { CodSelfManagedControls } from './../../logic/cod-self-managed-controls';\nimport { localStorageValuesTwo } from './../../logic/cod-self-managed-steps';\nimport { CalculateQuotesParams, CalculateQuotesService } from './../../logic/calculate-quotes.service';\nimport { BaseService } from './../../../core/utils/base-service/base.service';\nimport { IObtainCodPricesRq } from './../../../core/models/commercial/commercial.model';\nimport { CodSelfManagedSteps } from '../../logic/cod-self-managed-steps';\nimport { CommercialService } from '../../../core/services/commercial-service/comercial.service';\n\n//import Prime ng and Library Alert\nimport { MessageService } from 'primeng/api';\nimport Swal from 'sweetalert2';\n\n@Component({\n  selector: 'app-cod-self-form-step-three',\n  templateUrl: './cod-self-form-step-three.component.html',\n  styleUrls: ['./cod-self-form-step-three.component.css'],\n})\nexport class CodSelfFormStepThreeComponent extends CodSelfManagedSteps implements OnInit {\n\n  @Output() completed = new EventEmitter<number>();\n  @Output() financingData = new EventEmitter<any>();\n\n  controls = new CodSelfManagedControls().controls[2];\n  messageInfo:string = \"Selecciona un plan de pagos\";\n  visible: boolean = false;\n  codSelfFormStepThree!: FormGroup;\n  paymentMethods: any[] = [\n    { code: '1', name: 'Financiado' },\n    { code: '2', name: 'Contado' },\n  ];\n  feeResponse: boolean = false;\n  thereArePlans: boolean = false;\n  dataPrices:any;\n  isFinancing: boolean = false;\n  dataFinancingMaster: any[] = [];\n  dataFinancing: any[] = [];\n  selectedRow: number | null = null;\n  errorMessage: string = 'Faltan campos por llenar.';\n  totalInitialPaymentSpan?: number;\n  isLoadingSelectLevels = false;\n  totalInitialPayment?: number;\n\n  constructor(\n    private fb: FormBuilder,\n    private messageService: MessageService,\n    private commercialService: CommercialService,\n    private baseService: BaseService,\n    private codFormControls: CodSelfManagedControls,\n    private calculateQuotesService: CalculateQuotesService) {\n    super();\n    this.initForm();\n  }\n\n  initForm() {\n    this.codSelfFormStepThree = this.fb.group({\n      program_price: [{ value: '', disabled: true }, [Validators.required]],\n      payment_date: ['' , [Validators.required]],\n      payment_method: ['', [Validators.required]],\n      quota_times: [{ value: '', disabled: true }, [Validators.required]],\n      total_price: [{ value: '', disabled: true }, [Validators.required]],\n      paid_level: ['', [Validators.required]],\n      quota_price: ['', [Validators.required]],\n      fee_number: ['', [Validators.required]],\n      selectedRow: [null],\n    });\n    this.listenPaymentMethodField();\n  }\n  ngOnInit(): void {\n    this.startLocalStorageWork();\n    const currentDate = new Date().toISOString().split('T')[0];\n    this.codSelfFormStepThree.controls['payment_date'].setValue(currentDate)\n\n    this.codSelfFormStepThree.get('payment_method')?.valueChanges.subscribe(() => {\n      this.selectedRow = null;\n      this.codSelfFormStepThree.controls['selectedRow'].setValue(null);\n      this.codSelfFormStepThree.controls['fee_number'].setValue(null);\n      this.codSelfFormStepThree.controls['quota_price'].setValue(null);\n      this.codSelfFormStepThree.controls['paid_level'].setValue(null);\n      this.codSelfFormStepThree.controls['selectedRow'].setValue(null);\n    });\n  }\n  startLocalStorageWork() {\n    this.controls.forEach(control => {\n      let localStorageValue: localStorageValuesTwo = this.readAndWriteLS(3, control.name);\n      this.codSelfFormStepThree.controls[control.name].setValue(localStorageValue.value);\n      this.listenFormChanges(3, control.name, this.codSelfFormStepThree.controls[control.name].valueChanges);\n    });\n  }\n\n  listenPaymentMethodField() {\n    const control = this.codSelfFormStepThree.get('payment_method');\n    control?.valueChanges.subscribe((change) => {\n      // Financiado\n      if (change === '1') {\n        // Poner validaciones\n        this.codSelfFormStepThree.controls['program_price'].setValidators([Validators.required]);\n        this.codSelfFormStepThree.controls['payment_date'].setValidators([Validators.required]);\n        this.codSelfFormStepThree.controls['quota_times'].setValidators([Validators.required]);\n        this.codSelfFormStepThree.controls['total_price'].setValidators([Validators.required]);\n\n        this.updateValueAndValidity();\n        this.updateGlobalControls(change)\n      }\n\n      // de contado\n      if (change === '2') {\n        // Quitar las validaciones\n        this.codSelfFormStepThree.controls['program_price'].setValidators([Validators.required]);\n        this.codSelfFormStepThree.controls['payment_date'].setValidators([Validators.required]);\n        this.codSelfFormStepThree.controls['quota_times'].clearValidators();\n        this.codSelfFormStepThree.controls['total_price'].setValidators([Validators.required]);\n\n        this.updateValueAndValidity();\n        this.updateGlobalControls(change)\n      }\n    });\n  }\n  updateGlobalControls(change: string) {\n    let controls = this.controls.filter(control => control.name !== 'payment_method');\n    controls.forEach(control => {\n      if (change === '1') this.codFormControls.changeValue(3, control.name, true)\n      if (change === '2') {\n        if (control.name === 'quota_times') this.codFormControls.changeValue(3, control.name, false);\n      }\n    });\n  }\n  onReject() {\n    this.messageService.clear('confirm');\n    this.visible = false;\n  }\n\n  showConfirm() {\n    if (!this.visible) {\n        this.messageService.add({ key: 'confirm', sticky: true, severity: 'success', summary: 'Can you send me the report?', life: 5000 });\n        this.visible = true;\n    }\n  }\n\n  selectPaymentMethod(paymentMethod: any) {\n    this.feeResponse = true;\n    this.thereArePlans = false;\n\n    if (paymentMethod !== '') {\n      const request: IObtainCodPricesRq = {\n        token:            this.baseService.getUserToken(),\n        course_type:      Number(this.localStorageCOD.getCodFormData(2, 'course_type')),\n        agreement:        Number(this.localStorageCOD.getCodFormData(1, 'agreement_by_category')),\n        course_modality:  Number(this.localStorageCOD.getCodFormData(2, 'course_modality')),\n        payment_method:   parseInt(paymentMethod)\n      }\n      this.commercialService.ObtainCodPricesCodSelfManaged(request).subscribe((response)=> {\n        if (response.data != null) {\n          this.dataPrices = response.data;\n          this.feeResponse = false;\n          this.thereArePlans = true;\n        }else {\n          this.thereArePlans = false;\n          this.feeResponse = false;\n          Swal.fire({\n            position: 'center',\n            icon: 'warning',\n            title:\n              '<p style=\"font-family: Poppins\"\">Oops.. no hay planes de pagos, \\n en el curso elegido.</p>',\n            showConfirmButton: false,\n            timer: 3000,\n          });\n          this.clearInputPayment();\n        }\n      });\n      this.codSelfFormStepThree.controls['payment_method'].setValue(paymentMethod);\n    } else {\n      this.codSelfFormStepThree.controls['payment_method'].setValue(null);\n    }\n  }\n\n  clearInputPayment(){\n    this.codSelfFormStepThree.controls['program_price'].setValue(null);\n    this.codSelfFormStepThree.controls['quota_times'].setValue(null);\n    this.codSelfFormStepThree.controls['total_price'].setValue(null);\n  }\n  back() {\n    this.completed.emit(1);\n  }\n\n  sendForm() {\n\n    this.completed.emit(3);\n  }\n\n  showTable() {\n    this.isLoadingSelectLevels = true;\n    this.isFinancing = true;\n    this.financingData.emit(null);\n    const total_price = this.codSelfFormStepThree.controls['total_price'].value;\n    if ((total_price === 'null') || this.codSelfFormStepThree.invalid) {\n      Swal.fire({\n        title: 'Error table',\n        text: 'Debes ingresar el monto total de la matrícula y la cuota inicial',\n        icon: 'error'\n      })\n      return;\n    }\n\n    // Calcular cuotas\n    this.dataFinancing = [];\n\n    let params: CalculateQuotesParams = {\n      date: new Date(this.codSelfFormStepThree.controls['payment_date'].value),\n      quotaValues: Number(this.codSelfFormStepThree.controls['quota_price'].value),\n      quotaTimes: Number(this.codSelfFormStepThree.controls['fee_number'].value),\n      totalPrice: this.codSelfFormStepThree.controls['total_price'].value,\n    }\n\n    this.dataFinancingMaster = this.calculateQuotesService.calculateQuotes(params);\n    if (this.dataFinancingMaster.length > 1) {\n\n      const enrollmentValue = this.dataFinancingMaster[0][1];\n      const firstQuotaValue = this.dataFinancingMaster[1][1];\n      this.totalInitialPaymentSpan = parseFloat(enrollmentValue.replace(/[^\\d.-]/g, '')) + parseFloat(firstQuotaValue.replace(/[^\\d.-]/g, ''));\n\n      const enrollmentValueTwo = parseFloat(this.dataFinancingMaster[0][1].replace(/[^\\d.-]/g, ''));\n      const firstQuotaValueTwo = parseFloat(this.dataFinancingMaster[1][1].replace(/[^\\d.-]/g, ''));\n      this.totalInitialPayment = enrollmentValueTwo + firstQuotaValueTwo;\n\n      const totalInitialPaymentInteger = Math.round(this.totalInitialPayment);\n\n      const formattedTotalInitialPayment = new Intl.NumberFormat('en-US', { style: 'currency', currency: 'USD',minimumFractionDigits: 0 }).format(totalInitialPaymentInteger);\n\n      const combinedRecord = [\n        this.dataFinancingMaster[0][0],\n        formattedTotalInitialPayment,\n        this.dataFinancingMaster[0][2]\n      ];\n      this.dataFinancing = [combinedRecord, ...this.dataFinancingMaster.slice(2)];\n    }\n    this.isFinancing = true;\n    this.financingData.emit(this.dataFinancingMaster);\n    this.isLoadingSelectLevels = false;\n  }\n\n  selectLevels(dataPayment: any, rowIndex: number){\n    rowIndex\n    if (this.codSelfFormStepThree.get('payment_method')?.value == 1) {\n      this.selectedRow = rowIndex;\n      this.codSelfFormStepThree.controls['selectedRow'].setValue(rowIndex);\n      this.codSelfFormStepThree.controls['quota_times'].setValue(dataPayment.code);\n      this.codSelfFormStepThree.controls['total_price'].setValue(dataPayment.enrollment);\n      this.codSelfFormStepThree.controls['program_price'].setValue(dataPayment.financed_price);\n      this.codSelfFormStepThree.controls['paid_level'].setValue(dataPayment.paid_level - 1);\n      this.codSelfFormStepThree.controls['fee_number'].setValue(dataPayment.fee_number);\n      this.codSelfFormStepThree.controls['quota_price'].setValue(dataPayment.quota_price);\n      this.updateValueAndValidity();\n      this.showTable();\n    } else if(this.codSelfFormStepThree.get('payment_method')?.value == 2){\n      this.selectedRow = rowIndex;\n      this.codSelfFormStepThree.controls['selectedRow'].setValue(rowIndex);\n      this.codSelfFormStepThree.controls['quota_times'].setValue(dataPayment.code);\n      this.codSelfFormStepThree.controls['total_price'].setValue(dataPayment.enrollment);\n      this.codSelfFormStepThree.controls['program_price'].setValue(dataPayment.normal_price);\n      this.codSelfFormStepThree.controls['paid_level'].setValue(dataPayment.paid_level - 1);\n      this.codSelfFormStepThree.controls['fee_number'].setValue(dataPayment.fee_number);\n      this.codSelfFormStepThree.controls['quota_price'].setValue(dataPayment.quota_price);\n      this.updateValueAndValidity();\n    }\n  }\n\n  updateValueAndValidity() {\n    this.codSelfFormStepThree.controls['program_price'].updateValueAndValidity();\n    this.codSelfFormStepThree.controls['payment_date'].updateValueAndValidity();\n    this.codSelfFormStepThree.controls['quota_times'].updateValueAndValidity();\n    this.codSelfFormStepThree.controls['total_price'].updateValueAndValidity();\n  }\n\n}\n","<div class=\"container-main\">\n  <div class=\"container-form\">\n    <h2>Pagos</h2>\n    <p-toast position=\"top-center\" key=\"confirm\" (onClose)=\"onReject()\" [baseZIndex]=\"10\">\n      <ng-template let-message pTemplate=\"message\">\n          <div class=\"flex flex-column align-items-start\" style=\"flex: 1\">\n              <div class=\"flex align-items-center gap-2\">\n                  <img src=\"./assets/logos/reading.png\" style=\"width: 65px;\" shape=\"circle\" />\n                  <span class=\"font-bold text-900\">Jacob</span>\n              </div>\n              <div class=\"font-medium text-lg my-3 text-900\">{{ messageInfo }}</div>\n          </div>\n      </ng-template>\n    </p-toast>\n    <i class=\"pi pi-exclamation-circle cursor-pointer w-auto\" (click)=\"showConfirm()\" pTooltip=\"Mas info.\" tooltipPosition=\"bottom\"></i>\n    <div class=\"animate__animated animate__slideInRight ng-star-inserted\">\n      <div class=\"container__body__select flex justify-content-center flex-wrap\">\n\n        <form autocomplete=\"off\" [formGroup]=\"codSelfFormStepThree\" class=\"grid mt-2 flex flex-column align-items-center\">\n\n          <div class=\"container_selects col-12\">\n            <ipt-select\n              [initialValue]=\"codSelfFormStepThree.controls['payment_method'].value\"\n              [control]=\"codSelfFormStepThree.controls['payment_method']\"\n              (eventSelect)=\"selectPaymentMethod($event)\"\n              [data]=\"paymentMethods\"\n              [defaultText]=\"'Método de pago'\"\n            ></ipt-select>\n            <ipt-loader *ngIf=\"feeResponse\"></ipt-loader>\n\n            <div class=\"col-12\" *ngIf=\"thereArePlans\">\n              <p-table\n                [value]=\"dataPrices\"\n                [tableStyle]=\"{'min-width': '100%'}\"\n                [rowHover]=\"true\"\n              >\n                <ng-template pTemplate=\"caption\">\n                  <div class=\"flex align-items-center\">\n                    Click en niveles a cancelar\n                  </div>\n                </ng-template>\n                <ng-template pTemplate=\"header\">\n                  <tr>\n                    <th class=\"bg-blue-200 text-center font-medium pt-2 pb-2\"></th>\n                    <th class=\"bg-blue-200 text-center font-medium pt-2 pb-2\">Cancelar</th>\n                    <th class=\"bg-blue-200 text-center font-medium pt-2 pb-2\">Cuotas</th>\n                  </tr>\n                </ng-template>\n                <ng-template pTemplate=\"body\" let-data let-rowIndex=\"rowIndex\">\n                  <tr [class.selected-row]=\"selectedRow === rowIndex\" (click)=\"selectLevels(data, rowIndex)\">\n                    <td class=\"pt-0 pb-0 text-center\">\n                      <p-radioButton [value]=\"rowIndex\" formControlName=\"selectedRow\"></p-radioButton>\n                    </td>\n                    <td class=\"pt-1 pb-1\">{{ data.paid_level }} {{ data.paid_level == 1 ? \"Nivel\" : \"Niveles\"}}</td>\n                    <td class=\"pt-1 pb-1 text-center\">{{ data.fee_number }}</td>\n                  </tr>\n                </ng-template>\n              </p-table>\n            </div>\n          </div>\n\n          <div class=\"container_selects col-12\">\n            <ipt-input\n              [inputType]=\"'text'\"\n              [placeHolder]=\"'Monto total de la matrícula'\"\n              [control]=\"codSelfFormStepThree.controls['total_price']\"\n              [withPipe]=\"true\"\n            ></ipt-input>\n          </div>\n\n          <div class=\"container_selects col-12\">\n            <ipt-input\n              [withPipe]=\"true\"\n              [inputType]=\"'text'\"\n              [control]=\"codSelfFormStepThree.controls['program_price']\"\n              [placeHolder]=\"'Valor total del programa'\"\n            ></ipt-input>\n          </div>\n\n          <div class=\"flex justify-content-center flex-wrap m-2\">\n          </div>\n\n          <!-- Tabla de financiación -->\n          <div class=\"col-12\" *ngIf=\"codSelfFormStepThree.controls['payment_method'].value === '1' && isFinancing\">\n            <div class=\"flex gap-1 md:gap-4 xl:gap-8 m-1 p-2 border-round bg-blue-500 text-white\">\n              <div class=\"container_icon flex mr-4 justify-content-center align-items-start mt-1\">\n                <i class=\"pi pi-info-circle cursor-pointer w-auto mb-4\" pTooltip=\"Mas info.\" tooltipPosition=\"bottom\"></i>\n              </div>\n              <div class=\"flex flex-column container_info_span flex align-items-center justify-content-center\">\n                <span><strong>NOTA:</strong> Deberá pagar la matrícula y la primera cuota <strong>(total: ${{ totalInitialPaymentSpan }})</strong> para completar el proceso de inscripción.</span><br>\n                <span>Recuerda que las fechas cambian de acuerdo a la fecha que comienza el plan</span>\n              </div>\n            </div>\n\n            <p-table\n              *ngIf=\"!isLoadingSelectLevels\"\n              [value]=\"dataFinancing\"\n              [tableStyle]=\"{'min-width': '100%'}\"\n              [rowHover]=\"true\"\n            >\n              <ng-template pTemplate=\"caption\">\n                <div class=\"flex align-items-center\">\n                  Cálculo de cuotas\n                </div>\n              </ng-template>\n              <ng-template pTemplate=\"header\">\n                <tr>\n                  <th class=\"bg-blue-200 text-center font-medium pt-2 pb-2\">#</th>\n                  <th class=\"bg-blue-200 text-center font-medium pt-2 pb-2\">Valor</th>\n                  <th class=\"bg-blue-200 text-center font-medium pt-2 pb-2\">Fecha</th>\n                </tr>\n              </ng-template>\n              <ng-template pTemplate=\"body\" let-data>\n                <tr>\n                  <td class=\"p-0 text-center text-sm\">{{ data[0] }}</td>\n                  <td class=\"p-0 text-center text-sm\">{{ data[1] }}</td>\n                  <td class=\"p-0 text-center text-sm\">{{ data[2] }}</td>\n                </tr>\n              </ng-template>\n            </p-table>\n            <ipt-loader *ngIf=\"isLoadingSelectLevels\"></ipt-loader>\n          </div>\n\n        </form>\n      </div>\n\n      <div class=\"flex justify-content-between mt-3 align-items-center gap-3\">\n        <!-- <span *ngIf=\"codSelfFormStepOne.invalid && codSelfFormStepOne.touched\" class=\"text-red-500 font-bold text-center mt-1 py-2 bg-red-100 w-full border-round-xl\">{{ errorMessage }}</span> -->\n        <button\n        pButton\n        icon=\"pi pi-arrow-left\"\n        type=\"submit\"\n        (click)=\"back()\"\n        ></button>\n\n        <button\n        pButton\n        icon=\"pi pi-arrow-right\"\n        [disabled]=\"!codSelfFormStepThree.valid\"\n        (click)=\"sendForm()\"\n        ></button>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|