private void butConfirmar_Click(object sender, System.EventArgs e) { usuario = (IUsuarios)Session["usuario"]; bool ok = true; Hashtable hGuiasNR = new Hashtable(); // Guías que no están en condiciones de ser recibidas DsGuiaColectora dsGuiasNR = new DsGuiaColectora(); string CBIngresados = txtCodigosBarraIngresado.Text.Split('-')[0]; // Obtengo el listado de códigos ingresados string[] codigosIngresados = CBIngresados.Split('@'); int cant = Utiles.Validaciones.obtieneEntero(this.txtGuiaIndex.Text); DsDetalleHojaRutaRepartidor dsDetalle = new DsDetalleHojaRutaRepartidor(); for (int i = 0; i < codigosIngresados.Length - 1; i++) { int guiaID = Utiles.Validaciones.obtieneEntero(codigosIngresados[i]); // si la guía existe en el sistema, la ingreso a la HRR if (guiaID > 0) { ds = (DsHojaRutaRepartidor)Session["HojaRutaRepartidorColectora"]; // Reviso si la guía puede ser incluida en la HRRepartidor. Busco en el Ds que se cargo al principio if (ds.Guias.Select("GuiaID = " + guiaID).Length > 0) { DsDetalleHojaRutaRepartidor.DatosRow drDetalle = (DsDetalleHojaRutaRepartidor.DatosRow)dsDetalle.Datos.NewRow(); drDetalle.AgenciaID = AgenciaConectadaID; drDetalle.EstadoGuiaHojaRutaRepartidor = 1; drDetalle.GuiaID = guiaID; drDetalle.Prioridad = 0; drDetalle.GenerarFacturaRemito = false; dsDetalle.Datos.AddDatosRow(drDetalle); } // fin if EsRecepcionable else // La guia no puede ser incluida. Consulto el motivo. Guardo el nro y el motivo por el cual no puede ser incluida { // acá debería guardar las que no se pueden recibir y luego mostrarlas en un alert... IGuia oGuia = GuiaFactory.GetGuia(); oGuia.GuiaID = guiaID; oGuia.ConsultarGuiaColectora(); oGuia.UnidadNegocioID = this.UnidadNegocioID; oGuia.UsuarioID = usuario.UsuarioID; string guia = oGuia.NroSucursalGuia + "-" + oGuia.NroGuia + "-" + oGuia.TipoGuia; //if (hGuiasNR.ContainsKey(guia) == false) //{ // hGuiasNR.Add(guia, oGuia.MotivoNoRecepcionable); //} ok = false; if (dsGuiasNR.Datos.FindByGuiaID(oGuia.GuiaID) == null) { dsGuiasNR.Datos.AddDatosRow(oGuia.GuiaID, "", 0, 0, 0, 0, 0, 0, DateTime.Now, 0, 0, 0, "", DateTime.Now, "", DateTime.Now, "", "", 0, 0, 0, "", DateTime.Now, 0, "", false, 0, false, false, 0, 0, 0, 0, oGuia.MotivoNoRecepcionable, "", "", "", "", 0, 0, false, false, guia); } } } } // fin for this.txtSeGuardo.Text = "0"; this.txtSeGuardoSinErrores.Text = "0"; // Si hay guias que guardar, genero la Hoja de Ruta del Repartidor if (dsDetalle.Datos.Count > 0) { IHojaRutaRepartidor hojaRutaRepartidor = HojaRutaRepartidorFactory.GetHojaRutaRepartidor(); hojaRutaRepartidor.DsDetalle = dsDetalle; hojaRutaRepartidor.Fecha = DateTime.Now; hojaRutaRepartidor.EstadoHojaRutaRepartidor = (int)NegociosSisPackInterface.SisPack.EstadoHojaRutaRepartidor.GeneradaporColectoradeDatos; //Generada por Colectora de Datos hojaRutaRepartidor.UsuarioID = usuario.UsuarioID; hojaRutaRepartidor.AgenciaID = this.AgenciaConectadaID; hojaRutaRepartidor.Generar(); hojaRutaRepartidor.Consultar(); lblGuia.Text = string.Empty; lblCliente.Text = string.Empty; lblDestino.Text = string.Empty; lblBultos.Text = string.Empty; txtNroHojaRutaRepartidor.Text = hojaRutaRepartidor.NroHojaRutaRepartidor.ToString(); //uppnlDatosGuias.Update(); this.txtSeGuardo.Text = "1"; } Session["GuiasNRHojaRutaRepartidor"] = hGuiasNR; if (ok) { Session["GuiasNRHojaRutaRepartidor"] = null; Session["DsGuiasNRHojaRutaRepartidor"] = null; this.txtSeGuardoSinErrores.Text = "1"; } else { Session["GuiasNRHojaRutaRepartidor"] = hGuiasNR; Session["DsGuiasNRHojaRutaRepartidor"] = dsGuiasNR; if (Session["DsGuiasNRHojaRutaRepartidor"] != null) { dsGuiasNR = (DsGuiaColectora)Session["DsGuiasNRHojaRutaRepartidor"]; if (dsGuiasNR.Datos.Count > 0) { MostrarGuiasNoRecepcionables(dsGuiasNR); } } //Response.Redirect("HojaRutaRepartidor.aspx?d=1"); } string txtSeGuardo = this.txtSeGuardo.ClientID; string txtNroHojaRutaRepartidor1 = this.txtNroHojaRutaRepartidor.ClientID; string txtSeGuardoSinErrores = this.txtSeGuardoSinErrores.ClientID; System.Text.StringBuilder scriptString = new System.Text.StringBuilder(); scriptString.Append("<script language='javascript'>function MjeError(){\n"); scriptString.Append("if (window.document.getElementById('" + txtSeGuardo + "').value == '0'){\n"); scriptString.Append(" alert('No se genero Hoja de Ruta. Sin datos que guardar.');\n"); scriptString.Append("if (window.document.getElementById('" + txtSeGuardoSinErrores + "').value == '0'){\n"); scriptString.Append(" window.document.getElementById('tblGuias').style.display = 'none';\n"); scriptString.Append(" window.document.getElementById('tblBotones').style.display = 'none';\n"); scriptString.Append(" window.document.getElementById('tblDatos').style.display = 'none';\n"); scriptString.Append("}\n"); scriptString.Append(" } else {\n"); scriptString.Append(" alert('Datos Guardados. Se generó la Hoja de Ruta de Reparto: Nº ' + window.document.getElementById('"+ txtNroHojaRutaRepartidor1 + "').value);\n"); scriptString.Append("if (window.document.getElementById('" + txtSeGuardoSinErrores + "').value == '1'){\n"); scriptString.Append("window.location = 'HojaRutaRepartidor.aspx';\n"); scriptString.Append("}else{\n"); scriptString.Append(" window.document.getElementById('tblGuias').style.display = 'none';\n"); scriptString.Append(" window.document.getElementById('tblBotones').style.display = 'none';\n"); scriptString.Append(" window.document.getElementById('tblDatos').style.display = 'none';\n"); scriptString.Append("}\n"); scriptString.Append("}\n"); scriptString.Append("}\n</script>"); Page.RegisterClientScriptBlock("MjeError", scriptString.ToString()); //ScriptManager.RegisterClientScriptBlock(this.uppnlBotones, // uppnlBotones.GetType(), // "MjeError", // script, // true); }
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(); } } }