예제 #1
0
        public ActionResult FormRegistroPresupuesto(
            string _Detalle,
            string _TipoProveedor,
            string _IdProveedor,
            string[] _IdDocumentoComercial,
            string[] _TipoDeDocumento,
            string[] _ItemsNombres,
            string[] _ItemsDescripciones,
            string[] _ItemsCategoriasCriterios,
            string[] _ItemsValoresTotales
            )
        {
            var n_oe = (OperacionDeEgreso)Session["NuevoEgreso"];

            List <Item> n_items = new List <Item>()
            {
            };

            for (int i = 0; i < _ItemsNombres.Length; i++)
            {
                // Parseo el texto de Categoria, Criterio.
                var categorias_criterios = new Dictionary <String, List <String> > {
                };
                string categoria, criterio;

                foreach (String dupla in _ItemsCategoriasCriterios[i].Replace(" ", string.Empty).Split('.'))
                {
                    if (dupla.Count() > 0)
                    {
                        categoria = dupla.Split(',')[0];
                        criterio  = dupla.Split(',')[1];

                        if (!categorias_criterios.ContainsKey(categoria))
                        {
                            categorias_criterios.Add(categoria, new List <string> {
                            });
                        }

                        if (!categorias_criterios[categoria].Contains(criterio))
                        {
                            categorias_criterios[categoria].Add(criterio);
                        }
                    }
                }

                var categorias = new List <Categoria> {
                };

                foreach (var kvp in categorias_criterios)
                {
                    foreach (var value in kvp.Value)
                    {
                        categorias.Add(
                            new Categoria(kvp.Key,
                                          new Criterio(value, null)));
                    }
                }

                n_items.Add(
                    new Item(
                        _ItemsNombres[i],
                        _ItemsDescripciones[i],
                        float.Parse(_ItemsValoresTotales[i]),
                        categorias
                        )
                    );
            }

            var n_documentosComerciales = new List <DocumentoComercial>()
            {
            };

            for (int i = 0; i < _IdDocumentoComercial.Length; i++)
            {
                n_documentosComerciales.Add(
                    new DocumentoComercial(int.Parse(_IdDocumentoComercial[i]), _TipoDeDocumento[i])
                    );
            }

            PersonaProveedora         n_personaProveedora         = null;
            EntidadJuridicaProveedora n_entidadJuridicaProveedora = null;

            if (_TipoProveedor == "PersonaProveedora")
            {
                n_personaProveedora = PersonaProveedoraDAO.obtenerPersonaProveedora(int.Parse(_IdProveedor));
            }
            if (_TipoProveedor == "EntidadJuridicaProveedora")
            {
                n_entidadJuridicaProveedora = EntidadJuridicaProveedoraDAO.obtenerEntidadJuridicaProveedora(int.Parse(_IdProveedor));
            }

            var n_presupuesto = new Presupuesto(
                n_personaProveedora,
                n_entidadJuridicaProveedora,
                n_items,
                null,
                _Detalle,
                n_documentosComerciales
                );

            n_oe.Compra.agregarPresupuesto(n_presupuesto);

            Session["CantPresReq"] = (int)Session["CantPresReq"] - 1;

            if ((int)Session["CantPresReq"] > 0)
            {
                Session["NuevoEgreso"] = n_oe;
                return(RedirectToAction("NuevoPresupuesto", "Home"));
            }
            else
            {
                OperacionDeEgresoDAO.guardar((OperacionDeEgreso)Session["NuevoEgreso"]);
                return(RedirectToAction("Egresos", "Home"));
            }
        }
