/// <summary>
        /// Cargar los detalles de la remisión
        /// </summary>
        private void CargaRemision(string sFolioRemision)
        {
            //Objeto que contiene la remisión
            MedDAL.DAL.remisiones oRemision = new MedDAL.DAL.remisiones();
            MedNeg.Remisiones.BlRemisiones oblRemision = new MedNeg.Remisiones.BlRemisiones();

            oRemision = oblRemision.BuscarRemisionFolio(sFolioRemision);

            //Llenar los campos del pedido
            Session["sIdPedido"] = oRemision.idPedido;
            Session["sIdCliente"] = oRemision.idCliente;
            Session["sIdRemision"] = oRemision.idRemision;

            //Llenar los campos del cliente
            txbCliente.Text = oRemision.clientes.Nombre + " " + oRemision.clientes.Apellidos;
            txbDireccion.Text = oRemision.clientes.Calle + " " + oRemision.clientes.NumeroExt;
            if (oRemision.clientes.NumeroInt != null)
            {
                txbDireccion.Text += "Int: " + oRemision.clientes.NumeroInt;
            }

            txbPoblacion.Text = oRemision.clientes.poblaciones.Nombre.ToString() + ", " + oRemision.clientes.municipios.Nombre.ToString() + ", " + oRemision.clientes.estados.Nombre.ToString();

            //Llenar los datos de la partida de la remisión
            oblRemision = new MedNeg.Remisiones.BlRemisiones();

            //Recuperar la partida del pedido
            var oQuery = oblRemision.RecuperarPartidaRemision(oRemision.idRemision);
            //Session["lstDetallePartida"] = new List<MedNeg.Facturas.BlDetallePartida>();
            if (((List<MedNeg.Facturas.BlDetallePartida>)Session["lstDetallePartida"]).Count() > 0)
            {
                ((List<MedNeg.Facturas.BlDetallePartida>)Session["lstDetallePartida"]).Clear();
            }

            Session["sTotalFactura"] = 0;
            //Recorrer el resultado y meterlo al datagridview
            foreach (MedDAL.DAL.remisiones_partida oDetalle in oQuery)
            {
                oblDetallePartida = new MedNeg.Facturas.BlDetallePartida(
                    Convert.ToInt32(oDetalle.idProducto),
                    oDetalle.productos.Clave1,
                    oDetalle.productos.Nombre,
                    oDetalle.Cantidad,
                    Convert.ToDecimal(oDetalle.IEPS),
                    Convert.ToDecimal(oDetalle.Iva),
                    Convert.ToDecimal(oDetalle.Precio),
                   oDetalle.Observaciones,
                    Convert.ToDecimal((oDetalle.Precio * oDetalle.Cantidad) + oDetalle.IEPS + oDetalle.Iva));

                ((List<MedNeg.Facturas.BlDetallePartida>)Session["lstDetallePartida"]).Add(oblDetallePartida);

                Session["sTotalFactura"] = Convert.ToDecimal(Session["sTotalFactura"]) + Convert.ToDecimal((oDetalle.Precio * oDetalle.Cantidad) + oDetalle.IEPS + oDetalle.Iva);

            }

            //Hacer el binding de la data al dgvDatos
            lblTotal.Text = "TOTAL:$" + Session["sTotalFactura"].ToString();
            dgvPartidaDetalle.DataBind();
        }
