public PlanillaRemuneracion UpdatePlanilla(PlanillaRemuneracion planillaRemuneracion) { IPlanillaRemuneracionRepository remuneracionRepository = _DataRepositoryFactory.GetDataRepository <IPlanillaRemuneracionRepository>(); IVacacionesRepository vacacionesRepository = _DataRepositoryFactory.GetDataRepository <IVacacionesRepository>(); var Persona = remuneracionRepository.Update(planillaRemuneracion); Persona.VacacionesPeriodo = vacacionesRepository.Update(planillaRemuneracion.VacacionesPeriodo); return(Persona); }
public Vacaciones UpdateVacaciones(VacacionesPersona vacacionesPersona) { IVacacionesRepository vacacionesRepository = _DataRepositoryFactory.GetDataRepository <IVacacionesRepository>(); Vacaciones vacaciones = vacacionesRepository.Get(vacacionesPersona.IdVacaciones); if (vacaciones != null) { vacaciones.IniProg = vacacionesPersona.IniProg; vacaciones.FinProg = vacacionesPersona.FinProg; return(vacacionesRepository.Update(vacaciones)); } return(vacaciones); }
//public void EliminarPlanilla(string Periodo, string TipoPlanilla) //{ // IPlanillaRemuneracionRepository planillaRepository = _DataRepositoryFactory.GetDataRepository<IPlanillaRemuneracionRepository>(); //} public List <PlanillaRemuneracion> GenerarPlanilla(string Periodo) { int Anio = Convert.ToInt32(Periodo.Substring(0, 4)); int Mes = Convert.ToInt32(Periodo.Substring(4, 2)); IPersonalRepository personalRepository = _DataRepositoryFactory.GetDataRepository <IPersonalRepository>(); IFondoPensionesRepository fondoRepository = _DataRepositoryFactory.GetDataRepository <IFondoPensionesRepository>(); IAporteEmpleadorRepository aportesRepository = _DataRepositoryFactory.GetDataRepository <IAporteEmpleadorRepository>(); IDiasLaborablesRepository diasRepository = _DataRepositoryFactory.GetDataRepository <IDiasLaborablesRepository>(); IVacacionesRepository vacacionesRepository = _DataRepositoryFactory.GetDataRepository <IVacacionesRepository>(); List <PlanillaRemuneracion> remuneracion = new List <PlanillaRemuneracion>(); IEnumerable <Personal> personalActivo = personalRepository.GetPersonalActivo(); foreach (Personal personal in personalActivo) { FondoPensiones fondoPensiones = fondoRepository.Get(personal.IdFondoPen ?? 0); AporteEmpleador aporteEmpleadorESSALUD = aportesRepository.Get(1); AporteEmpleador aporteEmpleadorSCTR = aportesRepository.Get(2); DiasLaborables diasLaborables = diasRepository.GetDiasPorPeriodo(Periodo); Vacaciones vacacionesInicio = vacacionesRepository.GetVacacionesInicioPeriodoPersona(personal.IdPersonal, Anio, Mes); Vacaciones vacacionesFin = vacacionesRepository.GetVacacionesFinPeriodoPersona(personal.IdPersonal, Anio, Mes); Vacaciones vacacionesPeriodo = vacacionesRepository.GetVacacionesPorPeriodoPersona(Anio, personal.IdPersonal); decimal porcentajeApoObl = ((personal.TipComAFP == "F") ? fondoPensiones.ApoOblF : fondoPensiones.ApoOblM) ?? 0; decimal porcentajeComVar = ((personal.TipComAFP == "F") ? fondoPensiones.ComVarF : fondoPensiones.ComVarM) ?? 0; decimal porcentajePriSeg = ((personal.TipComAFP == "F") ? fondoPensiones.PriSegF : fondoPensiones.PriSegM) ?? 0; //decimal TotalIngreso = personal.RemBas + personal.AsiFam + personal.RieCaj; //terminar //decimal MontoOnp = (personal.RemBas * fondoPensiones.PorONP) ?? 0; //decimal MontoAporteObl = (personal.RemBas * porcentajeApoObl) ?? 0; //decimal MontoComVar = (personal.RemBas * porcentajeComVar) ?? 0; //decimal MontoPriSeg = (personal.RemBas * porcentajePriSeg) ?? 0; //decimal totalDescuento = MontoOnp + MontoAporteObl + MontoComVar + MontoPriSeg; decimal porcentajeSCTR = ((personal.SCTR == "N") ? 0 : aporteEmpleadorSCTR.Porcentaje) ?? 0; decimal porcentajeESSALUD = (aporteEmpleadorESSALUD.Porcentaje) ?? 0; decimal montoESSALUD = (personal.RemBas * aporteEmpleadorESSALUD.Porcentaje) ?? 0; decimal montoSCTR = (personal.RemBas * porcentajeSCTR) ?? 0; // decimal totalAporte = montoESSALUD + montoSCTR; PlanillaRemuneracion planillaPersona = new PlanillaRemuneracion(0, Periodo, personal.IdPersonal, personal.CodPer, personal.IdCargo ?? null, personal.CodCar, personal.IdFondoPen ?? null, personal.CodFon, personal.TipComAFP, personal.RemBas, personal.AsiFam, 0, 0, 0, personal.RieCaj, 0, 0, 0, fondoPensiones.PorONP, porcentajeApoObl, porcentajePriSeg, porcentajeComVar, 0 , 0, aporteEmpleadorESSALUD.Porcentaje, porcentajeSCTR, diasLaborables.DiasLab, personal.HorLab, null, null, null, null, null, null, null, null, null, "F", "N"); planillaPersona.VacacionesPeriodo = vacacionesPeriodo; planillaPersona.NombrePersona = personal.GetNombre(); remuneracion.Add(planillaPersona); } return(remuneracion); }
public IEnumerable <VacacionesPersona> GetVacacionesPorPeriodo(int Anio) { IVacacionesRepository vacacionesRepository = _DataRepositoryFactory.GetDataRepository <IVacacionesRepository>(); var vacaciones = vacacionesRepository.GetVacacionesPorPeriodo(Anio); if (vacaciones != null && vacaciones.Count() > 0) { return(vacaciones); } IEnumerable <Personal> personalActivo = GetPersonalActivo(); if (personalActivo != null && personalActivo.Count() > 0) { foreach (Personal personal in personalActivo) { vacacionesRepository.Add(new Vacaciones(Anio, personal.IdPersonal, personal.CodPer, "F", "-")); } return(GetVacacionesPorPeriodo(Anio)); } return(vacaciones); }
public IEnumerable <PlanillaRemuneracion> GetPlanillaNormalPorPeriodo(int Anio, int Mes) { IPlanillaRemuneracionRepository planillaRepository = _DataRepositoryFactory.GetDataRepository <IPlanillaRemuneracionRepository>(); IPersonalRepository personalRepository = _DataRepositoryFactory.GetDataRepository <IPersonalRepository>(); IVacacionesRepository vacacionesRepository = _DataRepositoryFactory.GetDataRepository <IVacacionesRepository>(); IFondoPensionesRepository fondoPensionesRepository = _DataRepositoryFactory.GetDataRepository <IFondoPensionesRepository>(); IAreaServicioRepository areaServicioRepository = _DataRepositoryFactory.GetDataRepository <IAreaServicioRepository>(); ICargoRepository cargoRepository = _DataRepositoryFactory.GetDataRepository <ICargoRepository>(); string Periodo = Anio.ToString() + Utiles.CerosIzquierda(Mes.ToString(), 2); var planilla = planillaRepository.GetPlanillaPorPeriodo(Periodo, "N"); IEnumerable <VacacionesPersona> vacaciones = vacacionesRepository.GetVacacionesPorPeriodo(Anio); if (vacaciones == null || vacaciones.Count() == 0) { throw new InvalidOperationException("No se han registrado las vacaciones para este periodo. Imposible continuar con la operaciĆ³n."); } if (planilla != null && planilla.Count() > 0) { var personal = personalRepository.Get(); var fondoPen = fondoPensionesRepository.Get(); var areasServicio = areaServicioRepository.Get(); var cargos = cargoRepository.Get(); foreach (PlanillaRemuneracion registro in planilla) { var persona = personal.Where(o => o.IdPersonal == registro.IdPersonal).FirstOrDefault(); var fondo = fondoPen.Where(o => o.IdFondoPen == registro.IdFondoPen).FirstOrDefault(); var area = areasServicio.Where(o => o.IdAreaServicio == persona.IdAreaServicio).FirstOrDefault(); var cargo = cargos.Where(o => o.IdCargo == persona.IdCargo).FirstOrDefault(); registro.NombrePersona = persona.ApePaterno + " " + persona.ApeMaterno + ", " + persona.Nombre; registro.VacacionesPeriodo = vacacionesRepository.GetVacacionesPorPeriodoPersona(Anio, registro.IdPersonal ?? 0); registro.ApellidoPaterno = persona.ApePaterno; registro.ApellidoMaterno = persona.ApeMaterno; registro.Nombre = persona.Nombre; registro.CUSPP = persona.CUSPP; registro.Dni = persona.DNI; registro.FechaIngreso = persona.FecIngreso ?? DateTime.Now; registro.AFP = fondo.Entidad; registro.Cargo = cargo.Cargo1; registro.Area = area.Area; } //planilla = planilla.OrderBy(o => o.NombrePersona); return(planilla); } IEnumerable <PlanillaRemuneracion> planillas = GenerarPlanilla(Periodo); if (planillas != null && planillas.Count() > 0) { foreach (PlanillaRemuneracion _planilla in planillas) { planillaRepository.Add(_planilla); } return(GetPlanillaNormalPorPeriodo(Anio, Mes)); } return(planilla); }