import { Component, OnInit, Input, ViewChild } from "@angular/core"; import { InstrumentComponent } from "@app/components/investment-proposals/instrument/instrument.component"; import { FormBuilder, FormGroup, Validators } from "@angular/forms"; import { IAngularMyDpOptions, IMyDateModel } from "angular-mydatepicker"; import { formatDate, DatePipe } from "@angular/common"; import { Router } from "@angular/router"; import { FormInvestmentProposalService } from "@app/services/form-investment-proposal.service"; import { CatalogsService } from "@app/services/catalogs.service"; import { InstrumentCalculations } from "@app/services/instrument-calculations.service"; import Swal from "sweetalert2"; import { GeneralInfo } from "@app/models/investment-proposal-form"; import { parse } from "date-fns"; import { MatPaginator } from "@angular/material/paginator"; import { MatSort } from "@angular/material/sort"; import { MatTableDataSource } from "@angular/material/table"; @Component({ selector: "app-fondos", templateUrl: "./fondos.component.html" }) export class FINV implements InstrumentComponent { title: string = "Fondos de inversión"; @Input() data: any; @Input() summary: boolean; @Input() investmentID: string; displayedColumns: string[] = [ "posicion", "plazo", "fecha_pago", "ingreso_bruto", "ingreso_neto", "dividendo_porcentaje", "rendimiento_porcentaje", "rendimiento" ]; @ViewChild(MatPaginator, { static: true }) paginator: MatPaginator; @ViewChild(MatSort, { static: true }) sort: MatSort; form: any; general: GeneralInfo; // For daterange daysLabels: any = { su: "Dom", mo: "Lun", tu: "Mar", we: "Mie", th: "Jue", fr: "Vie", sa: "Sab" }; monthsLabels: any = { 1: "Ene", 2: "Feb", 3: "Mar", 4: "Abr", 5: "May", 6: "Jun", 7: "Jul", 8: "Ago", 9: "Sep", 10: "Oct", 11: "Nov", 12: "Dic" }; investmentProposalForm: FormGroup; myDpOptions: IAngularMyDpOptions = { dateRange: false, dateFormat: "dd/mm/yyyy", dayLabels: this.daysLabels, monthLabels: this.monthsLabels }; myDateInit: boolean = true; m_fecha_vencimiento_compra: IMyDateModel; m_fecha_operacion: IMyDateModel; m_fecha_rendencion: IMyDateModel; m_fecha_liquidacion_compra: IMyDateModel; submitted: boolean = false; instrument_exists: boolean; instrument_work: any = []; financials: any; base_types: any; proyecciones: any; fondosObject: {}; dataSource = new MatTableDataSource(this.proyecciones); dataSource2 = new MatTableDataSource(this.proyecciones); hasProjections: boolean; fecha_vencimiento: any; operation_result: boolean = false; operation_results_work: any = []; instrument_work_summary: any = []; cuota_participacion: any; valor_participacion: any; dias_liquidacion: any; dias_vencimiento: any; valor_nominal: any; valor_transado: any; comision_casa_porcentaje: any; comision_casa: any; comision_bolsa_porcentaje: any; comision_bolsa: any; rendimiento_porcentaje: any; dividendo_porcentaje: any; fecha_operacion: any; fecha_liquidacion: any; consolidado_proyeccion: any; monto_pagar: any; constructor( private formBuilder: FormBuilder, private router: Router, private formDataService: FormInvestmentProposalService, private catalogService: CatalogsService, private instrumentCalcService: InstrumentCalculations, public datepipe: DatePipe ) { this.instrument_work = this.formDataService.getWork(); this.instrument_exists = this.instrument_work == undefined; this.general = this.formDataService.getGeneralInfo(); if ( this.instrument_work != undefined && this.instrument_work.proyecciones != "" ) { this.hasProjections = true; this.consolidado_proyeccion = this.instrument_work.proyecciones[ this.instrument_work.proyecciones.length - 1 ]; this.operation_results_work = this.instrument_work["resultado_operacion"]; if (this.instrument_work["instrumento"] != undefined) { this.instrument_work = this.instrument_work["instrumento"]; } this.instrument_work_summary = this.instrument_work; this.dataSource2.data = this.instrument_work.proyecciones.slice(0, -1); this.dataSource2.paginator = this.paginator; this.dataSource2.sort = this.sort; } else { this.hasProjections = false; } if ( this.operation_results_work != undefined && this.operation_results_work != "" ) { this.operation_result = true; } this.investmentProposalForm = this.formBuilder.group({ cuota_participacion: [ this.instrument_exists ? "" : this.instrument_work.cuota_participacion, [ Validators.required, Validators.pattern(/^[+]?([0-9]+(?:[\.][0-9]*)?|\.[0-9]+)$/) ] ], valor_participacion: [ this.instrument_exists ? "" : this.instrument_work.valor_participacion, [ Validators.required, Validators.pattern(/^[+]?([0-9]+(?:[\.][0-9]*)?|\.[0-9]+)$/) ] ], comision_casa_porcentaje: [ this.instrument_exists ? "" : this.instrument_work.comision_casa_porcentaje, [ Validators.required, Validators.pattern(/^[+]?([0-9]+(?:[\.][0-9]*)?|\.[0-9]+)$/) ] ], comision_bolsa_porcentaje: [ this.instrument_exists ? "" : this.instrument_work.comision_bolsa_porcentaje, [ Validators.required, Validators.pattern(/^[+]?([0-9]+(?:[\.][0-9]*)?|\.[0-9]+)$/) ] ], dividendo_porcentaje: [ this.instrument_exists ? "" : this.instrument_work.dividendo_porcentaje, [ Validators.required, Validators.pattern(/^[+]?([0-9]+(?:[\.][0-9]*)?|\.[0-9]+)$/) ] ], rendimiento_porcentaje: [ this.instrument_exists ? "" : this.instrument_work.rendimiento_porcentaje, [ Validators.required, Validators.pattern(/^[+]?([0-9]+(?:[\.][0-9]*)?|\.[0-9]+)$/) ] ], dias_liquidacion: [ this.instrument_exists ? "" : this.instrument_work.dias_liquidacion, [ Validators.required, Validators.pattern(/^[+]?([0-9]+(?:[\.][0-9]*)?|\.[0-9]+)$/) ] ], dias_vencimiento: [ this.instrument_exists ? "" : this.instrument_work.dias_vencimiento, [ Validators.required, Validators.pattern(/^[+]?([0-9]+(?:[\.][0-9]*)?|\.[0-9]+)$/) ] ], fecha_operacion: [ this.instrument_exists ? "" : { isRange: false, singleDate: { jsDate: parse( this.instrument_work.fecha_operacion, "dd/MM/yyyy", new Date() ), formatted: this.instrument_work.fecha_operacion } }, Validators.required ] }); } get f() { return this.investmentProposalForm.controls; } save(form: any): boolean { if (!form.valid) { return false; } this.formDataService.setWork(this.fondosObject); return true; } getCalculations(form: any, saveForm: boolean) { this.submitted = true; if (!form.valid) { return false; } Swal.fire({ allowOutsideClick: false, icon: "info", text: "Espere por favor..." }); Swal.showLoading(); this.instrumentCalcService .fondosCalc( "FINV", // Codigo del instrumento { id_tipo_base: +this.general.base_anual, id_formato_ingreso: +this.general.formato_ingreso, id_periodicidad: +this.general.periodicidad }, { cuota_participacion: +this.f.cuota_participacion.value, valor_participacion: +this.f.valor_participacion.value, comision_bolsa_porcentaje: +this.f.comision_bolsa_porcentaje.value, comision_casa_porcentaje: +this.f.comision_casa_porcentaje.value, dividendo_porcentaje: +this.f.dividendo_porcentaje.value, rendimiento_porcentaje: +this.f.rendimiento_porcentaje.value, dias_liquidacion: this.f.dias_liquidacion.value, dias_vencimiento: this.f.dias_vencimiento.value, fecha_operacion: this.f.fecha_operacion.value.singleDate.formatted } ) .subscribe( ans => { this.cuota_participacion = ans["result"]["instrumento"]["cuota_participacion"]; this.valor_participacion = ans["result"]["instrumento"]["valor_participacion"]; this.dias_liquidacion = ans["result"]["instrumento"]["dias_liquidacion"]; this.dias_vencimiento = ans["result"]["instrumento"]["dias_vencimiento"]; this.valor_nominal = ans["result"]["instrumento"]["valor_nominal"]; this.valor_transado = ans["result"]["instrumento"]["valor_transado"]; this.monto_pagar = ans["result"]["instrumento"]["monto_pagar"]; this.comision_casa_porcentaje = ans["result"]["instrumento"]["comision_casa_porcentaje"]; this.comision_casa = ans["result"]["instrumento"]["comision_casa"]; this.comision_bolsa_porcentaje = ans["result"]["instrumento"]["comision_bolsa_porcentaje"]; this.comision_bolsa = ans["result"]["instrumento"]["comision_bolsa"]; this.rendimiento_porcentaje = ans["result"]["instrumento"]["rendimiento_porcentaje"]; this.dividendo_porcentaje = ans["result"]["instrumento"]["dividendo_porcentaje"]; this.fecha_operacion = ans["result"]["instrumento"]["fecha_operacion"]; this.fecha_liquidacion = ans["result"]["instrumento"]["fecha_liquidacion"]; this.fecha_vencimiento = ans["result"]["instrumento"]["fecha_vencimiento"]; // Proyecciones this.proyecciones = ans["result"]["proyecciones"]; if (this.proyecciones != undefined && this.proyecciones.length > 0) { this.hasProjections = true; let proyecciones_temp = this.proyecciones; this.consolidado_proyeccion = proyecciones_temp[proyecciones_temp.length - 1]; this.proyecciones = ans["result"]["proyecciones"]; } this.operation_result = true; this.dataSource.data = this.proyecciones; this.dataSource2.data = this.proyecciones; this.dataSource.paginator = this.paginator; this.dataSource.sort = this.sort; this.fondosObject = { cuota_participacion: this.investmentProposalForm.value .cuota_participacion, valor_participacion: this.investmentProposalForm.value .valor_participacion, comision_bolsa_porcentaje: this.investmentProposalForm.value .comision_bolsa_porcentaje, comision_casa_porcentaje: this.investmentProposalForm.value .comision_casa_porcentaje, dividendo_porcentaje: this.investmentProposalForm.value .dividendo_porcentaje, rendimiento_porcentaje: this.investmentProposalForm.value .rendimiento_porcentaje, dias_liquidacion: this.investmentProposalForm.value .dias_liquidacion, dias_vencimiento: this.investmentProposalForm.value .dias_vencimiento, fecha_operacion: this.f.fecha_operacion.value.singleDate.formatted, valor_nominal: this.valor_nominal, valor_transado: this.valor_transado, monto_pagar: this.monto_pagar, comision_casa: this.comision_casa, comision_bolsa: this.comision_bolsa, fecha_liquidacion: this.fecha_liquidacion, fecha_vencimiento: this.fecha_vencimiento, // Proyecciones proyecciones: this.proyecciones }; this.formDataService.setWork(this.fondosObject); Swal.close(); if (saveForm == true) { if (this.investmentID != undefined) { this.router.navigate(["/investment-proposal/complement-info"], { queryParams: { id: this.investmentID } }); } else { this.router.navigate(["/investment-proposal/complement-info"]); } } }, err => { Swal.fire({ icon: "error", title: "Error en el servidor", text: "No su pudo obtener la informacion" }); return false; } ); } goToPrevious() { this.submitted = true; if (this.investmentID != undefined) { this.router.navigate(["/investment-proposal/general-info"], { queryParams: { id: this.investmentID } }); } else { this.router.navigate(["/investment-proposal/general-info"]); } } goToNext(form: any) { this.getCalculations(form, true); } }