예제 #2
0
        /// <summary>
        /// Eliminar
        /// </summary>
        /// <param name="iIdRemision"></param>
        private void Eliminar(int iIdRemision)
        {

            //Eliminar primero la partida para la integridad referencial
            oblRemision = new MedNeg.Remisiones.BlRemisiones();
            string sDatosBitacora= string.Empty;

            //Guardar los datos del pedido para la bitacora
            oRemision = new MedDAL.DAL.remisiones();
            oRemision = oblRemision.BuscarRemision(iIdRemision);

            sDatosBitacora += "Folio:" + oRemision.Folio.ToString()+" ";
            sDatosBitacora += "Fecha:" + oRemision.Fecha.ToShortDateString()+" ";
            switch (oRemision.Estatus)
            {
                case "1":
                    sDatosBitacora += "Estatus:Pedido ";
                    break;
                case "2":
                     sDatosBitacora +="Estatus:Remitido ";
                    break;
                case "3":
                    sDatosBitacora +="Estatus:Facturado ";
                    break;
                case "4":
                    sDatosBitacora += "Estatus:Cancelado ";
                    break;
            }
            
            //Recuperar la partida del pedido
            oblRemision = new MedNeg.Remisiones.BlRemisiones();
            var oQuery = oblRemision.RecuperarPartidaRemision(iIdRemision);
            //Recorrer el resultado y meterlo al datagridview
            foreach (MedDAL.DAL.remisiones_partida oDetalle in oQuery)
            {
                sDatosBitacora += "Producto:" + oDetalle.productos.Nombre.ToString()+" ";
                sDatosBitacora += "Cantidad:" + oDetalle.Cantidad.ToString()+ " ";
                sDatosBitacora += "IEPS:" + oDetalle.IEPS.ToString() + " ";
                sDatosBitacora += "Iva:" + oDetalle.Iva.ToString() + " ";
                sDatosBitacora += "Precio:" + oDetalle.Precio.ToString()+ " ";
                sDatosBitacora += "Total:" + Convert.ToDecimal((oDetalle.Cantidad * oDetalle.Precio) + oDetalle.IEPS + oDetalle.Iva)+ ", ";

            }

            if (oblRemision.EliminarRemisionPartida(iIdRemision))
            {
                oblRemision= new MedNeg.Remisiones.BlRemisiones();
                if (oblRemision.EliminarRegistro(iIdRemision))
                {
                    
                    MedDAL.DAL.bitacora oBitacora = new MedDAL.DAL.bitacora();
                    MedNeg.Bitacora.BlBitacora oblBitacora = new MedNeg.Bitacora.BlBitacora();
                    oBitacora.FechaEntradaSrv = DateTime.Now;
                    oBitacora.FechaEntradaCte = DateTime.Now;//Linea Temporal
                    oBitacora.Modulo = "Remisiones";
                    oBitacora.Usuario = Session["usuario"].ToString();
                    oBitacora.Nombre = Session["nombre"].ToString();
                    oBitacora.Accion = "Eliminación de Remisión";
                    oBitacora.Descripcion = sDatosBitacora;

                    if (!oblBitacora.NuevoRegistro(oBitacora))
                    {
                        lblDatos.Text = "El evento no pudo ser registrado en la bitácora";
                    }
                }
                else
                {
                    lblDatos.Text = "No se pudo eliminar la remisión, por favor vuelva a intentarlo"; 
                }

            }
            else
            {
                lblDatos.Text = "No se pudo eliminar la remisión, por favor vuelva a intentarlo"; 
            }
           
        }
