Ejemplo n.º 1
0
        private void butConfirmar_Click(object sender, System.EventArgs e)
        {
            usuario = (IUsuarios)Session["usuario"];

            bool      ok                         = true;
            Hashtable hGuias                     = new Hashtable(); // Guías que no se pueden recibir, porque son de ag. no automatizadas o no existen
            Hashtable hGuiasNR                   = new Hashtable(); // Guías que no están en condiciones de ser conformadas
            Hashtable hGuiasIncompletas          = new Hashtable(); // Guías que se pueden recibir, pero no se completaron los datos (valor declarado, bultos y agencias)
            Hashtable hRemitosFaltaIngresarDatos = new Hashtable(); // Remitos que no se pueden conformar por que le falta ingresar los datos para facturar

            DsFacturaImpresion.DatosRow drFac;
            Hashtable hGuiasSinCompletar = new Hashtable(); // Guías que pertenecen a la HRepartidor original pero que no se ingresaron en la conformacion/observacion masiva.
            Hashtable hGuiasIngresadas   = new Hashtable(); // Guías que se ingresaron, lo utilizo para hacer una validacion al final

            // Busco los datos de la agencia
            IAgencia datosAgencia = AgenciaFactory.GetAgencia();

            datosAgencia.AgenciaID = usuario.AgenciaID;
            datosAgencia.Consultar();

            DsDatosGenerarFactura dsDatosFacturasAGenerar;

            if (Session["DatosFacturasARealizarConformacionMasivaCB"] != null)
            {
                dsDatosFacturasAGenerar = (DsDatosGenerarFactura)Session["DatosFacturasARealizarConformacionMasivaCB"];
            }
            else
            {
                dsDatosFacturasAGenerar = new DsDatosGenerarFactura();
            }
            DsFacturaImpresion          dsFAImprimir = new DsFacturaImpresion();
            DsDetalleHojaRutaRepartidor dsDetalle    = new DsDetalleHojaRutaRepartidor();
            DsHojaRutaRepartidor        dsHR         = (DsHojaRutaRepartidor)Session["dsHojaRutaRepartidor"];

            if (Session["DsDetalleHojaRutaRepartidor"] != null)
            {
                dsDetalle = (DsDetalleHojaRutaRepartidor)Session["DsDetalleHojaRutaRepartidor"];
            }

            if (Session["hGuiasIngresadas"] != null)
            {
                hGuiasIngresadas = (Hashtable)Session["hGuiasIngresadas"];
            }

            int cant = Utiles.Validaciones.obtieneEntero(this.txtGuiaIndex.Text);

            for (int i = 0; i < cant; i++)
            {
                string txt        = "txt" + i;
                string obs        = "Obs" + i.ToString() + "$txtObservacionID";
                string obsCodigo  = "Obs" + i.ToString() + "$txtCodigo";
                string obsDescrip = "Obs" + i.ToString() + "$txtObsDescrip";
                string ddl        = "ddl" + i.ToString();

                string nroGuia       = Request.Form[txt].ToString();
                string observacionID = Request.Form[obs].ToString();
                string sObsCodigo    = Request.Form[obsCodigo].ToString();
                string sObsDescrip   = Request.Form[obsDescrip].ToString();

                // Lógica para recibir (y observar) guías
                string tGuia = "";

                tGuia = NegociosSisPackInterface.SisPack.TipoGuia(nroGuia.Substring(0, 1));

                string nroSucursal = nroGuia.Substring(1, 4);
                string nGuia       = nroGuia.Substring(5);

                IGuia oGuia = GuiaFactory.GetGuia();
                oGuia.NroGuia         = Utiles.Validaciones.obtieneEntero(nGuia);
                oGuia.NroSucursalGuia = nroSucursal;
                oGuia.TipoGuia        = tGuia;
                oGuia.Consultar();
                oGuia.EsRecepcion     = 1;
                oGuia.UnidadNegocioID = this.UnidadNegocioID;
                oGuia.UsuarioID       = usuario.UsuarioID;

                IGuiaFactura oGuiaFactura = GuiaFacturaFactory.GetGuiaFactura();
                oGuiaFactura.UsuarioID = usuario.UsuarioID;

                // si la guía existe en el sistema, verifco si está en condiciones de conformarse y si es así la conformo
                if (oGuia.GuiaID > 0)
                {
                    //SFE: 22/08/2012. Guardo las guias ingresadas para al final del foreach realizar una validacion.
                    hGuiasIngresadas.Add(oGuia.GuiaID, nroSucursal + "-" + nGuia + "-" + tGuia);

                    // Reviso si la guía esta en condiciones de ser conformada (tanto por que tiene los estados necesarios
                    // en la cabecera de la guía o en los estados historicos)
                    if (EsConformable(oGuia))
                    {
                        // Reviso si se trata de un remito por un flete pago en destino y si es asi, si esta o no facturado
                        if (tGuia == "R" && oGuia.GuiaTieneFPD() && oGuia.RemitoEstaFacturado() == false)
                        {
                            // Se trata de un remito.
                            // Reviso si tengo que observar la guía o conformarla
                            if (Utiles.Validaciones.obtieneEntero(observacionID) > 0)
                            {
                                // tengo que observar la guía
                                oGuia.ObservacionID = Utiles.Validaciones.obtieneEntero(observacionID);
                            }

                            // Tengo que conformar la guía
                            // Reviso si la agencia es autoimpresora
                            if (datosAgencia.TipoImpresionGuiaId == (int)NegociosSisPackInterface.SisPack.TipoImpresionGuia.PreImpresa)
                            {
                                // la agencia no es autoimpresora. marco como que no se puede conformar la guía
                                hGuiasNR.Add(oGuia.GuiaID, nroSucursal + "-" + nGuia + "-" + tGuia);
                            }
                            else
                            {
                                // La agencia es autoimpresora
                                // Reviso si se ingreso la información para facturar el remito
                                if (Validaciones.obtieneEntero(dsDatosFacturasAGenerar.Datos.Compute("count(guiaid)", "guiaid=" + oGuia.GuiaID.ToString()).ToString()) == 0)
                                {
                                    dsDatosFacturasAGenerar.Datos.Select("guiaid =" + oGuia.GuiaID.ToString());
                                    // No se ingreso la información de la factura.
                                    if (hRemitosFaltaIngresarDatos.ContainsKey(oGuia.GuiaID) == false)
                                    {
                                        hRemitosFaltaIngresarDatos.Add(oGuia.GuiaID, nroGuia);//Validaciones.obtieneEntero(nroSucursal).ToString("0000") + " - " + Validaciones.obtieneEntero(nroGuia).ToString("00000000") + "-" + tGuia);
                                        ok = false;
                                    }
                                }
                                else
                                {
                                    // Si se ingreso la información de la factura
                                    ((IGuia)oGuiaFactura).GuiaID    = oGuia.GuiaID;
                                    ((IGuia)oGuiaFactura).UsuarioID = usuario.UsuarioID;

                                    // Cargo la información para realizar la factura
                                    IFactura oFactura = CargarDatosFactura(((IGuia)oGuiaFactura).GuiaID);
                                    ((IGuia)oGuiaFactura).OFactura = oFactura;

                                    DsDetalleHojaRutaRepartidor.DatosRow dr = (DsDetalleHojaRutaRepartidor.DatosRow)dsDetalle.Datos.NewRow();
                                    dr.GuiaID        = oGuia.GuiaID;
                                    dr.ObservacionID = oGuia.ObservacionID;
                                    dr.Observaciones = sObsDescrip;
                                    dsDetalle.Datos.AddDatosRow(dr);
                                    dsDetalle.Datos.AcceptChanges();
                                }
                            }
                        }
                        else
                        {
                            // Se trata de una guía normal o de un remito de un cliente coorporativo. No de un remito por Flete pago en destino. O el remito ya esta facturado
                            ((IGuia)oGuiaFactura).GuiaID = oGuia.GuiaID;

                            IParametroUNegocio paramAdm = ParametroUNegocioFactory.GetParametroUNegocio();
                            paramAdm.Parametro       = NegociosSisPackInterface.SisPack.Parametro.AgenciaDeAdministracion;
                            paramAdm.UnidadNegocioID = this.UnidadNegocioID;
                            paramAdm.Consultar();
                            int agAdm = Utiles.Validaciones.obtieneEntero(paramAdm.ValorString);
                            paramAdm = null;

                            // Si la agencia conectada es igual a la agencia de destino, le permito conformar
                            if ((this.AgenciaConectadaID == oGuia.AgenciaDestinoID ||
                                 ((this.AgenciaConectadaID != oGuia.AgenciaDestinoID || this.AgenciaConectadaID == agAdm) && oGuia.EstadoSentidoViaje == (int)NegociosSisPackInterface.SisPack.ValorEstadoSentidoViaje.Devolucion) ||
                                 (this.EsGuiaDeAgenciaRedespachoReferenciada(oGuia)) ||
                                 (this.EsGuiaDePuntoRecepcionReferenciado(oGuia))))
                            {
                                oGuia.ObservacionID = Utiles.Validaciones.obtieneEntero(observacionID);

                                DsDetalleHojaRutaRepartidor.DatosRow dr = (DsDetalleHojaRutaRepartidor.DatosRow)dsDetalle.Datos.NewRow();
                                //DsDetalleHojaRutaRepartidor.DatosRow dr = (DsDetalleHojaRutaRepartidor.DatosRow)dsDetalle.Datos.NewRow();
                                dr.GuiaID        = oGuia.GuiaID;
                                dr.ObservacionID = oGuia.ObservacionID;
                                dr.Observaciones = sObsDescrip;
                                dsDetalle.Datos.AddDatosRow(dr);
                                dsDetalle.Datos.AcceptChanges();
                            }
                            else
                            {
                                // No se puede conformar...
                                string guia = nroSucursal + "-" + nGuia + "-" + tGuia;
                                if (!hGuiasNR.ContainsKey(oGuia.GuiaID))
                                {
                                    hGuiasNR.Add(oGuia.GuiaID, guia);
                                    // SFE
                                    ok = false;
                                }
                            }
                        }
                    } // fin if EsConformable
                    else
                    {
                        // La guía no existe... no se puede conformar...
                        string guia = nroSucursal + "-" + nGuia + "-" + tGuia;
                        if (!hGuiasNR.ContainsKey(oGuia.GuiaID))
                        {
                            hGuiasNR.Add(oGuia.GuiaID, guia);
                        }
                        ok = false;
                    }
                }
                else
                {
                    // La guía no existe... no se puede conformar...
                    string guia = nroSucursal + "-" + nGuia + "-" + tGuia;
                    if (!hGuiasNR.ContainsKey(oGuia.GuiaID))
                    {
                        hGuiasNR.Add(oGuia.GuiaID, guia);
                    }
                    ok = false;
                }
            } // fin for


            //SFE: 22/08/2012. Recorro el detalle de las guias que componen la Hoja de Ruta del Repartidor
            foreach (DsHojaRutaRepartidor.GuiasRow item in dsHR.Guias)
            {
                //SFE: 22/08/2012. Valido que las guias que se ingresaron se correspondan y esten todas con las guias de la HRepartidor
                // Es decir verifico que en el HashTable de guias ingresadas exista el item que compone la HR, sino existe la coloco en el Hash de guias sin completar para mostrarla nuevamente.
                if (hGuiasIngresadas.ContainsKey(item.GuiaID) == false)
                {
                    ok = false;
                    hGuiasSinCompletar.Add(item.GuiaID, item.NroCompletoGuia);
                }
            }
            //SFE: 22/08/2012. Fin

            // Este dsDetalle contiene las guias ingresadas y que pertenecen a la HRepartidor, va a servir para marcarlas en la pagina de atras (la que llama).
            Session["DsDetalleHojaRutaRepartidor"] = dsDetalle;
            Session["GuiasNR"] = hGuiasNR;
            Session["hRemitosFaltaIngresarDatos"] = hRemitosFaltaIngresarDatos;
            Session["hGuiasSinCompletar"]         = hGuiasSinCompletar;
            Session["hGuiasIngresadas"]           = hGuiasIngresadas;

            StringBuilder scriptRedirect = new StringBuilder();

            if (ok)
            {
                Session["GuiasDefectuosas"]   = null;
                Session["hGuiasIngresadas"]   = null;
                Session["hGuiasSinCompletar"] = null;

                StringBuilder scriptFinal = new StringBuilder();
                scriptFinal.Append("<script type=\"text/javascript\">\n");
                scriptFinal.Append("window.close();\n");
                scriptFinal.Append("</script>");
                Page.RegisterStartupScript("DatosRegistrados", scriptFinal.ToString());
            }
            else
            {
                if (hGuiasIncompletas != null && hGuiasIncompletas.Count > 0)
                {
                    hGuias = hGuiasIncompletas;
                }

                this.txtGuiasDefectuosas.Text = "1";
                Session["GuiasDefectuosas"]   = hGuias;;

                Hashtable hGuiasNr = new Hashtable();
                if (Session["GuiasNR"] != null)
                {
                    hGuiasNr = (Hashtable)Session["GuiasNR"];

                    if (hGuiasNr.Count > 0)
                    {
                        MostrarGuiasNoConformables(hGuiasNr);
                    }
                }
                else
                {
                    this.lblMensaje.Visible = false;
                }

                if (Session["hRemitosFaltaIngresarDatos"] != null && ((Hashtable)Session["hRemitosFaltaIngresarDatos"]).Count > 0)
                {
                    // Si hay remitos que no se conformaron por falta de ingreso de datos. Muetro el mensaje de error y vuelvo a cargar los datos de estos remitos
                    MostrarRemitosSinConformarPorFaltaDatos();
                }
                if (Session["hGuiasSinCompletar"] != null && ((Hashtable)Session["hGuiasSinCompletar"]).Count > 0)
                {
                    // Si hay guias que pertenecen a la HRepartidor y no se ingresaron. Muetro el mensaje de error y vuelvo a cargar los datos de estos remitos
                    MostrarGuiasNoIngresadas();
                }
            }
        }
