iptdevs-design-system 3.1.4395 → 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
|
@@ -18,59 +18,31 @@ export class CodSelfManagedControls {
|
|
|
18
18
|
{ name: 'student_email', required: true, description: 'Correo del estudiante' },
|
|
19
19
|
{ name: 'student_phone_indicative', required: true, description: 'Indicativo del estudiante' },
|
|
20
20
|
{ name: 'student_phone_number', required: true, description: 'Teléfono del estudiante' },
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
// { name: 'student_occupation', required: true, description: 'Ocupación del estudiante' },
|
|
24
|
-
// { name: 'stratum', required: true, description: 'Estrato del estudiante' },
|
|
25
|
-
// { name: 'grade', required: true, description: 'Grado del estudiante' },
|
|
26
|
-
// { name: 'civil_status', required: true, description: 'Estado civil del estudiante' },
|
|
27
|
-
// { name: 'password', required: true, description: 'Contraseña del estudiante' },
|
|
28
|
-
// { name: 're_password', required: true, description: 'Confirmación de contraseña' },
|
|
21
|
+
{ name: 'grade', required: true, description: 'Grado del estudiante' },
|
|
22
|
+
{ name: 'agreement_by_category', required: true, description: 'Convenio' },
|
|
29
23
|
],
|
|
30
24
|
[
|
|
31
|
-
{ name: '
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
// { name: 'availible_courses', required: false, description: 'Cursos disponibles' },
|
|
37
|
-
// { name: 'course_modality', required: false, description: 'Modalidad del curso' },
|
|
25
|
+
{ name: 'academic_plan', required: true, description: 'Plan académico' },
|
|
26
|
+
{ name: 'course_type', required: true, description: 'Tipo de curso' },
|
|
27
|
+
{ name: 'english_level', required: true, description: 'Nivel de inglés' },
|
|
28
|
+
{ name: 'availible_courses', required: false, description: 'Cursos disponibles' },
|
|
29
|
+
{ name: 'course_modality', required: false, description: 'Modalidad del curso' },
|
|
38
30
|
],
|
|
39
|
-
// [
|
|
40
|
-
// { name: 'parent_id_card_type', required: true, description: 'Tipo de documento del acudiente' },
|
|
41
|
-
// { name: 'parent_id_card', required: true, description: 'Documento del acudiente' },
|
|
42
|
-
// { name: 'parent_last_name', required: true, description: 'Apellidos del acudiente' },
|
|
43
|
-
// { name: 'parent_name', required: true, description: 'Nombres del acudiente' },
|
|
44
|
-
// { name: 'needAtendant', required: true, description: '¿Requiere acudiente?' },
|
|
45
|
-
// { name: 'parent_phone_indicative', required: true, description: 'Indicativo del acudiente' },
|
|
46
|
-
// { name: 'parent_occupation', required: true, description: 'Ocupación del acudiente' },
|
|
47
|
-
// { name: 'parent_address', required: true, description: 'Dirección del acudiente' },
|
|
48
|
-
// { name: 'parent_phone_number', required: true, description: 'Teléfono del acudiente' }
|
|
49
|
-
// ],
|
|
50
31
|
[
|
|
51
|
-
{ name: 'payment_date', required: true, description: 'Fecha de pago' },
|
|
52
32
|
{ name: 'program_price', required: true, description: 'Valor total del programa' },
|
|
33
|
+
{ name: 'payment_date', required: true, description: 'Fecha de pago' },
|
|
53
34
|
{ name: 'payment_method', required: true, description: 'Método de pago' },
|
|
54
35
|
{ name: 'quota_times', required: true, description: 'Cantidad de cuotas' },
|
|
55
36
|
{ name: 'total_price', required: true, description: 'Precio total de la matricula' },
|
|
56
37
|
{ name: 'paid_level', required: true, description: 'Niveles pagos' },
|
|
57
38
|
],
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
// { name: 'multiculturalism_2', required: false, description: 'Multiculturalismo' },
|
|
66
|
-
// { name: 'multiculturalism_3', required: false, description: 'Multiculturalismo' },
|
|
67
|
-
// { name: 'multiculturalism_4', required: false, description: 'Multiculturalismo' },
|
|
68
|
-
// { name: 'multiculturalism_5', required: false, description: 'Multiculturalismo' },
|
|
69
|
-
// { name: 'multiculturalism_6', required: false, description: 'Multiculturalismo' },
|
|
70
|
-
// { name: 'health_regimen', required: true, description: 'Régimen de salud' },
|
|
71
|
-
// { name: 'code_refers', required: true, description: 'Refiere' },
|
|
72
|
-
// { name: 'code_cod', required: false, description: 'Codigo Cod' }
|
|
73
|
-
// ],
|
|
39
|
+
[
|
|
40
|
+
{ name: 'optionsPayments', required: true, description: 'Tipo de pago' },
|
|
41
|
+
{ name: 'invoicing_name', required: true, description: 'Nombre de facturacion' },
|
|
42
|
+
{ name: 'invoicing_Apellido', required: true, description: 'Apellido de facturacion' },
|
|
43
|
+
{ name: 'invoicing_idType', required: true, description: 'Tipo de documento de facturacion' },
|
|
44
|
+
{ name: 'invoicing_document', required: true, description: 'documento de facturacion' },
|
|
45
|
+
],
|
|
74
46
|
];
|
|
75
47
|
this.$controls = new BehaviorSubject([]);
|
|
76
48
|
this.$controls.next(this.controls);
|
|
@@ -94,4 +66,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.7", ngImpor
|
|
|
94
66
|
providedIn: 'root'
|
|
95
67
|
}]
|
|
96
68
|
}], ctorParameters: function () { return []; } });
|
|
97
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cod-self-managed-controls.js","sourceRoot":"","sources":["../../../../../../design-system/src/lib/cod-self-managed/logic/cod-self-managed-controls.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from \"@angular/core\";\nimport { BehaviorSubject, Observable } from \"rxjs\";\n\nexport interface ControlSteps {\n  name: string;\n  required: boolean;\n  description: string;\n}\n@Injectable({\n  providedIn: 'root'\n})\nexport class CodSelfManagedControls {\n\n  public controls: Array<ControlSteps[]> = [\n    [\n      { name: 'student_name', required: true, description: 'Nombres del estudiante' },\n      { name: 'student_last_name', required: true, description: 'Apellidos del estudiante' },\n      { name: 'student_id_card_type', required: true, description: 'Tipo de documento del estudiante' },\n      { name: 'student_id_card', required: true, description: 'Documento del estudiante' },\n      { name: 'gender', required: true, description: 'Género' },\n      { name: 'birthdate', required: true, description: 'Fecha de nacimiento del estudiante' },\n      { name: 'age', required: true, description: 'Edad' },\n      { name: 'country', required: true, description: 'País' },\n      { name: 'state', required: true, description: 'Departamento o estado' },\n      { name: 'city', required: true, description: 'Ciudad de residencia' },\n      { name: 'student_email', required: true, description: 'Correo del estudiante' },\n      { name: 'student_phone_indicative', required: true, description: 'Indicativo del estudiante' },\n      { name: 'student_phone_number', required: true, description: 'Teléfono del estudiante' },\n      // { name: 'student_address', required: true, description: 'Dirección del estudiante' },\n      // { name: 'nickname', required: true, description: 'Alias o nickname' },\n      // { name: 'student_occupation', required: true, description: 'Ocupación del estudiante' },\n      // { name: 'stratum', required: true, description: 'Estrato del estudiante' },\n      // { name: 'grade', required: true, description: 'Grado del estudiante' },\n      // { name: 'civil_status', required: true, description: 'Estado civil del estudiante' },\n      // { name: 'password', required: true, description: 'Contraseña del estudiante' },\n      // { name: 're_password', required: true, description: 'Confirmación de contraseña' },\n    ],\n    [\n      { name: 'schedule', required: true, description: 'horario requerido' },\n      // { name: 'academic_plan', required: true, description: 'Plan académico' },\n      // { name: 'course_type', required: true, description: 'Tipo de curso' },\n      // { name: 'agreement_by_category', required: true, description: 'Convenio' },\n      // { name: 'english_level', required: true, description: 'Nivel de inglés' },\n      // { name: 'availible_courses', required: false, description: 'Cursos disponibles' },\n      // { name: 'course_modality', required: false, description: 'Modalidad del curso' },\n    ],\n    // [\n    //   { name: 'parent_id_card_type', required: true, description: 'Tipo de documento del acudiente' },\n    //   { name: 'parent_id_card', required: true, description: 'Documento del acudiente' },\n    //   { name: 'parent_last_name', required: true, description: 'Apellidos del acudiente' },\n    //   { name: 'parent_name', required: true, description: 'Nombres del acudiente' },\n    //   { name: 'needAtendant', required: true, description: '¿Requiere acudiente?' },\n    //   { name: 'parent_phone_indicative', required: true, description: 'Indicativo del acudiente' },\n    //   { name: 'parent_occupation', required: true, description: 'Ocupación del acudiente' },\n    //   { name: 'parent_address', required: true, description: 'Dirección del acudiente' },\n    //   { name: 'parent_phone_number', required: true, description: 'Teléfono del acudiente' }\n    // ],\n    [\n      { name: 'payment_date', required: true, description: 'Fecha de pago' },\n      { name: 'program_price', required: true, description: 'Valor total del programa' },\n      { name: 'payment_method', required: true, description: 'Método de pago' },\n      { name: 'quota_times', required: true, description: 'Cantidad de cuotas' },\n      { name: 'total_price', required: true, description: 'Precio total de la matricula' },\n      { name: 'paid_level', required: true, description: 'Niveles pagos' },\n    ],\n    // [\n    //   { name: 'marketing_reasons', required: true, description: '¿Cómo se enteró del programa?' },\n    //   { name: 'observation', required: false, description: 'Observación' },\n    //   { name: 'study_reasons', required: true, description: 'Motivo' },\n    //   { name: 'terms', required: true, description: 'Términos y condiciones' },\n    //   { name: 'disability', required: false, description: 'Discapacidad' },\n    //   { name: 'multiculturalism_1', required: false, description: 'Multiculturalismo' },\n    //   { name: 'multiculturalism_2', required: false, description: 'Multiculturalismo' },\n    //   { name: 'multiculturalism_3', required: false, description: 'Multiculturalismo' },\n    //   { name: 'multiculturalism_4', required: false, description: 'Multiculturalismo' },\n    //   { name: 'multiculturalism_5', required: false, description: 'Multiculturalismo' },\n    //   { name: 'multiculturalism_6', required: false, description: 'Multiculturalismo' },\n    //   { name: 'health_regimen', required: true, description: 'Régimen de salud' },\n    //   { name: 'code_refers', required: true, description: 'Refiere' },\n    //   { name: 'code_cod', required: false, description: 'Codigo Cod' }\n    // ],\n  ];\n\n  private $controls = new BehaviorSubject<Array<ControlSteps[]>>([]);\n\n  constructor() {\n    this.$controls.next(this.controls);\n  }\n\n  getControlValues(): Observable<Array<ControlSteps[]>> {\n    return this.$controls.asObservable();\n  }\n\n  // Cambiar los valores de los controls, ejemplo: true y false del checkbox\n  changeValue(step: number, controlName: string, newValue: any) {\n    const controls: Array<ControlSteps[]> = { ...this.controls };\n    let control = controls[step-1].filter(element => element.name === controlName);\n    control[0].required = newValue;\n\n    this.$controls.next(controls)\n  }\n}\n"]}
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cod-self-managed-controls.js","sourceRoot":"","sources":["../../../../../../design-system/src/lib/cod-self-managed/logic/cod-self-managed-controls.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from \"@angular/core\";\nimport { BehaviorSubject, Observable } from \"rxjs\";\n\nexport interface ControlSteps {\n  name: string;\n  required: boolean;\n  description: string;\n}\n@Injectable({\n  providedIn: 'root'\n})\nexport class CodSelfManagedControls {\n\n  public controls: Array<ControlSteps[]> = [\n    [\n      { name: 'student_name', required: true, description: 'Nombres del estudiante' },\n      { name: 'student_last_name', required: true, description: 'Apellidos del estudiante' },\n      { name: 'student_id_card_type', required: true, description: 'Tipo de documento del estudiante' },\n      { name: 'student_id_card', required: true, description: 'Documento del estudiante' },\n      { name: 'gender', required: true, description: 'Género' },\n      { name: 'birthdate', required: true, description: 'Fecha de nacimiento del estudiante' },\n      { name: 'age', required: true, description: 'Edad' },\n      { name: 'country', required: true, description: 'País' },\n      { name: 'state', required: true, description: 'Departamento o estado' },\n      { name: 'city', required: true, description: 'Ciudad de residencia' },\n      { name: 'student_email', required: true, description: 'Correo del estudiante' },\n      { name: 'student_phone_indicative', required: true, description: 'Indicativo del estudiante' },\n      { name: 'student_phone_number', required: true, description: 'Teléfono del estudiante' },\n      { name: 'grade', required: true, description: 'Grado del estudiante' },\n      { name: 'agreement_by_category', required: true, description: 'Convenio' },\n    ],\n    [\n      { name: 'academic_plan', required: true, description: 'Plan académico' },\n      { name: 'course_type', required: true, description: 'Tipo de curso' },\n      { name: 'english_level', required: true, description: 'Nivel de inglés' },\n      { name: 'availible_courses', required: false, description: 'Cursos disponibles' },\n      { name: 'course_modality', required: false, description: 'Modalidad del curso' },\n    ],\n    [\n      { name: 'program_price', required: true, description: 'Valor total del programa' },\n      { name: 'payment_date', required: true, description: 'Fecha de pago' },\n      { name: 'payment_method', required: true, description: 'Método de pago' },\n      { name: 'quota_times', required: true, description: 'Cantidad de cuotas' },\n      { name: 'total_price', required: true, description: 'Precio total de la matricula' },\n      { name: 'paid_level', required: true, description: 'Niveles pagos' },\n    ],\n    [\n      { name: 'optionsPayments', required: true, description: 'Tipo de pago' },\n      { name: 'invoicing_name', required: true, description: 'Nombre de facturacion' },\n      { name: 'invoicing_Apellido', required: true, description: 'Apellido de facturacion' },\n      { name: 'invoicing_idType', required: true, description: 'Tipo de documento de facturacion' },\n      { name: 'invoicing_document', required: true, description: 'documento de facturacion' },\n    ],\n  ];\n\n  private $controls = new BehaviorSubject<Array<ControlSteps[]>>([]);\n\n  constructor() {\n    this.$controls.next(this.controls);\n  }\n\n  getControlValues(): Observable<Array<ControlSteps[]>> {\n    return this.$controls.asObservable();\n  }\n\n  // Cambiar los valores de los controls, ejemplo: true y false del checkbox\n  changeValue(step: number, controlName: string, newValue: any) {\n    const controls: Array<ControlSteps[]> = { ...this.controls };\n    let control = controls[step-1].filter(element => element.name === controlName);\n    control[0].required = newValue;\n\n    this.$controls.next(controls)\n  }\n}\n"]}
|
|
@@ -26,4 +26,4 @@ export class CodSelfManagedSteps {
|
|
|
26
26
|
});
|
|
27
27
|
}
|
|
28
28
|
}
|
|
29
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29kLXNlbGYtbWFuYWdlZC1zdGVwcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2Rlc2lnbi1zeXN0ZW0vc3JjL2xpYi9jb2Qtc2VsZi1tYW5hZ2VkL2xvZ2ljL2NvZC1zZWxmLW1hbmFnZWQtc3RlcHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLGlDQUFpQyxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFPaEYsTUFBTSxPQUFnQixtQkFBbUI7SUFJdkM7UUFGTyxvQkFBZSxHQUFHLElBQUksaUNBQWlDLEVBQUUsQ0FBQztJQUVsRCxDQUFDO0lBRWhCLGNBQWMsQ0FBQyxJQUFZLEVBQUUsT0FBZTtRQUMxQyxJQUFJLElBQUksQ0FBQyxlQUFlLENBQUMsY0FBYyxDQUFDLElBQUksRUFBRSxPQUFPLENBQUMsRUFBRTtZQUN0RCxNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsZUFBZSxDQUFDLGNBQWMsQ0FBQyxJQUFJLEVBQUUsT0FBTyxDQUFDLENBQUM7WUFDakUsT0FBTyxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsQ0FBQztTQUMzQjthQUFNO1lBQ0wsT0FBTyxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsRUFBRSxFQUFFLENBQUE7U0FDOUI7SUFDSCxDQUFDO0lBRUQscUJBQXFCLENBQUMsSUFBWSxFQUFFLE9BQWUsRUFBRSxLQUFVO1FBQzdELElBQUksQ0FBQyxlQUFlLENBQUMsY0FBYyxDQUFDLElBQUksRUFBRSxPQUFPLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDNUQsQ0FBQztJQUVELGlCQUFpQixDQUFDLElBQVksRUFBRSxPQUFlLEVBQUUsR0FBb0I7UUFDbkUsR0FBRyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUNwQixJQUFJLENBQUMscUJBQXFCLENBQUMsSUFBSSxFQUFFLE9BQU8sRUFBRSxLQUFLLENBQUMsQ0FBQztRQUNuRCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxpQkFBaUIsQ0FBQyxRQUF3QjtRQUN4QyxRQUFRLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxFQUFFO1lBQ3pCLFlBQVksQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3hDLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUVGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gXCJyeGpzXCI7XG5pbXBvcnQgeyBDb250cm9sU3RlcHMgfSBmcm9tIFwiLi9jb2Qtc2VsZi1tYW5hZ2VkLWNvbnRyb2xzXCI7XG5pbXBvcnQgeyBMb2NhbFN0b3JhZ2VDb2RTZWxmTWFnYW5lZFNlcnZpY2UgfSBmcm9tIFwiLi9sb2NhbC1zdG9yYWdlLWNvZC5zZXJ2aWNlXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgbG9jYWxTdG9yYWdlVmFsdWVzVHdvIHtcbiAgY29udHJvbDogc3RyaW5nLFxuICB2YWx1ZTogYW55XG59XG5cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBDb2RTZWxmTWFuYWdlZFN0ZXBzIHtcblxuICBwdWJsaWMgbG9jYWxTdG9yYWdlQ09EID0gbmV3IExvY2FsU3RvcmFnZUNvZFNlbGZNYWdhbmVkU2VydmljZSgpO1xuXG4gIGNvbnN0cnVjdG9yKCkge31cblxuICByZWFkQW5kV3JpdGVMUyhzdGVwOiBudW1iZXIsIGNvbnRyb2w6IHN0cmluZyk6IGxvY2FsU3RvcmFnZVZhbHVlc1R3byB7XG4gICAgaWYgKHRoaXMubG9jYWxTdG9yYWdlQ09ELmdldENvZEZvcm1EYXRhKHN0ZXAsIGNvbnRyb2wpKSB7XG4gICAgICBjb25zdCB2YWx1ZSA9IHRoaXMubG9jYWxTdG9yYWdlQ09ELmdldENvZEZvcm1EYXRhKHN0ZXAsIGNvbnRyb2wpO1xuICAgICAgcmV0dXJuIHsgY29udHJvbCwgdmFsdWUgfTtcbiAgICB9IGVsc2Uge1xuICAgICAgcmV0dXJuIHsgY29udHJvbCwgdmFsdWU6ICcnIH1cbiAgICB9XG4gIH1cblxuICBzZXREYXRhSW5Mb2NhbFN0b3JhZ2Uoc3RlcDogbnVtYmVyLCBjb250cm9sOiBzdHJpbmcsIHZhbHVlOiBhbnkpIHtcbiAgICB0aGlzLmxvY2FsU3RvcmFnZUNPRC5zZXRDb2RGb3JtRGF0YShzdGVwLCBjb250cm9sLCB2YWx1ZSk7XG4gIH1cblxuICBsaXN0ZW5Gb3JtQ2hhbmdlcyhzdGVwOiBudW1iZXIsIGNvbnRyb2w6IHN0cmluZywgb2JzOiBPYnNlcnZhYmxlPGFueT4pIHtcbiAgICBvYnMuc3Vic2NyaWJlKHZhbHVlID0+IHtcbiAgICAgIHRoaXMuc2V0RGF0YUluTG9jYWxTdG9yYWdlKHN0ZXAsIGNvbnRyb2wsIHZhbHVlKTtcbiAgICB9KTtcbiAgfVxuXG4gIHJlc2V0TG9jYWxTdG9yYWdlKGNvbnRyb2xzOiBDb250cm9sU3RlcHNbXSkge1xuICAgIGNvbnRyb2xzLmZvckVhY2goY29udHJvbCA9PiB7XG4gICAgICBsb2NhbFN0b3JhZ2UucmVtb3ZlSXRlbShjb250cm9sLm5hbWUpO1xuICAgIH0pO1xuICB9XG5cbn1cbiJdfQ==
|
package/esm2020/lib/cod-self-managed/steps/cod-form-step-four/cod-self-form-step-four.component.mjs
CHANGED
|
@@ -1,11 +1,248 @@
|
|
|
1
|
-
import { Component } from '@angular/core';
|
|
1
|
+
import { Component, Output, EventEmitter, Input } from '@angular/core';
|
|
2
|
+
import { Validators, FormControl } from '@angular/forms';
|
|
3
|
+
import { CodSelfManagedSteps } from '../../logic/cod-self-managed-steps';
|
|
4
|
+
import { CodSelfManagedControls } from '../../logic/cod-self-managed-controls';
|
|
2
5
|
import * as i0 from "@angular/core";
|
|
3
|
-
|
|
6
|
+
import * as i1 from "@angular/forms";
|
|
7
|
+
import * as i2 from "primeng/api";
|
|
8
|
+
import * as i3 from "../../logic/cod-self-managed-controls";
|
|
9
|
+
import * as i4 from "@angular/common";
|
|
10
|
+
import * as i5 from "../../../components/atoms/button/button.component";
|
|
11
|
+
import * as i6 from "../../../components/atoms/input/input.component";
|
|
12
|
+
import * as i7 from "../../../components/atoms/select/select.component";
|
|
13
|
+
import * as i8 from "primeng/tooltip";
|
|
14
|
+
import * as i9 from "primeng/button";
|
|
15
|
+
import * as i10 from "primeng/toast";
|
|
16
|
+
import * as i11 from "primeng/radiobutton";
|
|
17
|
+
export class CodSelfFormStepFourComponent extends CodSelfManagedSteps {
|
|
18
|
+
constructor(fb, messageService, codFormControls) {
|
|
19
|
+
super();
|
|
20
|
+
this.fb = fb;
|
|
21
|
+
this.messageService = messageService;
|
|
22
|
+
this.codFormControls = codFormControls;
|
|
23
|
+
this.completed = new EventEmitter();
|
|
24
|
+
this.action = new EventEmitter();
|
|
25
|
+
this.controls = new CodSelfManagedControls().controls[3];
|
|
26
|
+
this.messageInfo = "Datos de facturacion de acuerdo a tu eleccion";
|
|
27
|
+
this.visible = false;
|
|
28
|
+
this.messageAlertPlacementTest = false;
|
|
29
|
+
this.disableweekdays = [];
|
|
30
|
+
this.isSelectionOptionPayments = true;
|
|
31
|
+
this.isEditBillingData = true;
|
|
32
|
+
this.OptionPayments = [
|
|
33
|
+
{ code: 1, key: 'in', name: 'Instalaciones' },
|
|
34
|
+
// { code: 2, key: 'tr', name: 'Transferencia' },
|
|
35
|
+
{ code: 3, key: 'ps', name: 'Pasarela pagos' },
|
|
36
|
+
];
|
|
37
|
+
this.studentIdCardType = new FormControl();
|
|
38
|
+
this.initForm();
|
|
39
|
+
}
|
|
40
|
+
ngOnInit() {
|
|
41
|
+
this.startLocalStorageWork();
|
|
42
|
+
this.subscribeToStudentIdCardTypeChanges();
|
|
43
|
+
this.getDataUser();
|
|
44
|
+
}
|
|
45
|
+
initForm() {
|
|
46
|
+
this.codSelfFormStepFour = this.fb.group({
|
|
47
|
+
optionsPayments: ['', [Validators.required]],
|
|
48
|
+
invoicing_name: ['', [Validators.required]],
|
|
49
|
+
invoicing_Apellido: ['', [Validators.required]],
|
|
50
|
+
invoicing_idType: ['', [Validators.required]],
|
|
51
|
+
invoicing_document: ['', [Validators.required, Validators.minLength(5), Validators.maxLength(20), Validators.pattern(/^[0-9]*$/)]],
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
subscribeToStudentIdCardTypeChanges() {
|
|
55
|
+
this.studentIdCardType.valueChanges.subscribe(value => {
|
|
56
|
+
this.updateBillingDataFields(value);
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
getDataUser() {
|
|
60
|
+
const typeIdCard = this.localStorageCOD.getCodFormData(1, 'student_id_card_type');
|
|
61
|
+
this.studentIdCardType.setValue(typeIdCard);
|
|
62
|
+
}
|
|
63
|
+
updateBillingDataFields(typeIdCard) {
|
|
64
|
+
if (typeIdCard != null && typeIdCard != "2") {
|
|
65
|
+
const nameStudent = this.localStorageCOD.getCodFormData(1, 'student_name');
|
|
66
|
+
const lastNameStudent = this.localStorageCOD.getCodFormData(1, 'student_last_name');
|
|
67
|
+
const typeIdCardStudent = this.localStorageCOD.getCodFormData(1, 'student_id_card_type');
|
|
68
|
+
const idCardStudent = this.localStorageCOD.getCodFormData(1, 'student_id_card');
|
|
69
|
+
this.codSelfFormStepFour.controls['invoicing_name'].setValue(nameStudent);
|
|
70
|
+
this.codSelfFormStepFour.controls['invoicing_Apellido'].setValue(lastNameStudent);
|
|
71
|
+
this.codSelfFormStepFour.controls['invoicing_idType'].setValue(typeIdCardStudent);
|
|
72
|
+
this.codSelfFormStepFour.controls['invoicing_document'].setValue(idCardStudent);
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
// Limpia los campos si el tipo de documento es "2"
|
|
76
|
+
this.codSelfFormStepFour.controls['invoicing_name'].setValue('');
|
|
77
|
+
this.codSelfFormStepFour.controls['invoicing_Apellido'].setValue('');
|
|
78
|
+
this.codSelfFormStepFour.controls['invoicing_idType'].setValue('');
|
|
79
|
+
this.codSelfFormStepFour.controls['invoicing_document'].setValue('');
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
back() {
|
|
83
|
+
if (!this.isSelectionOptionPayments && !this.isEditBillingData) {
|
|
84
|
+
this.isEditBillingData = true;
|
|
85
|
+
}
|
|
86
|
+
else if (!this.isSelectionOptionPayments && this.isEditBillingData) {
|
|
87
|
+
this.isSelectionOptionPayments = true;
|
|
88
|
+
}
|
|
89
|
+
else {
|
|
90
|
+
this.completed.emit(2);
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
next() {
|
|
94
|
+
if (this.isSelectionOptionPayments) {
|
|
95
|
+
this.isSelectionOptionPayments = false;
|
|
96
|
+
}
|
|
97
|
+
else if (!this.isEditBillingData) {
|
|
98
|
+
this.isEditBillingData = true;
|
|
99
|
+
}
|
|
100
|
+
else {
|
|
101
|
+
this.sendForm();
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
startLocalStorageWork() {
|
|
105
|
+
this.controls.forEach(control => {
|
|
106
|
+
let localStorageValue = this.readAndWriteLS(4, control.name);
|
|
107
|
+
this.codSelfFormStepFour.controls[control.name].setValue(localStorageValue.value);
|
|
108
|
+
this.listenFormChanges(4, control.name, this.codSelfFormStepFour.controls[control.name].valueChanges);
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
editBillingData() {
|
|
112
|
+
this.isEditBillingData = false;
|
|
113
|
+
}
|
|
114
|
+
updateDatosBillingData() {
|
|
115
|
+
this.isEditBillingData = true;
|
|
116
|
+
}
|
|
117
|
+
sendForm() {
|
|
118
|
+
this.codSelfFormStepFour.markAllAsTouched();
|
|
119
|
+
this.action.emit('create');
|
|
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
|
+
selectOpcionsPayments(eve) {
|
|
132
|
+
this.selectedOptionPayments = eve;
|
|
133
|
+
this.isSelectionOptionPayments = false;
|
|
134
|
+
if (this.selectedOptionPayments !== null) {
|
|
135
|
+
this.codSelfFormStepFour.controls['optionsPayments'].setValue(this.selectedOptionPayments.code);
|
|
136
|
+
if (this.selectedOptionPayments.code === 1) { // Instalaciones
|
|
137
|
+
this.addValidators();
|
|
138
|
+
}
|
|
139
|
+
else if (this.selectedOptionPayments.code === 3) { // Pasarela Pago
|
|
140
|
+
this.removeValidators();
|
|
141
|
+
}
|
|
142
|
+
// Aplicar el validador personalizado basado en la opción seleccionada
|
|
143
|
+
this.codSelfFormStepFour.setValidators(paymentOptionValidator(this.selectedOptionPayments));
|
|
144
|
+
this.codSelfFormStepFour.updateValueAndValidity();
|
|
145
|
+
this.updateGlobalControls(this.selectedOptionPayments.code);
|
|
146
|
+
}
|
|
147
|
+
else {
|
|
148
|
+
this.codSelfFormStepFour.controls['optionsPayments'].setValue(null);
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
addValidators() {
|
|
152
|
+
this.codSelfFormStepFour.controls['invoicing_name'].setValidators([Validators.required]);
|
|
153
|
+
this.codSelfFormStepFour.controls['invoicing_Apellido'].setValidators([Validators.required]);
|
|
154
|
+
this.codSelfFormStepFour.controls['invoicing_idType'].setValidators([Validators.required]);
|
|
155
|
+
this.codSelfFormStepFour.controls['invoicing_document'].setValidators([Validators.required, Validators.minLength(5), Validators.maxLength(20), Validators.pattern(/^[0-9]*$/)]);
|
|
156
|
+
this.codSelfFormStepFour.controls['invoicing_name'].updateValueAndValidity();
|
|
157
|
+
this.codSelfFormStepFour.controls['invoicing_Apellido'].updateValueAndValidity();
|
|
158
|
+
this.codSelfFormStepFour.controls['invoicing_idType'].updateValueAndValidity();
|
|
159
|
+
this.codSelfFormStepFour.controls['invoicing_document'].updateValueAndValidity();
|
|
160
|
+
}
|
|
161
|
+
removeValidators() {
|
|
162
|
+
this.codSelfFormStepFour.controls['invoicing_name'].clearValidators();
|
|
163
|
+
this.codSelfFormStepFour.controls['invoicing_Apellido'].clearValidators();
|
|
164
|
+
this.codSelfFormStepFour.controls['invoicing_idType'].clearValidators();
|
|
165
|
+
this.codSelfFormStepFour.controls['invoicing_document'].clearValidators();
|
|
166
|
+
this.codSelfFormStepFour.controls['invoicing_name'].updateValueAndValidity();
|
|
167
|
+
this.codSelfFormStepFour.controls['invoicing_Apellido'].updateValueAndValidity();
|
|
168
|
+
this.codSelfFormStepFour.controls['invoicing_idType'].updateValueAndValidity();
|
|
169
|
+
this.codSelfFormStepFour.controls['invoicing_document'].updateValueAndValidity();
|
|
170
|
+
}
|
|
171
|
+
selectIdType(idType) {
|
|
172
|
+
if (idType !== 'Tipo de documento') {
|
|
173
|
+
this.codSelfFormStepFour.controls['invoicing_idType'].setValue(idType);
|
|
174
|
+
}
|
|
175
|
+
else {
|
|
176
|
+
this.codSelfFormStepFour.controls['invoicing_idType'].setValue(null);
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
getViewBasedOnPaymentOption() {
|
|
180
|
+
if (this.selectedOptionPayments?.code === 1) {
|
|
181
|
+
return 'in';
|
|
182
|
+
}
|
|
183
|
+
else if (this.selectedOptionPayments?.code === 3) {
|
|
184
|
+
return 'ps';
|
|
185
|
+
}
|
|
186
|
+
return 'default';
|
|
187
|
+
}
|
|
188
|
+
getIdTypeDescription(idType) {
|
|
189
|
+
switch (idType) {
|
|
190
|
+
case '0':
|
|
191
|
+
return 'N/A';
|
|
192
|
+
case '1':
|
|
193
|
+
return 'C.C';
|
|
194
|
+
case '2':
|
|
195
|
+
return 'T.I';
|
|
196
|
+
case '3':
|
|
197
|
+
return 'C.E';
|
|
198
|
+
case '4':
|
|
199
|
+
return 'P.E.P';
|
|
200
|
+
case '5':
|
|
201
|
+
return 'R.U.M';
|
|
202
|
+
case '6':
|
|
203
|
+
return 'P.P.T';
|
|
204
|
+
case '7':
|
|
205
|
+
return 'P.A';
|
|
206
|
+
case '8':
|
|
207
|
+
return 'R.C';
|
|
208
|
+
case '9':
|
|
209
|
+
return 'C.D';
|
|
210
|
+
default:
|
|
211
|
+
return '';
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
updateGlobalControls(change) {
|
|
215
|
+
let controls = this.controls.filter(control => control.name !== 'optionsPayments');
|
|
216
|
+
controls.forEach(control => {
|
|
217
|
+
if (change === 1)
|
|
218
|
+
this.codFormControls.changeValue(4, control.name, true);
|
|
219
|
+
if (change === 3)
|
|
220
|
+
this.codFormControls.changeValue(4, control.name, false);
|
|
221
|
+
});
|
|
222
|
+
}
|
|
4
223
|
}
|
|
5
|
-
CodSelfFormStepFourComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.7", ngImport: i0, type: CodSelfFormStepFourComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
6
|
-
CodSelfFormStepFourComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.7", type: CodSelfFormStepFourComponent, selector: "app-cod-self-form-step-four", ngImport: i0, template: "<span>
|
|
224
|
+
CodSelfFormStepFourComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.7", ngImport: i0, type: CodSelfFormStepFourComponent, deps: [{ token: i1.FormBuilder }, { token: i2.MessageService }, { token: i3.CodSelfManagedControls }], target: i0.ɵɵFactoryTarget.Component });
|
|
225
|
+
CodSelfFormStepFourComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.7", type: CodSelfFormStepFourComponent, selector: "app-cod-self-form-step-four", inputs: { idTypes: "idTypes" }, outputs: { completed: "completed", action: "action" }, usesInheritance: true, ngImport: i0, template: "<div class=\"container-main\">\n <div class=\"container-form\">\n <div class=\"title_step\">\n <h2>Datos de Facturaci\u00F3n</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 </div>\n\n <i class=\"pi pi-exclamation-circle cursor-pointer w-auto \" (click)=\"showConfirm()\" pTooltip=\"M\u00E1s info.\" tooltipPosition=\"bottom\"></i>\n <div class=\"animate__animated animate__slideInRight ng-star-inserted\">\n <form autocomplete=\"off\" [formGroup]=\"codSelfFormStepFour\" class=\"grid mt-2 flex flex-column align-items-center\">\n <div class=\"container__body__select flex justify-content-center flex-wrap\">\n <div class=\"container__type__payments\" *ngIf=\"isSelectionOptionPayments\">\n <div class=\"flex flex-column gap-3\">\n <h3>\u00BFC\u00F3mo quieres pagar?</h3>\n <div *ngFor=\"let category of OptionPayments; index as ind\" class=\"field-checkbox\">\n <p-radioButton\n [inputId]=\"category.key\"\n name=\"category\"\n [value]=\"category\"\n [(ngModel)]=\"selectedOptionPayments\"\n [disabled]=\"disableweekdays[ind]\"\n [ngModelOptions]=\"{ standalone: true }\"\n (ngModelChange)=\"selectOpcionsPayments($event)\"\n ></p-radioButton>\n <label [for]=\"category.key\" class=\"ml-2\">\n {{ category.name }}\n </label>\n </div>\n </div>\n </div>\n\n <div class=\"container__option__instalations\" *ngIf=\"!isSelectionOptionPayments\">\n <!-- Vista para la opci\u00F3n de pago \"Instalaciones\" -->\n <div *ngIf=\"getViewBasedOnPaymentOption() === 'in'\">\n <div class=\"container__info flex flex-column align-items-center justify-content-center mt-1 mb-4\" *ngIf=\"isEditBillingData\">\n <img src=\"./assets/logos/lobo-web.png\" alt=\"Receipt Icon\" shape=\"circle\" class=\"circular-image\" />\n <strong>{{ codSelfFormStepFour.get('invoicing_name')?.value }} {{ codSelfFormStepFour.get('invoicing_Apellido')?.value }}</strong>\n <span>{{ getIdTypeDescription(codSelfFormStepFour.get('invoicing_idType')?.value) }} {{ codSelfFormStepFour.get('invoicing_document')?.value }}</span>\n <div class=\"container-button\">\n <ipt-button [label]=\"'Modificar Datos'\" (onClick)=\"editBillingData()\" [primary]=\"false\"></ipt-button>\n </div>\n </div>\n <div class=\"m-2\" *ngIf=\"!isEditBillingData\">\n <h3>Completa los nuevos datos para la emisi\u00F3n de tu factura</h3>\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=\"M\u00E1s info.\" tooltipPosition=\"bottom\"></i>\n </div>\n <div class=\"flex flex-column container_info_span flex align-items-center justify-content-center\">\n <span>Si proporcionas datos de un tercero, confirmas que los datos son correctos y que tienes su consentimiento para el uso de la informaci\u00F3n. Estos datos se tratar\u00E1n de acuerdo a nuestra <a href=\"\">Declaraci\u00F3n de Privacidad</a></span>\n </div>\n </div>\n <div>\n <ipt-input [inputType]=\"'text'\" [placeHolder]=\"'Nombres'\" [control]=\"codSelfFormStepFour.controls['invoicing_name']\"></ipt-input>\n <ipt-input [inputType]=\"'text'\" [placeHolder]=\"'Apellidos'\" [control]=\"codSelfFormStepFour.controls['invoicing_Apellido']\"></ipt-input>\n <ipt-select\n [initialValue]=\"codSelfFormStepFour.controls['invoicing_idType'].value\"\n [control]=\"codSelfFormStepFour.controls['invoicing_idType']\"\n [selectCode]=\"codSelfFormStepFour.controls['invoicing_idType'].value === null ? 'Tipo de documento' : codSelfFormStepFour.controls['invoicing_idType'].value\"\n [isRequired]=\"true\"\n [data]=\"idTypes\"\n (eventSelect)=\"selectIdType($event)\"\n [defaultText]=\"'Tipo de documento'\"\n ></ipt-select>\n <ipt-input [inputType]=\"'number'\" [placeHolder]=\"'N\u00FAmero de documento'\" [control]=\"codSelfFormStepFour.controls['invoicing_document']\"></ipt-input>\n </div>\n <div class=\"flex justify-content-end mt-3 align-items-center gap-3\">\n <button pButton [disabled]=\"!codSelfFormStepFour.valid\" label=\"Continuar\" type=\"button\" (click)=\"updateDatosBillingData()\"></button>\n </div>\n </div>\n </div>\n\n <!-- Vista para la opci\u00F3n de pago \"Pasarela pagos\" -->\n <div *ngIf=\"getViewBasedOnPaymentOption() === 'ps'\">\n <!-- TODO:<h3>Completa los datos para Pasarela pagos</h3> -->\n <!-- Aqu\u00ED puedes agregar el formulario espec\u00EDfico para Pasarela pagos -->\n </div>\n </div>\n </div>\n </form>\n\n <div class=\"flex justify-content-between mt-3 align-items-center gap-3\">\n <button pButton icon=\"pi pi-arrow-left\" type=\"button\" (click)=\"back()\"></button>\n <button *ngIf=\"!isSelectionOptionPayments && isEditBillingData && codSelfFormStepFour.valid\" pButton label=\"\u00A1Matricularme!\" type=\"button\" (click)=\"sendForm()\"></button>\n </div>\n </div>\n </div>\n</div>\n", styles: [".container-form{margin:5px;border-radius:3px;border:1px solid #2563eb;box-shadow:#3c40434d 0 1px 2px,#3c404326 0 2px 6px 2px;padding:.5rem}.error-message{font-size:x-small;color:red}:host ::ng-deep .p-toast{width:20rem!important}.circular-image{width:50px;height:50px;border-radius:50%;object-fit:cover;border:none}.container-button{width:10rem;margin-top:3%}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.ButtonComponent, selector: "ipt-button", inputs: ["primary", "size", "label", "buttonType", "isEnabled"], outputs: ["onClick"] }, { kind: "component", type: i6.InputComponent, selector: "ipt-input", inputs: ["inputType", "placeHolder", "validateText", "withPipe", "list", "iconUrl", "control", "prefix", "thousands", "decimal", "disabledSel"], outputs: ["dateSelected"] }, { kind: "component", type: i7.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: i8.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "fitContent", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i9.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "component", type: i10.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: i11.RadioButton, selector: "p-radioButton", inputs: ["value", "formControlName", "name", "disabled", "label", "tabindex", "inputId", "ariaLabelledBy", "ariaLabel", "style", "styleClass", "labelStyleClass"], outputs: ["onClick", "onFocus", "onBlur"] }] });
|
|
7
226
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.7", ngImport: i0, type: CodSelfFormStepFourComponent, decorators: [{
|
|
8
227
|
type: Component,
|
|
9
|
-
args: [{ selector: 'app-cod-self-form-step-four', template: "<span>
|
|
10
|
-
}] }
|
|
11
|
-
|
|
228
|
+
args: [{ selector: 'app-cod-self-form-step-four', template: "<div class=\"container-main\">\n <div class=\"container-form\">\n <div class=\"title_step\">\n <h2>Datos de Facturaci\u00F3n</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 </div>\n\n <i class=\"pi pi-exclamation-circle cursor-pointer w-auto \" (click)=\"showConfirm()\" pTooltip=\"M\u00E1s info.\" tooltipPosition=\"bottom\"></i>\n <div class=\"animate__animated animate__slideInRight ng-star-inserted\">\n <form autocomplete=\"off\" [formGroup]=\"codSelfFormStepFour\" class=\"grid mt-2 flex flex-column align-items-center\">\n <div class=\"container__body__select flex justify-content-center flex-wrap\">\n <div class=\"container__type__payments\" *ngIf=\"isSelectionOptionPayments\">\n <div class=\"flex flex-column gap-3\">\n <h3>\u00BFC\u00F3mo quieres pagar?</h3>\n <div *ngFor=\"let category of OptionPayments; index as ind\" class=\"field-checkbox\">\n <p-radioButton\n [inputId]=\"category.key\"\n name=\"category\"\n [value]=\"category\"\n [(ngModel)]=\"selectedOptionPayments\"\n [disabled]=\"disableweekdays[ind]\"\n [ngModelOptions]=\"{ standalone: true }\"\n (ngModelChange)=\"selectOpcionsPayments($event)\"\n ></p-radioButton>\n <label [for]=\"category.key\" class=\"ml-2\">\n {{ category.name }}\n </label>\n </div>\n </div>\n </div>\n\n <div class=\"container__option__instalations\" *ngIf=\"!isSelectionOptionPayments\">\n <!-- Vista para la opci\u00F3n de pago \"Instalaciones\" -->\n <div *ngIf=\"getViewBasedOnPaymentOption() === 'in'\">\n <div class=\"container__info flex flex-column align-items-center justify-content-center mt-1 mb-4\" *ngIf=\"isEditBillingData\">\n <img src=\"./assets/logos/lobo-web.png\" alt=\"Receipt Icon\" shape=\"circle\" class=\"circular-image\" />\n <strong>{{ codSelfFormStepFour.get('invoicing_name')?.value }} {{ codSelfFormStepFour.get('invoicing_Apellido')?.value }}</strong>\n <span>{{ getIdTypeDescription(codSelfFormStepFour.get('invoicing_idType')?.value) }} {{ codSelfFormStepFour.get('invoicing_document')?.value }}</span>\n <div class=\"container-button\">\n <ipt-button [label]=\"'Modificar Datos'\" (onClick)=\"editBillingData()\" [primary]=\"false\"></ipt-button>\n </div>\n </div>\n <div class=\"m-2\" *ngIf=\"!isEditBillingData\">\n <h3>Completa los nuevos datos para la emisi\u00F3n de tu factura</h3>\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=\"M\u00E1s info.\" tooltipPosition=\"bottom\"></i>\n </div>\n <div class=\"flex flex-column container_info_span flex align-items-center justify-content-center\">\n <span>Si proporcionas datos de un tercero, confirmas que los datos son correctos y que tienes su consentimiento para el uso de la informaci\u00F3n. Estos datos se tratar\u00E1n de acuerdo a nuestra <a href=\"\">Declaraci\u00F3n de Privacidad</a></span>\n </div>\n </div>\n <div>\n <ipt-input [inputType]=\"'text'\" [placeHolder]=\"'Nombres'\" [control]=\"codSelfFormStepFour.controls['invoicing_name']\"></ipt-input>\n <ipt-input [inputType]=\"'text'\" [placeHolder]=\"'Apellidos'\" [control]=\"codSelfFormStepFour.controls['invoicing_Apellido']\"></ipt-input>\n <ipt-select\n [initialValue]=\"codSelfFormStepFour.controls['invoicing_idType'].value\"\n [control]=\"codSelfFormStepFour.controls['invoicing_idType']\"\n [selectCode]=\"codSelfFormStepFour.controls['invoicing_idType'].value === null ? 'Tipo de documento' : codSelfFormStepFour.controls['invoicing_idType'].value\"\n [isRequired]=\"true\"\n [data]=\"idTypes\"\n (eventSelect)=\"selectIdType($event)\"\n [defaultText]=\"'Tipo de documento'\"\n ></ipt-select>\n <ipt-input [inputType]=\"'number'\" [placeHolder]=\"'N\u00FAmero de documento'\" [control]=\"codSelfFormStepFour.controls['invoicing_document']\"></ipt-input>\n </div>\n <div class=\"flex justify-content-end mt-3 align-items-center gap-3\">\n <button pButton [disabled]=\"!codSelfFormStepFour.valid\" label=\"Continuar\" type=\"button\" (click)=\"updateDatosBillingData()\"></button>\n </div>\n </div>\n </div>\n\n <!-- Vista para la opci\u00F3n de pago \"Pasarela pagos\" -->\n <div *ngIf=\"getViewBasedOnPaymentOption() === 'ps'\">\n <!-- TODO:<h3>Completa los datos para Pasarela pagos</h3> -->\n <!-- Aqu\u00ED puedes agregar el formulario espec\u00EDfico para Pasarela pagos -->\n </div>\n </div>\n </div>\n </form>\n\n <div class=\"flex justify-content-between mt-3 align-items-center gap-3\">\n <button pButton icon=\"pi pi-arrow-left\" type=\"button\" (click)=\"back()\"></button>\n <button *ngIf=\"!isSelectionOptionPayments && isEditBillingData && codSelfFormStepFour.valid\" pButton label=\"\u00A1Matricularme!\" type=\"button\" (click)=\"sendForm()\"></button>\n </div>\n </div>\n </div>\n</div>\n", styles: [".container-form{margin:5px;border-radius:3px;border:1px solid #2563eb;box-shadow:#3c40434d 0 1px 2px,#3c404326 0 2px 6px 2px;padding:.5rem}.error-message{font-size:x-small;color:red}:host ::ng-deep .p-toast{width:20rem!important}.circular-image{width:50px;height:50px;border-radius:50%;object-fit:cover;border:none}.container-button{width:10rem;margin-top:3%}\n"] }]
|
|
229
|
+
}], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i2.MessageService }, { type: i3.CodSelfManagedControls }]; }, propDecorators: { idTypes: [{
|
|
230
|
+
type: Input
|
|
231
|
+
}], completed: [{
|
|
232
|
+
type: Output
|
|
233
|
+
}], action: [{
|
|
234
|
+
type: Output
|
|
235
|
+
}] } });
|
|
236
|
+
// Definición de la función de validador personalizada
|
|
237
|
+
function paymentOptionValidator(selectedOptionPayments) {
|
|
238
|
+
return (control) => {
|
|
239
|
+
if (selectedOptionPayments?.code === 1) { // Instalaciones
|
|
240
|
+
if (!control.get('invoicing_name')?.value || !control.get('invoicing_Apellido')?.value ||
|
|
241
|
+
!control.get('invoicing_idType')?.value || !control.get('invoicing_document')?.value) {
|
|
242
|
+
return { 'requiredFieldsMissing': true };
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
return null;
|
|
246
|
+
};
|
|
247
|
+
}
|
|
248
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cod-self-form-step-four.component.js","sourceRoot":"","sources":["../../../../../../../design-system/src/lib/cod-self-managed/steps/cod-form-step-four/cod-self-form-step-four.component.ts","../../../../../../../design-system/src/lib/cod-self-managed/steps/cod-form-step-four/cod-self-form-step-four.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Output, EventEmitter, OnInit, Input } from '@angular/core';\nimport { FormGroup, FormBuilder, Validators, FormControl, AbstractControl, ValidatorFn } from '@angular/forms';\nimport { MessageService } from 'primeng/api';\nimport { IweekDaysRq } from './../../../core/models/academic/academic.component';\nimport { CodSelfManagedSteps, localStorageValuesTwo } from '../../logic/cod-self-managed-steps';\nimport { CodSelfManagedControls } from '../../logic/cod-self-managed-controls';\n\n@Component({\n  selector: 'app-cod-self-form-step-four',\n  templateUrl: './cod-self-form-step-four.component.html',\n  styleUrls: ['./cod-self-form-step-four.component.css'],\n})\nexport class CodSelfFormStepFourComponent extends CodSelfManagedSteps implements OnInit {\n\n  @Input() idTypes: any;\n  @Output() completed = new EventEmitter<number>();\n  @Output() action = new EventEmitter<string>();\n\n  controls = new CodSelfManagedControls().controls[3];\n  messageInfo: string = \"Datos de facturacion de acuerdo a tu eleccion\";\n  visible: boolean = false;\n  codSelfFormStepFour!: FormGroup;\n  selectedOptionPayments?: IweekDaysRq;\n  messageAlertPlacementTest = false;\n  disableweekdays: boolean[] = [];\n  isSelectionOptionPayments = true;\n  isEditBillingData = true;\n  OptionPayments: any[] = [\n    { code: 1, key: 'in', name: 'Instalaciones' },\n    // { code: 2, key: 'tr', name: 'Transferencia' },\n    { code: 3, key: 'ps', name: 'Pasarela pagos' },\n  ];\n\n  studentIdCardType = new FormControl();\n\n  constructor(\n    private fb: FormBuilder,\n    private messageService: MessageService,\n    private codFormControls: CodSelfManagedControls,\n  ) {\n    super();\n    this.initForm();\n  }\n\n  ngOnInit(): void {\n    this.startLocalStorageWork();\n    this.subscribeToStudentIdCardTypeChanges();\n    this.getDataUser();\n  }\n\n  initForm() {\n    this.codSelfFormStepFour = this.fb.group({\n      optionsPayments: ['', [Validators.required]],\n      invoicing_name: ['', [Validators.required]],\n      invoicing_Apellido: ['', [Validators.required]],\n      invoicing_idType: ['', [Validators.required]],\n      invoicing_document: ['', [Validators.required, Validators.minLength(5), Validators.maxLength(20), Validators.pattern(/^[0-9]*$/)]],\n    });\n  }\n\n  subscribeToStudentIdCardTypeChanges() {\n    this.studentIdCardType.valueChanges.subscribe(value => {\n      this.updateBillingDataFields(value);\n    });\n  }\n\n  getDataUser() {\n    const typeIdCard = this.localStorageCOD.getCodFormData(1, 'student_id_card_type');\n    this.studentIdCardType.setValue(typeIdCard);\n  }\n\n  updateBillingDataFields(typeIdCard: string | null) {\n    if (typeIdCard != null && typeIdCard != \"2\") {\n      const nameStudent = this.localStorageCOD.getCodFormData(1, 'student_name');\n      const lastNameStudent = this.localStorageCOD.getCodFormData(1, 'student_last_name');\n      const typeIdCardStudent = this.localStorageCOD.getCodFormData(1, 'student_id_card_type');\n      const idCardStudent = this.localStorageCOD.getCodFormData(1, 'student_id_card');\n\n\n      this.codSelfFormStepFour.controls['invoicing_name'].setValue(nameStudent);\n      this.codSelfFormStepFour.controls['invoicing_Apellido'].setValue(lastNameStudent);\n      this.codSelfFormStepFour.controls['invoicing_idType'].setValue(typeIdCardStudent);\n      this.codSelfFormStepFour.controls['invoicing_document'].setValue(idCardStudent);\n    } else {\n      // Limpia los campos si el tipo de documento es \"2\"\n      this.codSelfFormStepFour.controls['invoicing_name'].setValue('');\n      this.codSelfFormStepFour.controls['invoicing_Apellido'].setValue('');\n      this.codSelfFormStepFour.controls['invoicing_idType'].setValue('');\n      this.codSelfFormStepFour.controls['invoicing_document'].setValue('');\n    }\n  }\n\n  back() {\n    if (!this.isSelectionOptionPayments && !this.isEditBillingData) {\n      this.isEditBillingData = true;\n    } else if (!this.isSelectionOptionPayments && this.isEditBillingData) {\n      this.isSelectionOptionPayments = true;\n    } else {\n      this.completed.emit(2);\n    }\n  }\n\n  next() {\n    if (this.isSelectionOptionPayments) {\n      this.isSelectionOptionPayments = false;\n    } else if (!this.isEditBillingData) {\n      this.isEditBillingData = true;\n    } else {\n      this.sendForm();\n    }\n  }\n\n  startLocalStorageWork() {\n    this.controls.forEach(control => {\n      let localStorageValue: localStorageValuesTwo = this.readAndWriteLS(4, control.name);\n      this.codSelfFormStepFour.controls[control.name].setValue(localStorageValue.value);\n      this.listenFormChanges(4, control.name, this.codSelfFormStepFour.controls[control.name].valueChanges);\n    });\n  }\n\n  editBillingData() {\n    this.isEditBillingData = false;\n  }\n\n  updateDatosBillingData() {\n    this.isEditBillingData = true;\n  }\n\n  sendForm() {\n    this.codSelfFormStepFour.markAllAsTouched();\n    this.action.emit('create');\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  selectOpcionsPayments(eve: IweekDaysRq) {\n    this.selectedOptionPayments = eve;\n    this.isSelectionOptionPayments = false;\n\n    if (this.selectedOptionPayments !== null) {\n      this.codSelfFormStepFour.controls['optionsPayments'].setValue(this.selectedOptionPayments.code);\n\n      if (this.selectedOptionPayments.code === 1) { // Instalaciones\n        this.addValidators();\n      } else if (this.selectedOptionPayments.code === 3) { // Pasarela Pago\n        this.removeValidators();\n      }\n\n      // Aplicar el validador personalizado basado en la opción seleccionada\n      this.codSelfFormStepFour.setValidators(paymentOptionValidator(this.selectedOptionPayments));\n      this.codSelfFormStepFour.updateValueAndValidity();\n      this.updateGlobalControls(this.selectedOptionPayments.code);\n    } else {\n      this.codSelfFormStepFour.controls['optionsPayments'].setValue(null);\n    }\n  }\n\n  addValidators() {\n    this.codSelfFormStepFour.controls['invoicing_name'].setValidators([Validators.required]);\n    this.codSelfFormStepFour.controls['invoicing_Apellido'].setValidators([Validators.required]);\n    this.codSelfFormStepFour.controls['invoicing_idType'].setValidators([Validators.required]);\n    this.codSelfFormStepFour.controls['invoicing_document'].setValidators([Validators.required, Validators.minLength(5), Validators.maxLength(20), Validators.pattern(/^[0-9]*$/)]);\n    this.codSelfFormStepFour.controls['invoicing_name'].updateValueAndValidity();\n    this.codSelfFormStepFour.controls['invoicing_Apellido'].updateValueAndValidity();\n    this.codSelfFormStepFour.controls['invoicing_idType'].updateValueAndValidity();\n    this.codSelfFormStepFour.controls['invoicing_document'].updateValueAndValidity();\n  }\n\n  removeValidators() {\n    this.codSelfFormStepFour.controls['invoicing_name'].clearValidators();\n    this.codSelfFormStepFour.controls['invoicing_Apellido'].clearValidators();\n    this.codSelfFormStepFour.controls['invoicing_idType'].clearValidators();\n    this.codSelfFormStepFour.controls['invoicing_document'].clearValidators();\n    this.codSelfFormStepFour.controls['invoicing_name'].updateValueAndValidity();\n    this.codSelfFormStepFour.controls['invoicing_Apellido'].updateValueAndValidity();\n    this.codSelfFormStepFour.controls['invoicing_idType'].updateValueAndValidity();\n    this.codSelfFormStepFour.controls['invoicing_document'].updateValueAndValidity();\n  }\n\n  selectIdType(idType: any) {\n    if (idType !== 'Tipo de documento') {\n      this.codSelfFormStepFour.controls['invoicing_idType'].setValue(idType);\n    } else {\n      this.codSelfFormStepFour.controls['invoicing_idType'].setValue(null);\n    }\n  }\n\n  getViewBasedOnPaymentOption(): string {\n    if (this.selectedOptionPayments?.code === 1) {\n      return 'in';\n    } else if (this.selectedOptionPayments?.code === 3) {\n      return 'ps';\n    }\n    return 'default';\n  }\n\n  getIdTypeDescription(idType: string): string {\n    switch (idType) {\n      case '0':\n        return 'N/A';\n      case '1':\n        return 'C.C';\n      case '2':\n        return 'T.I';\n      case '3':\n        return 'C.E';\n      case '4':\n        return 'P.E.P';\n      case '5':\n        return 'R.U.M';\n      case '6':\n        return 'P.P.T';\n      case '7':\n        return 'P.A';\n      case '8':\n        return 'R.C';\n      case '9':\n        return 'C.D';\n      default:\n        return '';\n    }\n  }\n  updateGlobalControls(change: number) {\n    let controls = this.controls.filter(control => control.name !== 'optionsPayments');\n    controls.forEach(control => {\n      if (change === 1) this.codFormControls.changeValue(4, control.name, true)\n      if (change === 3) this.codFormControls.changeValue(4, control.name, false)\n    });\n  }\n}\n\n\n// Definición de la función de validador personalizada\nfunction paymentOptionValidator(selectedOptionPayments: IweekDaysRq): ValidatorFn {\n  return (control: AbstractControl): { [key: string]: any } | null => {\n    if (selectedOptionPayments?.code === 1) { // Instalaciones\n      if (!control.get('invoicing_name')?.value || !control.get('invoicing_Apellido')?.value ||\n          !control.get('invoicing_idType')?.value || !control.get('invoicing_document')?.value) {\n        return { 'requiredFieldsMissing': true };\n      }\n    }\n    return null;\n  };\n}\n","<div class=\"container-main\">\n  <div class=\"container-form\">\n    <div class=\"title_step\">\n      <h2>Datos de Facturación</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    </div>\n\n    <i class=\"pi pi-exclamation-circle cursor-pointer w-auto \" (click)=\"showConfirm()\" pTooltip=\"Más info.\" tooltipPosition=\"bottom\"></i>\n    <div class=\"animate__animated animate__slideInRight ng-star-inserted\">\n      <form autocomplete=\"off\" [formGroup]=\"codSelfFormStepFour\" class=\"grid mt-2 flex flex-column align-items-center\">\n        <div class=\"container__body__select flex justify-content-center flex-wrap\">\n          <div class=\"container__type__payments\" *ngIf=\"isSelectionOptionPayments\">\n            <div class=\"flex flex-column gap-3\">\n              <h3>¿Cómo quieres pagar?</h3>\n              <div *ngFor=\"let category of OptionPayments; index as ind\" class=\"field-checkbox\">\n                <p-radioButton\n                  [inputId]=\"category.key\"\n                  name=\"category\"\n                  [value]=\"category\"\n                  [(ngModel)]=\"selectedOptionPayments\"\n                  [disabled]=\"disableweekdays[ind]\"\n                  [ngModelOptions]=\"{ standalone: true }\"\n                  (ngModelChange)=\"selectOpcionsPayments($event)\"\n                ></p-radioButton>\n                <label [for]=\"category.key\" class=\"ml-2\">\n                  {{ category.name }}\n                </label>\n              </div>\n            </div>\n          </div>\n\n          <div class=\"container__option__instalations\" *ngIf=\"!isSelectionOptionPayments\">\n            <!-- Vista para la opción de pago \"Instalaciones\" -->\n            <div *ngIf=\"getViewBasedOnPaymentOption() === 'in'\">\n              <div class=\"container__info flex flex-column align-items-center justify-content-center mt-1 mb-4\" *ngIf=\"isEditBillingData\">\n                <img src=\"./assets/logos/lobo-web.png\" alt=\"Receipt Icon\" shape=\"circle\" class=\"circular-image\" />\n                <strong>{{ codSelfFormStepFour.get('invoicing_name')?.value }} {{ codSelfFormStepFour.get('invoicing_Apellido')?.value }}</strong>\n                <span>{{ getIdTypeDescription(codSelfFormStepFour.get('invoicing_idType')?.value) }} {{ codSelfFormStepFour.get('invoicing_document')?.value }}</span>\n                <div class=\"container-button\">\n                  <ipt-button [label]=\"'Modificar Datos'\" (onClick)=\"editBillingData()\" [primary]=\"false\"></ipt-button>\n                </div>\n              </div>\n              <div class=\"m-2\" *ngIf=\"!isEditBillingData\">\n                <h3>Completa los nuevos datos para la emisión de tu factura</h3>\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=\"Más info.\" tooltipPosition=\"bottom\"></i>\n                  </div>\n                  <div class=\"flex flex-column container_info_span flex align-items-center justify-content-center\">\n                    <span>Si proporcionas datos de un tercero, confirmas que los datos son correctos y que tienes su consentimiento para el uso de la información. Estos datos se tratarán de acuerdo a nuestra <a href=\"\">Declaración de Privacidad</a></span>\n                  </div>\n                </div>\n                <div>\n                  <ipt-input [inputType]=\"'text'\" [placeHolder]=\"'Nombres'\" [control]=\"codSelfFormStepFour.controls['invoicing_name']\"></ipt-input>\n                  <ipt-input [inputType]=\"'text'\" [placeHolder]=\"'Apellidos'\" [control]=\"codSelfFormStepFour.controls['invoicing_Apellido']\"></ipt-input>\n                  <ipt-select\n                    [initialValue]=\"codSelfFormStepFour.controls['invoicing_idType'].value\"\n                    [control]=\"codSelfFormStepFour.controls['invoicing_idType']\"\n                    [selectCode]=\"codSelfFormStepFour.controls['invoicing_idType'].value === null ? 'Tipo de documento' : codSelfFormStepFour.controls['invoicing_idType'].value\"\n                    [isRequired]=\"true\"\n                    [data]=\"idTypes\"\n                    (eventSelect)=\"selectIdType($event)\"\n                    [defaultText]=\"'Tipo de documento'\"\n                  ></ipt-select>\n                  <ipt-input [inputType]=\"'number'\" [placeHolder]=\"'Número de documento'\" [control]=\"codSelfFormStepFour.controls['invoicing_document']\"></ipt-input>\n                </div>\n                <div class=\"flex justify-content-end mt-3 align-items-center gap-3\">\n                  <button pButton [disabled]=\"!codSelfFormStepFour.valid\" label=\"Continuar\" type=\"button\" (click)=\"updateDatosBillingData()\"></button>\n                </div>\n              </div>\n            </div>\n\n            <!-- Vista para la opción de pago \"Pasarela pagos\" -->\n            <div *ngIf=\"getViewBasedOnPaymentOption() === 'ps'\">\n              <!-- TODO:<h3>Completa los datos para Pasarela pagos</h3> -->\n              <!-- Aquí puedes agregar el formulario específico para Pasarela pagos -->\n            </div>\n          </div>\n        </div>\n      </form>\n\n      <div class=\"flex justify-content-between mt-3 align-items-center gap-3\">\n        <button pButton icon=\"pi pi-arrow-left\" type=\"button\" (click)=\"back()\"></button>\n        <button *ngIf=\"!isSelectionOptionPayments && isEditBillingData && codSelfFormStepFour.valid\" pButton label=\"¡Matricularme!\" type=\"button\" (click)=\"sendForm()\"></button>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|