예제 #3
0
        /// <summary>
        /// Cargar los detalles de la remisión
        /// </summary>
        private void CargaRemision(string sFolioRemision)
        {
           //Objeto que contiene la remisión
            MedDAL.DAL.remisiones oRemision = new MedDAL.DAL.remisiones();
            MedNeg.Remisiones.BlRemisiones oblRemision = new MedNeg.Remisiones.BlRemisiones();

            oRemision = oblRemision.BuscarRemisionFolio(sFolioRemision);

            //Llenar los campos del pedido
            Session["sIdPedido"] = oRemision.idPedido;
            Session["sIdCliente"] = oRemision.idCliente;
            Session["sIdRemision"] = oRemision.idRemision;
            
            //Llenar los campos del cliente
            txbCliente.Text = oRemision.clientes.Nombre + " " + oRemision.clientes.Apellidos;
            txbDireccion.Text = oRemision.clientes.Calle + " " + oRemision.clientes.NumeroExt;
            if (oRemision.clientes.NumeroInt != null)
            {
                txbDireccion.Text += "Int: " + oRemision.clientes.NumeroInt;
            }

            txbPoblacion.Text = oRemision.clientes.poblaciones.Nombre.ToString() + ", " + oRemision.clientes.municipios.Nombre.ToString() + ", " + oRemision.clientes.estados.Nombre.ToString();

            //Llenar los datos de la partida de la remisión
            oblRemision = new MedNeg.Remisiones.BlRemisiones();

            //Recuperar la partida del pedido
            List<MedDAL.DAL.remisiones_partida> oQuery = new List<MedDAL.DAL.remisiones_partida>();
            oQuery.AddRange(oblRemision.RecuperarPartidaRemision(oRemision.idRemision));
            //Session["lstDetallePartida"] = new List<MedNeg.Facturas.BlDetallePartida>();
            if (((List<MedNeg.Facturas.BlDetallePartida>)Session["lstDetallePartida"]).Count() > 0)
            {
                ((List<MedNeg.Facturas.BlDetallePartida>)Session["lstDetallePartida"]).Clear();
            }

            Session["sTotalFactura"] = 0;

            //0087 Variables para gestionar la carga de datos del producto o del ensamble
            string sClave;
            string sNombre;
            bool bEsEnsamble;

            //Recorrer el resultado y meterlo al datagridview
            foreach (MedDAL.DAL.remisiones_partida oDetalle in oQuery)
            {
                //0087 Identificar si es un producto o un ensamble
                if (oDetalle.idEnsamble.Equals(null))
                {
                    //Datos del producto
                    sClave = oDetalle.productos.Clave1;
                    sNombre = oDetalle.productos.Nombre;
                    bEsEnsamble = false;
                }
                else
                {
                    //Datos del ensamble
                    sClave = oDetalle.ensamble.ClaveBom;
                    sNombre = oDetalle.ensamble.Descripcion;
                    bEsEnsamble = true;
                }

                oblDetallePartida = new MedNeg.Facturas.BlDetallePartida(
                    Convert.ToInt32(oDetalle.idProducto),
                    //0087 Identificar si es un producto o un ensamble
                    //oDetalle.productos.Clave1,
                    //oDetalle.productos.Nombre,
                    sClave,
                    sNombre,
                    oDetalle.Cantidad,
                    Convert.ToDecimal(oDetalle.IEPS),
                    Convert.ToDecimal(oDetalle.Iva),
                    Convert.ToDecimal(oDetalle.Precio),
                   oDetalle.Observaciones,
                    Convert.ToDecimal((oDetalle.Precio * oDetalle.Cantidad) + oDetalle.IEPS + oDetalle.Iva),
                    oDetalle.Descripcion,
                    bEsEnsamble);

                ((List<MedNeg.Facturas.BlDetallePartida>)Session["lstDetallePartida"]).Add(oblDetallePartida);

                Session["sTotalFactura"] = Convert.ToDecimal(Session["sTotalFactura"]) + Convert.ToDecimal((oDetalle.Precio * oDetalle.Cantidad) + oDetalle.IEPS + oDetalle.Iva);

            }

            //Hacer el binding de la data al dgvDatos
            lblTotal.Text = "TOTAL:$" + Session["sTotalFactura"].ToString();
            dgvPartidaDetalle.DataBind();
        }