Ejemplo n.º 2
0
        public int AgregarGuia(IGuia guia, IUsuarios usuario, int agenciaConectadaID, int cantGuias, string nroRemito)
        {
            using (SqlConnection conexion = new SqlConnection())
            {
                GuiaServicioConfirmacion guiaServicio = new GuiaServicioConfirmacion();
                SqlTransaction           transaccion  = null;
                transaccion = null;
                conexion.ConnectionString = Config.ConnectionString;
                try
                {
                    // Abro la conexión a la BD
                    conexion.Open();
                    // Inicio una transacción
                    transaccion = conexion.BeginTransaction();

                    // Reviso si la guía esta Conformada o Entregada. Si no está conformada o entregada la conformo.
                    //if ((!guia.RevisarSiTieneEstadoHistoricoBuscado(7, 4, guia.AgenciaDestinoID)) && (!guia.RevisarSiTieneEstadoHistoricoBuscado(6, 1, guia.AgenciaDestinoID)))

                    /*10/10/2012: Si la guia va a un punto de recepcion ajeno debo buscar cual es la agencia de referencia de redespacho para que se conforme para dicha agencia*/
                    int agenciaDestinoID = 0;
                    if (guia.PuntoRecepcionID > 0)
                    {
                        PuntoRecepcion puntoRecepcion = new PuntoRecepcion();
                        puntoRecepcion.PuntoRecepcionID = guia.PuntoRecepcionID;
                        puntoRecepcion.Consultar();
                        if (puntoRecepcion.AgenciaReferenciaRedespacho > 0)
                        {
                            agenciaDestinoID = puntoRecepcion.AgenciaReferenciaRedespacho;
                        }
                        else
                        {
                            // Si en el caso que el punto de recepcion no tuviera agencia de referencia de redespacho, coloco como conformada a la agencia origen de la guia.
                            agenciaDestinoID = guia.AgenciaOrigenID;
                        }
                    }
                    else
                    {
                        agenciaDestinoID = guia.AgenciaDestinoID == 0 ? guia.AgenciaOrigenID : guia.AgenciaDestinoID; //En caso de error tomo agenciadestino = agenciaorigen
                    }
                    //DM 09/10/2012 modificado para que no tome un guia anulada y si ya ha sido conformada por alguna agencia
                    if ((!guia.RevisarSiTieneEstadoHistoricoBuscado(7, 4, agenciaDestinoID)) && (!guia.RevisarSiTieneEstadoHistoricoBuscado(6, 1, agenciaDestinoID)) && (!guia.EsGuiaAnulada(guia.GuiaID)) && (!guia.RevisarSiTieneEstadoHistoricoBuscadoSinAgencia(7, 4)))
                    {
                        #region Remito en cuenta corriente
                        if (guia.TipoGuia.Equals("R") && guia.GuiaTieneFPD() && guia.RemitoEstaFacturado() == false)
                        {
                            /* VSA: Controlar si el remito original se pasó a cuenta corriente -> Generar remito no factura. */
                            GuiaPasajeACtaCte oDatos = new GuiaPasajeACtaCte();
                            oDatos.GuiaID = guia.GuiaID;
                            oDatos.Consultar();
                            if (oDatos.ClienteIDNuevo != 0 && oDatos.ClienteIDAnt == 0)
                            {
                                guia.OFactura = new Factura();
                                guia.OFactura.ClasificacionFacturaID = (int)SisPack.ClasificacionFactura.Remito;
                                guia.OFactura.ClienteID       = oDatos.ClienteIDNuevo;
                                guia.OFactura.CondicionPagoID = (int)NegociosSisPackInterface.SisPack.CondicionPago.CuentaCorriente;

                                Cliente cliente = new Cliente();
                                cliente.ClienteID = oDatos.ClienteIDNuevo;
                                cliente.Consultar();
                                guia.OFactura.CondicionIVAAgentePago = (int)cliente.CondicionIva;
                                guia.OFactura.NroCUITAgentePago      = cliente.NroCuit;
                            }
                            oDatos = null;
                        }
                        #endregion

                        /*16/05/2012: Si la guia va a un punto de recepcion ajeno debo buscar cual es la agencia de referencia de redespacho para que se conforme para dicha agencia*/
                        //int agenciaDestinoID = 0;
                        //if (guia.PuntoRecepcionID > 0)
                        //{
                        //    PuntoRecepcion puntoRecepcion = new PuntoRecepcion();
                        //    puntoRecepcion.PuntoRecepcionID = guia.PuntoRecepcionID;
                        //    puntoRecepcion.Consultar();
                        //    if (puntoRecepcion.AgenciaReferenciaRedespacho > 0)
                        //        agenciaDestinoID = puntoRecepcion.AgenciaReferenciaRedespacho;
                        //    else
                        //        // Si en el caso que el punto de recepcion no tuviera agencia de referencia de redespacho, coloco como conformada a la agencia origen de la guia.
                        //        agenciaDestinoID = guia.AgenciaOrigenID;
                        //}
                        //else
                        //    agenciaDestinoID = guia.AgenciaDestinoID;

                        if (!guia.Entregada("Guía conformada por proceso de Recepción de Conformadas", agenciaDestinoID, transaccion, usuario))
                        {
                            new Exception("La guía " + guia.TipoGuia + " - " + guia.NroSucursalGuia + " - " + guia.NroGuia + " no se puede conformar correctamente.");
                        }
                    }

                    int lote = guia.RecibidaControlada("", agenciaConectadaID, usuario, this.CajaID, cantGuias, transaccion);

                    if (lote == 0) /* La guía ya se almacenó rollback */
                    {
                        new Exception("La guía " + guia.TipoGuia + " - " + guia.NroSucursalGuia + " - " + guia.NroGuia + " ya está almacenada en otra caja.");
                    }
                    else
                    {
                        if (nroRemito != string.Empty) // si el remito es string.Empty es que no se selecciono para confirmar servicio
                        {
                            //Diego Guardo la confirmacion del servicio
                            guiaServicio.Fecha     = DateTime.Now;
                            guiaServicio.AgenciaID = agenciaConectadaID;
                            guiaServicio.GuiaID    = guia.GuiaID;
                            guiaServicio.NroRemito = nroRemito;
                            guiaServicio.UsuarioID = usuario.UsuarioID;
                            guiaServicio.GuardarConfirmacion(transaccion);
                        }
                    }

                    transaccion.Commit();
                    return(lote);
                }
                catch (Exception ex)
                {
                    transaccion.Rollback();
                    throw ex;
                }
            }
        }