public Dictionary <string, string> IdsAcumulados(EUsuario usuario, ETerminal terminal) { var repositorio = new RVenta(); DataTable registros = repositorio.IdRegistroVenta(terminal.Codigo, usuario.IdUsuario); if (registros.IsNullOrEmptyTable()) { return(null); } else { Dictionary <string, string> acumulados = new Dictionary <string, string>(); acumulados.Add("idRegistroVenta", (string)registros.Rows[0]["id_registro_venta"]); //System.Diagnostics.Debug.WriteLine(registros.Rows[0].Field<string>("id_registro_venta")); //System.Diagnostics.Debug.WriteLine(registros.Rows[0].Field<string>("id_tot_med_pago")); foreach (DataRow registro in registros.Rows) { if ((string)registro["id_medio"] != null) { System.Diagnostics.Debug.WriteLine((string)registro["id_medio"]); acumulados.Add((string)registro["id_medio"], (string)registro["id_tot_med_pago"]); } } return(acumulados); } }
public void CancelarVenta(ETransaccion transaccion, ref Dictionary <string, string> IdsAcumulados, ETerminal terminal, EUsuario usuario, String tipo, out Respuesta respuesta) { respuesta = new Respuesta(true); string idVenta = Guid.NewGuid().ToString(); RVenta rventa = new RVenta(); decimal bruto = transaccion.BrutoNegativo > transaccion.BrutoPositivo ? transaccion.BrutoNegativo : transaccion.BrutoPositivo; try { using (TransactionScope scope = new TransactionScope()) { if (rventa.CrearVenta(idVenta, bruto, bruto, terminal.Codigo, tipo, 1, 00, (long)terminal.NumeroUltimaTransaccion + 1, terminal.Prefijo, usuario.IdUsuario, 00) == 1) { //3. Creamos totales de venta(registro_venta). if (IdsAcumulados == null) { IdsAcumulados = new Dictionary <string, string>(); IdsAcumulados.Add("idRegistroVenta", Guid.NewGuid().ToString()); //Creamos el registro venta rventa.CrearRegistroVenta(IdsAcumulados["idRegistroVenta"], terminal.Codigo, usuario.IdUsuario); } //Actualizo registro venta rventa.ActualizarRegistroVenta(IdsAcumulados["idRegistroVenta"], bruto, bruto, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, bruto); rventa.ActualizarTerminal(terminal.Codigo, (long)terminal.NumeroUltimaFactura, (long)terminal.NumeroUltimaTransaccion + 1); } else { throw new Exception("[CancelarVenta]: Transaccion no pudo ser guardada."); } scope.Complete(); } } catch (SqlException e) { if (e.Number == -2 || e.Number == 121) { respuesta.Valida = false; respuesta.Mensaje = "Se perdió la conexión con el servidor."; log.Error("[CancelarVenta]: No pudo ser guardada la transacion: " + e.Message); } else { respuesta.Valida = false; respuesta.Mensaje = "Hubo un problema al momento de guardar la transaccion. Por favor contacte al administrador del sistema."; log.Error("[CancelarVenta]: No pudo ser guardada la venta: " + e.Message); } Telemetria.Instancia.AgregaMetrica(new Excepcion(e)); } catch (Exception e) { respuesta.Valida = false; respuesta.Mensaje = "[CancelarVenta]: No pudo ser guardada la transaccion."; log.Error("[CancelarVenta]: No pudo ser guardada la venta. " + e.Message); Telemetria.Instancia.AgregaMetrica(new Excepcion(e)); } }
public Decimal DineroEnCaja(string codTerminal, string codUsuario, out Respuesta respuesta) { RVenta rventa = new RVenta(); respuesta = new Respuesta(true); var registro = rventa.DineroEnCaja(codTerminal, codUsuario); Decimal valor = (decimal)registro["total"]; return(valor); }
public List <string> BuscarFactura(string codUsuario, string codTerminal, string nroTransaccion, string nroFactura, string prefijo, out Respuesta respuesta) { List <string> contenidos = new List <string>(); RVenta rventa = new RVenta(); respuesta = new Respuesta(false); var registros = rventa.BuscarFactura(codUsuario, codTerminal, prefijo, nroFactura, nroTransaccion); foreach (DataRow registro in registros.Rows) { string contenido = (string)registro["contenido"]; contenidos.Add(contenido); } return(contenidos); }
public string ImprimirUltima(string codTerminal, string codUsuario, out Respuesta respuesta) { string contenido = ""; RVenta rventa = new RVenta(); respuesta = new Respuesta(false); var registro = rventa.ImprimirUltima(codTerminal, codUsuario); if (registro == null) { respuesta.Valida = false; respuesta.Mensaje = "Ultima factura no encontrada"; } else { contenido = (string)registro["contenido"]; respuesta.Valida = true; } return(contenido); }
// TODO : este requiere manejo transaccional!. /// <summary> /// /// </summary> /// <param name="ajuste"></param> /// <param name="terminal"></param> /// <param name="usuario"></param> /// <param name="localidad"></param> /// <param name="numero"></param> /// <param name="tipo"></param> /// <param name="contenido"></param> /// <param name="modeloImpresora"></param> /// <param name="respuesta"></param> public void GuardarAjuste(EAjuste ajuste, ETerminal terminal, EUsuario usuario, ELocalidad localidad, ETipoAjuste tipo, string contenido, string modeloImpresora, out Respuesta respuesta) { respuesta = new Respuesta(false); //1. Creamos el encabezado de la venta. string idAjuste = Guid.NewGuid().ToString(); RAjuste rajuste = new RAjuste(); RVenta rventa = new RVenta(); try { using (TransactionScope scope = new TransactionScope()) { var reg = rajuste.GetNumeroAjuste(); // int numero = reg.Field<int>("nro_ajuste"); int numero = (int)reg["nro_ajuste"]; if (rajuste.CrearAjuste(idAjuste, tipo.CalcularCostoVenta, "00", localidad.Codigo, ajuste.Estado, localidad.Codigo, numero + 1, tipo.Signo, tipo.Id, tipo.Codigo, 0, ajuste.TotalVenta, usuario.IdUsuario, ajuste.TotalImpuesto()) == 1) { //2. Creamos cada detalle de la venta. string idAjusteDetalle = Guid.NewGuid().ToString(); var tirilla = ajuste.CopiaTirilla; foreach (EItemVenta detalle in tirilla) { respuesta.Valida = true; rajuste.CrearAjusteDetalle(idAjusteDetalle, idAjuste, detalle.Articulo.Id, detalle.Cantidad, "00", detalle.Articulo.CodigoImpresion, 0, numero + 1, detalle.Articulo.PrecioVenta1, detalle.Impuesto, detalle.Articulo.Impuesto1); idAjusteDetalle = Guid.NewGuid().ToString(); } rventa.CrearCopiaImpresion("00", terminal.Localidad.Codigo, terminal.Codigo, ((int)Enums.TipoTransaccion.Ajuste).ToString(), usuario.IdUsuario, contenido, terminal.Localidad.Codigo, modeloImpresora, 0, numero + 1, terminal.Prefijo, terminal.Codigo, ((int)Enums.TipoTransaccion.Ajuste).ToString(), usuario.IdUsuario); } else { throw new Exception("[GuardarAjuste]: Transaccion no pudo ser guardada."); } scope.Complete(); } } catch (SqlException e) { if (e.Number == -2 || e.Number == 121) { respuesta.Valida = false; respuesta.Mensaje = "Se perdió la conexión con el servidor."; log.Error("[GuardarAjuste]: No pudo ser guardada la transaccion: " + e.Message); } else { respuesta.Valida = false; respuesta.Mensaje = "Hubo un problema al momento de guardar la transaccion. Por favor contacte al administrador del sistema."; log.Error("[GuardarAjuste]: No pudo ser guardada la transaccion: " + e.Message); } Telemetria.Instancia.AgregaMetrica(new Excepcion(e)); } catch (Exception ex) { respuesta.Valida = false; respuesta.Mensaje = "[GuardarAjuste]: No pudo ser guardado el ajuste."; log.Error("[GuardarAjuste]: No pudo ser guardado el ajuste: " + ex.Message); Telemetria.Instancia.AgregaMetrica(new Excepcion(ex)); } }
public void GuardarVentaEspecial(EFacturaVentaEspecialSinMedioPago venta, ref Dictionary <string, string> IdsAcumulados, ETerminal terminal, EUsuario usuario, String tipo, string contenido, string modeloImpresora, bool implementaImpuestoCompuesto, out Respuesta respuesta) { //venta.DescontarCambio(); respuesta = new Respuesta(false); //1. Creamos el encabezado de la venta. string idVenta = Guid.NewGuid().ToString(); RVenta rventa = new RVenta(); RVentaEspecial rventaespecial = new RVentaEspecial(); try { using (TransactionScope scope = new TransactionScope()) { if (rventa.CrearVenta(idVenta, venta.BrutoNegativo, venta.BrutoPositivo, terminal.Codigo, tipo, 1, (long)terminal.NumeroUltimaFactura + 1, (long)terminal.NumeroUltimaTransaccion + 1, terminal.Prefijo, usuario.IdUsuario, 0) == 1) { //2. Creamos cada detalle de la venta. int consecutivo = 0; var tirilla = venta.tirilla; foreach (EItemVenta detalle in tirilla) { var idVentasArticulo = Guid.NewGuid(); consecutivo += 1; rventa.CrearDetalleVenta(idVentasArticulo, detalle.Articulo.Id, detalle.Articulo.CodigoImpresion, terminal.Codigo, consecutivo, detalle.Impuesto, (long)terminal.NumeroUltimaTransaccion + 1, detalle.Articulo.Impuesto1, detalle.Peso, usuario.IdUsuario, detalle.Valor, idVenta, detalle.Cantidad, detalle.CodigoLeido); if (implementaImpuestoCompuesto) { rventa.ActualizarVentasArticulo(idVentasArticulo); foreach (KeyValuePair <EImpuestosArticulo, decimal> entry in detalle.Impuestos) { rventa.CrearVentasArticuloImpuesto(idVentasArticulo, entry.Key.Descripcion, entry.Key.Identificador, entry.Key.Porcentaje, entry.Key.Valor, entry.Key.TipoImpuesto, entry.Value, entry.Key.Id); } } } //3. Creamos totales de venta(registro_venta). if (IdsAcumulados == null) { IdsAcumulados = new Dictionary <string, string>(); IdsAcumulados.Add("idRegistroVenta", Guid.NewGuid().ToString()); //Creamos el registro venta rventa.CrearRegistroVenta(IdsAcumulados["idRegistroVenta"], terminal.Codigo, usuario.IdUsuario); } //Actualizo registro venta //rventa.ActualizarRegistroVenta(IdsAcumulados["idRegistroVenta"], venta.BrutoPositivo, venta.BrutoNegativo, venta.NumeroDeItemsVenta, venta.NumeroDeItemsNegativo, venta.TotalVenta); rventaespecial.ActualizarRegistroVentaEspecial(venta.BrutoNegativo, venta.BrutoPositivo, venta.NumeroDeItemsVenta, venta.NumeroDeItemsNegativo, 1, venta.BrutoNegativo, venta.TotalVenta, 0, 0, IdsAcumulados["idRegistroVenta"]); rventaespecial.AsociarTipoVentaConEncabezado(venta.TipoVentaEspecial.Id, idVenta); if (venta.Cliente != null) { rventa.CrearVentasCliente(venta.Cliente.Id, idVenta); } rventa.ActualizarTerminal(terminal.Codigo, (long)terminal.NumeroUltimaFactura + 1, (long)terminal.NumeroUltimaTransaccion + 1); var plainTextBytes = System.Text.Encoding.UTF8.GetBytes(contenido); //contenido = System.Convert.ToBase64String(plainTextBytes); rventa.CrearCopiaImpresion("00", terminal.Localidad.Codigo, terminal.Codigo, tipo, usuario.IdUsuario, contenido, terminal.Localidad.Codigo, modeloImpresora, (long)terminal.NumeroUltimaFactura + 1, (int)terminal.NumeroUltimaTransaccion + 1, terminal.Prefijo, terminal.Codigo, tipo, usuario.IdUsuario); respuesta.Valida = true; } else { throw new Exception("[GuardarVenta]: Transaccion no pudo ser guardada."); } scope.Complete(); } } catch (TransactionAbortedException ex) { respuesta.Valida = false; respuesta.Mensaje = "[GuardarVentaEspecial]: No pudo ser guardada la venta."; log.Error("[GuardarVentaEspecial]: No pudo ser guardada la venta. " + ex.Message); Telemetria.Instancia.AgregaMetrica(new Excepcion(ex)); } }
// TODO : este requiere manejo transaccional!. public void GuardarDevolucion(EDevolucion devolucion, ref Dictionary <string, string> IdsAcumulados, ETerminal terminal, EUsuario usuario, string tipo, string contenido, string modeloImpresora, bool implementaImpuestoCompuesto, out Respuesta respuesta) { // //devolucion.DescontarCambio(); //1. Creamos el encabezado de la venta. string idVenta = Guid.NewGuid().ToString(); RVenta rventa = new RVenta(); respuesta = new Respuesta(false); try { using (TransactionScope scope = new TransactionScope()) { if (rventa.CrearVenta(idVenta, devolucion.BrutoNegativo, devolucion.BrutoPositivo, terminal.Codigo, tipo, 1, (long)terminal.NumeroUltimaFactura + 1, (long)terminal.NumeroUltimaTransaccion + 1, terminal.Prefijo, usuario.IdUsuario, 0) == 1) { //2. Creamos cada detalle de la venta. int consecutivo = 0; var tirilla = devolucion.tirilla; foreach (EItemVenta detalle in tirilla) { var idVentasArticulo = Guid.NewGuid(); consecutivo += 1; rventa.CrearDetalleVenta(idVentasArticulo, detalle.Articulo.Id, detalle.Articulo.CodigoImpresion, terminal.Codigo, consecutivo, detalle.Impuesto, (long)terminal.NumeroUltimaTransaccion + 1, detalle.Articulo.Impuesto1, detalle.Peso, usuario.IdUsuario, detalle.Valor, idVenta, detalle.Cantidad, detalle.CodigoLeido); if (implementaImpuestoCompuesto) { rventa.ActualizarVentasArticulo(idVentasArticulo); foreach (KeyValuePair <EImpuestosArticulo, decimal> entry in detalle.Impuestos) { rventa.CrearVentasArticuloImpuesto(idVentasArticulo, entry.Key.Descripcion, entry.Key.Identificador, entry.Key.Porcentaje, entry.Key.Valor, entry.Key.TipoImpuesto, entry.Value, entry.Key.Id); } } } //3. Creamos totales de venta(registro_venta). if (IdsAcumulados == null) { IdsAcumulados = new Dictionary <string, string>(); IdsAcumulados.Add("idRegistroVenta", Guid.NewGuid().ToString()); //Creamos el registro venta rventa.CrearRegistroVenta(IdsAcumulados["idRegistroVenta"], terminal.Codigo, usuario.IdUsuario); } //Actualizo registro venta rventa.ActualizarRegistroVenta(IdsAcumulados["idRegistroVenta"], devolucion.BrutoPositivo, devolucion.BrutoNegativo, devolucion.NumeroDeItemsVenta, 0, devolucion.TotalVenta, 1, devolucion.TotalVenta, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0); //4. Creamos el detalle de los medios de pago. consecutivo = 1; rventa.CrearMedioPago("1", terminal.Codigo, consecutivo, (long)terminal.NumeroUltimaTransaccion + 1, devolucion.TotalVenta, idVenta, 0, "00", "00", 0); //5. Creamos totales de medios de pago por cada medio de pago. if (!IdsAcumulados.ContainsKey("1")) { IdsAcumulados.Add("1", Guid.NewGuid().ToString()); rventa.CrearTotalesMedioPago(IdsAcumulados["1"], IdsAcumulados["idRegistroVenta"], "1"); } //Actualizamos el medio de pago rventa.ActualizarTotalesMedioPago(IdsAcumulados["1"], devolucion.TotalVenta); if (devolucion.Cliente != null) { rventa.CrearVentasCliente(devolucion.Cliente.Id, idVenta); } rventa.ActualizarTerminal(terminal.Codigo, (long)terminal.NumeroUltimaFactura + 1, (long)terminal.NumeroUltimaTransaccion + 1); //var plainTextBytes = System.Text.Encoding.UTF8.GetBytes(contenido); //contenido = System.Convert.ToBase64String(plainTextBytes); rventa.CrearCopiaImpresion("00", terminal.Localidad.Codigo, terminal.Codigo, tipo, usuario.IdUsuario, contenido, terminal.Localidad.Codigo, modeloImpresora, (long)terminal.NumeroUltimaFactura + 1, (int)terminal.NumeroUltimaTransaccion + 1, terminal.Prefijo, terminal.Codigo, tipo, usuario.IdUsuario); respuesta.Valida = true; } else { throw new Exception("[GuardarDevolucion]: Transaccion no pudo ser guardada."); } scope.Complete(); } } catch (SqlException e) { if (e.Number == -2 || e.Number == 121) { respuesta.Valida = false; respuesta.Mensaje = "Se perdió la conexión con el servidor."; log.Error("[GuardarDevolucion]: No pudo ser guardada la transaccion: " + e.Message); } else { respuesta.Valida = false; respuesta.Mensaje = "Hubo un problema al momento de guardar la transaccion. Por favor contacte al administrador del sistema."; log.Error("[GuardarDevolucion]: No pudo ser guardada la transaccion: " + e.Message); } Telemetria.Instancia.AgregaMetrica(new Excepcion(e)); } catch (Exception ex) { respuesta.Documentar(false, "[GuardarDevolucion]: No pudo ser guardada la devolucion. "); log.Error("[GuardarDevolucion]: No pudo ser guardada la devolucion. " + ex.Message); Telemetria.Instancia.AgregaMetrica(new Excepcion(ex)); } }