예제 #4
0
        /// <summary>
        /// Cargar los datos del pedido y su partida
        /// </summary>
        /// <param name="bDatos"></param>
        protected void CargarFormulario(bool bDatos)
        {
            pnlFormulario.Visible = true;
            pnlCatalogo.Visible = false;

            if (bDatos)
            {

                //Objeto que contiene el id del pedido 
                oblRemision = new MedNeg.Remisiones.BlRemisiones();
                oRemision = new MedDAL.DAL.remisiones();
                oRemision = (MedDAL.DAL.remisiones)oblRemision.BuscarRemision(int.Parse(dgvDatos.SelectedDataKey[0].ToString()));
                
                //Llenar los campos del pedido
                txbFolio.Text = oRemision.Folio;
                txbFecha.Text = oRemision.Fecha.ToShortDateString();
                int iContador = 0;
                cmbEstatus.SelectedIndex = -1;
                foreach (ListItem elemento in cmbEstatus.Items)
                {
                    if (elemento.Value.Equals(oRemision.Estatus.ToString()))
                    {
                        elemento.Selected = true;
                    }
                    iContador++;
                }
                
                //Llenar los campos del cliente
                txbCliente.Text = oRemision.clientes.Nombre + " " + oRemision.clientes.Apellidos;
                txbDireccion.Text = oRemision.clientes.Calle + " " + oRemision.clientes.NumeroExt;
                if (oRemision.clientes.NumeroInt != null)
                {
                    txbDireccion.Text += "Int: " + oRemision.clientes.NumeroInt;
                }

               txbPoblacion.Text = oRemision.clientes.poblaciones.Nombre.ToString() + ", " + oRemision.clientes.municipios.Nombre.ToString() +", " + oRemision.clientes.estados.Nombre.ToString();

               //Lenar los datos de la partida del detalle
               oblRemision = new MedNeg.Remisiones.BlRemisiones();

               //Recuperar la partida del pedido
               var oQuery = oblRemision.RecuperarPartidaRemision(oRemision.idRemision);

               //Limpíar la lista en caso de que tenga algo
               if (((List<MedNeg.Facturas.BlDetallePartida>)Session["lstDetallePartida"]).Count() > 0)
               {
                   ((List<MedNeg.Facturas.BlDetallePartida>)Session["lstDetallePartida"]).Clear();
               }

               Session["sTotalFactura"] = 0;

               //0087 Variables para gestionar la carga de datos del producto o del ensamble
               string sClave;
               string sNombre;
               bool bEsEnsamble;


               //Recorrer el resultado y meterlo al datagridview
               foreach (MedDAL.DAL.remisiones_partida oDetalle in oQuery)
               {
                   //0087 Identificar si es un producto o un ensamble
                   if (oDetalle.idEnsamble.Equals(null))
                   {
                       //Datos del producto
                       sClave = oDetalle.productos.Clave1;
                       sNombre = oDetalle.productos.Nombre;
                       bEsEnsamble = false;
                   }
                   else
                   {
                       //Datos del ensamble
                       sClave = oDetalle.ensamble.ClaveBom;
                       sNombre = oDetalle.ensamble.Descripcion;
                       bEsEnsamble = true;
                   }
                   oblDetallePartida = new MedNeg.Facturas.BlDetallePartida(
                       Convert.ToInt32(oDetalle.idProducto),
                       //0087 Comentar para enviar las variables correspondientes que tienen la info del producto o ensamble
                       //oDetalle.productos.Clave1,
                       //oDetalle.productos.Nombre,
                       sClave,
                       sNombre,
                       oDetalle.Cantidad,
                       Convert.ToDecimal(oDetalle.IEPS),
                       Convert.ToDecimal(oDetalle.Iva),
                       Convert.ToDecimal(oDetalle.Precio),
                      oDetalle.Observaciones,
                       Convert.ToDecimal((oDetalle.Precio * oDetalle.Cantidad)+oDetalle.IEPS+oDetalle.Iva),
                       oDetalle.Descripcion,
                       bEsEnsamble //0087
                       );

                     ((List<MedNeg.Facturas.BlDetallePartida>)Session["lstDetallePartida"]).Add(oblDetallePartida);
                     Session["sTotalFactura"] = Convert.ToDecimal(Session["sTotalFactura"]) + Convert.ToDecimal((oDetalle.Precio * oDetalle.Cantidad) + oDetalle.IEPS + oDetalle.Iva);
               }
               
                //Hacer el binding de la data al dgvDatos
               lblTotal.Text = "TOTAL:$" + Session["sTotalFactura"].ToString();
                dgvPartidaDetalle.DataBind();

                //si el estatus es 1 (Pedido) aun se pueden agregar articulos de lo contario ya no
               if (oRemision.Estatus == "2")
               {
                   HabilitaRemision();
                   Deshabilita();
               }
               else
               {
                   DeshabilitaRemision();
                   Deshabilita();
               }


            }
            else
            {
                Session["lstDetallePartidaPedidos"] = new List<MedNeg.Facturas.BlDetallePartida>();
                dgvPartidaDetalle.DataSource = ((List<MedNeg.Facturas.BlDetallePartida>)Session["lstDetallePartidaPedidos"]);
                dgvPartidaDetalle.DataBind();
                //Limpia();
                //Deshabilita();

            }
        }