Пример #1
0
        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);
            }
        }
Пример #2
0
        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));
            }
        }
Пример #3
0
        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);
        }
Пример #4
0
        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);
        }
Пример #5
0
        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);
        }
Пример #6
0
        // 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));
            }
        }
Пример #7
0
        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));
            }
        }
Пример #8
0
        // 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));
            }
        }