예제 #2
0
        public ActionResult FormRegistroCompra(
            string _IdOrg,
            string _fechaCompra,
            string _cantPresReq,
            string[] _UsuariosRevisores,
            string _tipoPago,
            string _numero,
            string _IdPais,
            string _Proveedor,
            string[] _IdDocumentoComercial,
            string[] _TipoDeDocumento,
            string[] _ItemsNombres,
            string[] _ItemsDescripciones,
            string[] _ItemsCategoriasCriterios,
            string[] _ItemsValoresTotales
            )
        {
            List <Item> n_items = new List <Item>()
            {
            };

            for (int i = 0; i < _ItemsNombres.Length; i++)
            {
                // Parseo el texto de Categoria, Criterio.
                var categorias_criterios = new Dictionary <String, List <String> > {
                };
                string categoria, criterio;

                foreach (String dupla in _ItemsCategoriasCriterios[i].Replace(" ", string.Empty).Split('.'))
                {
                    if (dupla.Count() > 0)
                    {
                        categoria = dupla.Split(',')[0];
                        criterio  = dupla.Split(',')[1];

                        if (!categorias_criterios.ContainsKey(categoria))
                        {
                            categorias_criterios.Add(categoria, new List <string> {
                            });
                        }

                        if (!categorias_criterios[categoria].Contains(criterio))
                        {
                            categorias_criterios[categoria].Add(criterio);
                        }
                    }
                }

                var categorias = new List <Categoria> {
                };

                foreach (var kvp in categorias_criterios)
                {
                    foreach (var value in kvp.Value)
                    {
                        categorias.Add(
                            new Categoria(kvp.Key,
                                          new Criterio(value, null)));
                    }
                }

                n_items.Add(
                    new Item(
                        _ItemsNombres[i],
                        _ItemsDescripciones[i],
                        float.Parse(_ItemsValoresTotales[i]),
                        categorias
                        )
                    );
            }


            //Operación de egreso
            MedioDePago n_medioDePago = new MedioDePago(_IdPais, _numero, _tipoPago);

            var n_documentosComerciales = new List <DocumentoComercial>()
            {
            };

            for (int i = 0; i < _IdDocumentoComercial.Length; i++)
            {
                n_documentosComerciales.Add(
                    new DocumentoComercial(int.Parse(_IdDocumentoComercial[i]), _TipoDeDocumento[i])
                    );
            }

            var n_usuarios = new List <Usuario> {
            };

            foreach (string IdUsuario in _UsuariosRevisores)
            {
                n_usuarios.Add(UsuarioDAO.obtenerUsuario(int.Parse(IdUsuario)));
            }

            PersonaProveedora         n_personaProveedora         = null;
            EntidadJuridicaProveedora n_entidadJuridicaProveedora = null;

            string id_proveedor   = _Proveedor.Split(' ')[0];
            string tipo_proveedor = _Proveedor.Split(' ')[1];

            if (tipo_proveedor == "pp")
            {
                n_personaProveedora = PersonaProveedoraDAO.obtenerPersonaProveedora(int.Parse(id_proveedor));
            }
            if (tipo_proveedor == "ejp")
            {
                n_entidadJuridicaProveedora = EntidadJuridicaProveedoraDAO.obtenerEntidadJuridicaProveedora(int.Parse(id_proveedor));
            }

            CriterioCompra n_criterio = new MenorValor();

            if (_cantPresReq == "")
            {
                _cantPresReq = "0";
            }

            Compra n_compra = new Compra(
                int.Parse(_cantPresReq),
                n_criterio,
                n_items,
                n_usuarios,
                n_personaProveedora,
                n_entidadJuridicaProveedora
                );

            OperacionDeEgreso n_oe = new OperacionDeEgreso(
                n_compra,
                n_medioDePago,
                n_documentosComerciales,
                DateTime.Parse(_fechaCompra)
                );

            n_oe.ID_Organizacion = int.Parse(_IdOrg);


            if (_cantPresReq == null || int.Parse(_cantPresReq) == 0)
            {
                OperacionDeEgresoDAO.guardar(n_oe);
                return(RedirectToAction("Egresos", "Home"));
            }
            else
            {
                Session["NuevoEgreso"]    = n_oe;
                Session["CantPresReq"]    = int.Parse(_cantPresReq);
                Session["CantPresReqMax"] = int.Parse(_cantPresReq);
                return(RedirectToAction("NuevoPresupuesto", "Home"));
            }
        }