Exemplo n.º 1
0
        public void GuardarRecogida(ERecogida recogida, ref Dictionary <string, string> IdsAcumulados, string tipo, ETerminal terminal, EUsuario usuario, EMedioPago medioPago, string contenido, string modeloImpresora, out Respuesta respuesta)
        {
            //1. Creamos el encabezado de la venta.
            string    idVenta   = Guid.NewGuid().ToString();
            RRecogida rRecogida = new RRecogida();

            respuesta = new Respuesta(false);

            try
            {
                using (TransactionScope scope = new TransactionScope())
                {
                    if (rRecogida.CrearRecogida(idVenta, recogida.Valor, terminal.Codigo, tipo, 1, terminal.NumeroUltimaTransaccion + 1, terminal.Prefijo, usuario.IdUsuario) == 1)
                    {
                        rRecogida.CrearVentaRecogida(recogida.CodigoRecogida.Codigo, recogida.CodigoRecogida.Descripcion, idVenta);

                        //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
                            rRecogida.CrearRegistroVenta(IdsAcumulados["idRegistroVenta"], terminal.Codigo, usuario.IdUsuario);
                        }
                        //Actualizo registro venta
                        rRecogida.ActualizarRegistroVenta(IdsAcumulados["idRegistroVenta"], recogida.Valor);

                        //4. Creamos el detalle de los medios de pago.
                        //List<EPago> pagos = re // prestamo.Pagos;

                        rRecogida.CrearMedioPago(medioPago.Codigo, terminal.Codigo, (long)terminal.NumeroUltimaTransaccion + 1, recogida.Valor, idVenta);

                        //Actualizamos el terminal
                        rRecogida.ActualizarTerminal(terminal.Codigo, (long)terminal.NumeroUltimaFactura, (long)terminal.NumeroUltimaTransaccion + 1);
                        rVenta.ActualizarTerminal(terminal.Codigo, (long)terminal.NumeroUltimaFactura, (long)terminal.NumeroUltimaTransaccion + 1);

                        rVenta.CrearCopiaImpresion("00", terminal.Localidad.Codigo, terminal.Codigo, tipo, usuario.IdUsuario, contenido, terminal.Localidad.Codigo, modeloImpresora, (long)terminal.NumeroUltimaFactura, (int)terminal.NumeroUltimaTransaccion + 1, terminal.Prefijo, terminal.Codigo, tipo, usuario.IdUsuario);
                        respuesta.Valida  = true;
                        respuesta.Mensaje = idVenta;
                    }
                    else
                    {
                        throw new Exception("[GuardarRecogida]: 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("[GuardarRecogida]: 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("[Guardarrecogida]: No pudo ser guardada la venta: " + e.Message);
                }
                Telemetria.Instancia.AgregaMetrica(new Excepcion(e));
            }
            catch (Exception ex)
            {
                respuesta.Documentar(false, " No pudo ser guardada la recogida.");
                log.Error("[GuardarRecogida]: No pudo ser guardada la recogida. " + ex.Message);
                Telemetria.Instancia.AgregaMetrica(new Excepcion(ex));
            }
        }
Exemplo n.º 2
0
        public static void GenerarTransaccionApertura()
        {
            try
            {
                bool generaTransAperturaCajon = Entorno.Instancia.Parametros.ObtenerValorParametro <bool>("pdv.imprime_transaccion_abrir_cajon");

                // ¿debe generar transacción?
                if (!generaTransAperturaCajon)
                {
                    return;
                }

                string motivoIntervencion = string.Empty;

                if (Entorno.Instancia.Recogida != null)
                {
                    ERecogida recogidaActual = Entorno.Instancia.Recogida;
                    if (recogidaActual != null)
                    {
                        if (recogidaActual.listRecogidas.Count > 0 && recogidaActual.Valor > 0)
                        {
                            return;
                        }
                    }

                    motivoIntervencion = "Intervención Recogida";
                }
                else if (Entorno.Instancia.Prestamo != null)
                {
                    EPrestamo prestamoActual = Entorno.Instancia.Prestamo;
                    if (prestamoActual != null)
                    {
                        if (prestamoActual.ListPrestamos.Count > 0 && prestamoActual.Valor > 0)
                        {
                            return;
                        }
                    }

                    motivoIntervencion = "Intervención Prestamo";
                }

                //
                log.Info("[GenerarTransaccionApertura] Guardando transacción apertura cajón ...");
                PCajon pCajon = new PCajon();
                Dictionary <string, string> idsAcumulados = Entorno.Instancia.IdsAcumulados;

                // Generar tirilla de apertura de cajón
                Respuesta respuesta = new Respuesta();
                string    factura   = ProcesarPlantilla.AperturaCajon();

                var tiempoGuardarAperturaCajon = new MetricaTemporizador("AperturaCajon");
                pCajon.GuardarAperturaCajon(ref idsAcumulados, ((int)TipoTransaccion.AbrirCajon).ToString(), Entorno.Instancia.Terminal, Entorno.Instancia.Usuario, factura ?? "contenido", out respuesta);
                string idVentaApertCajon = respuesta.Mensaje;

                if (!respuesta.Valida)
                {
                    Telemetria.Instancia.AgregaMetrica(tiempoGuardarAperturaCajon.Para().AgregarPropiedad("Exitoso", false).AgregarPropiedad("Transaccion", (Entorno.Instancia.Terminal.NumeroUltimaTransaccion + 1)).AgregarPropiedad("Error", respuesta.Mensaje));
                }
                else
                {
                    Telemetria.Instancia.AgregaMetrica(tiempoGuardarAperturaCajon.Para().AgregarPropiedad("Exitoso", true).AgregarPropiedad("Transaccion", (Entorno.Instancia.Terminal.NumeroUltimaTransaccion + 1)).AgregarPropiedad("CajonAbierto", respuesta.Mensaje));

                    respuesta = new Respuesta(false);

                    ETerminal terminal = new PTerminal().BuscarTerminalPorCodigo(Config.Terminal, out respuesta);
                    if (respuesta.Valida == true)
                    {
                        // guardar transacción si hubo
                        if (Entorno.Instancia.Usuario.UsuarioSupervisor != null)
                        {
                            PIntervencion pInterv = new PIntervencion();
                            EIntervencion eInterv = new EIntervencion();

                            eInterv.id_venta        = idVentaApertCajon;
                            eInterv.claveSupervisor = Entorno.Instancia.Usuario.UsuarioSupervisor.ClaveSupervisor;
                            eInterv.motivo          = motivoIntervencion;
                            eInterv.nro_transac     = Convert.ToInt32(Entorno.Instancia.Terminal.NumeroUltimaTransaccion + 1);

                            pInterv.GuardarIntervencion(eInterv, Entorno.Instancia.Terminal, Entorno.Instancia.Usuario, out respuesta);
                        }


                        Entorno.Instancia.Terminal                  = terminal;
                        Entorno.Instancia.IdsAcumulados             = idsAcumulados;
                        Entorno.Instancia.Usuario.UsuarioSupervisor = null;

                        Entorno.Instancia.Recogida = null;
                        Entorno.Instancia.Prestamo = null;

                        // Imprimir
                        Entorno.Instancia.Impresora.Imprimir(factura, cortarPapel: true, abrirCajon: false);
                        log.Info("[GenerarTransaccionApertura.AbrirCajon] Imprimir Operación: " + factura);
                    }
                }
            }
            catch (Exception ex)
            {
                log.Info($"[GenerarTransaccionApertura] Error: {ex.Message}");
            }
        }