public List <TraspasoPresupuesto> listarTraspasoPresupuesto(SqlConnection serConn)
        {
            CultureInfo[] cultures = { new CultureInfo("en-US"),
                                       new CultureInfo("fr-FR") };
            if (serConn.State != ConnectionState.Open)
            {
                serConn.Open();
            }
            List <TraspasoPresupuesto> traspasoPresupuestoList = new List <TraspasoPresupuesto>();

            if (serConn == null)
            {
                return(traspasoPresupuestoList);
            }

            List <Osur> osurList = Osur.listarOsur(serConn).Where(o => o.idAplicacion != null && o.idAplicacion > 0).ToList();
            List <RelacionOsurPresupuesto> listRelacionOsurPresupuiersto = RelacionOsurPresupuesto.listarRelacionOsurPresupuesto(serConn);

            foreach (Osur osur in osurList)
            {
                RelacionOsurPresupuesto relacionOrigen  = listRelacionOsurPresupuiersto.Find(o => o.idOsur == osur.idOsur);
                RelacionOsurPresupuesto relacionDestino = listRelacionOsurPresupuiersto.Find(o => o.idOsur == osur.idAplicacion);
                if (relacionOrigen != null && relacionDestino != null)
                {
                    TraspasoPresupuesto traspaso = new TraspasoPresupuesto();
                    traspaso.idPresupuestoOrigen  = relacionOrigen.idPresupuesto;
                    traspaso.idPresupuestoDestino = relacionDestino.idPresupuesto;
                    traspaso.monto = Convert.ToDecimal(osur.presupuestoAplicacion, cultures[0]);
                    traspasoPresupuestoList.Add(traspaso);
                }
            }

            return(traspasoPresupuestoList);
        }
Beispiel #2
0
        public List <PresupuestoOrden> listarPresupuestoOrden(SqlConnection serConn)
        {
            Console.WriteLine("Creacion de lista presupuestoOrden");
            if (serConn.State != ConnectionState.Open)
            {
                serConn.Open();
            }
            Presupuesto accederPresupuesto = new Presupuesto();
            //List<Presupuesto> listaPresupuesto = accederPresupuesto.listarPresupuesto(serConn);
            List <ConsecutivoZona>         listConsecutivoZona          = ConsecutivoZona.listarConsecutivoZona(serConn);
            List <RelacionOsurPresupuesto> listaRelacionOsurPresupuesto = RelacionOsurPresupuesto.listarRelacionOsurPresupuesto(serConn);
            List <RelacionCitaOrdenes>     listRelacionCitasOrdenes     = RelacionCitaOrdenes.listarRelacionCitaOrdenes(serConn).Where(o => o.idTrabajoTalleres != null).ToList();
            List <Ordenes>        listOrdenes       = Ordenes.listarOrdenes(serConn);
            List <Unidades>       listUnidades      = Unidades.listarUnidades(serConn);
            List <CentroTrabajos> listCentroTrabajo = CentroTrabajos.listarCentroTrabajos(serConn).Where(o => o.idOperacion == 3).ToList();

            List <PresupuestoOrden> listPresupuestoOrden = new List <PresupuestoOrden>();

            foreach (ConsecutivoZona consecutivoZona in listConsecutivoZona)
            {
                //Presupuesto presupuesto = listaPresupuesto.Find(o => o.Id == consecutivoZona.idOsur);
                RelacionOsurPresupuesto relacionOsurPresu   = listaRelacionOsurPresupuesto.Find(o => o.idOsur == consecutivoZona.idOsur);
                RelacionCitaOrdenes     relacionCitaOrdenes = listRelacionCitasOrdenes.Find(o => o.idTrabajoTalleres == consecutivoZona.idTrabajo);
                if (relacionCitaOrdenes == null)
                {
                    Console.Write("no existe relación de ordenes");
                }
                Ordenes        orden         = null;
                Unidades       unidad        = null;
                CentroTrabajos centroTrabajo = null;
                if (relacionCitaOrdenes != null)
                {
                    orden = listOrdenes.Find(o => o.idOrden == relacionCitaOrdenes.idOrdenAseprot);
                    if (orden != null)
                    {
                        unidad = listUnidades.Find(o => o.idUnidad == orden.idUnidad);
                        if (unidad != null)
                        {
                            centroTrabajo = listCentroTrabajo.Find(o => o.idCentroTrabajo == unidad.idCentroTrabajo);
                        }
                        else
                        {
                            Console.Write("no existe unidad");
                        }
                    }
                    else
                    {
                        Console.Write("no existe orden");
                    }
                }
                else
                {
                    Console.Write("no existe relación cita de ordenes");
                }


                if (relacionOsurPresu != null && relacionCitaOrdenes != null && orden != null && unidad != null && centroTrabajo != null)
                {
                    PresupuestoOrden presupuestoOrden = new PresupuestoOrden();
                    presupuestoOrden.idPresupuesto = relacionOsurPresu.idPresupuesto;
                    presupuestoOrden.idOrden       = relacionCitaOrdenes.idOrdenAseprot;
                    presupuestoOrden.fechaAlta     = consecutivoZona.fechaGeneracion;
                    presupuestoOrden.idUsuario     = 514;
                    presupuestoOrden.consecutivo   = consecutivoZona.numeroConsecutivo;
                    presupuestoOrden.zona          = consecutivoZona.idZona == 1 ? "N" : consecutivoZona.idZona == 2 ? "C" : consecutivoZona.idZona == 3 ? "P" : "G";
                    presupuestoOrden.folio         = "RC-GLR" + presupuestoOrden.zona + "-" + centroTrabajo.extra1 + "-" + "00000" + consecutivoZona.numeroConsecutivo + "-" + presupuestoOrden.fechaAlta.Year;
                    listPresupuestoOrden.Add(presupuestoOrden);
                }
            }
            return(listPresupuestoOrden);
        }