예제 #1
0
 public EntidadNegocio.Entidades.Descuento Details(int id)
 {
     Dato.Modelo.Descuento _descuento = new Dato.Modelo.Descuento();
     if (id == 0)
     {
         _descuento = new Dato.Modelo.Descuento();
     }
     else
     {
         _descuento = db.DescuentoSet.First(c => c.ID == id);
     }
     EntidadNegocio.Entidades.Descuento descuentoDetail = new EntidadNegocio.Entidades.Descuento();
     descuentoDetail.ID                  = _descuento.ID;
     descuentoDetail.Codigo              = _descuento.Codigo;
     descuentoDetail.Descripcion         = _descuento.Descripcion;
     descuentoDetail.PorcentajeDescuento = _descuento.PorcentajeDescuento ?? 0;
     if (_descuento.Estatus == 1)
     {
         descuentoDetail.Status = EntidadNegocio.Enumerados.EnumEstatus.Registro.Activo;
     }
     else
     {
         descuentoDetail.Status = EntidadNegocio.Enumerados.EnumEstatus.Registro.Inactivo;
     }
     return(descuentoDetail);
 }
예제 #2
0
        public Int32 UltimoID()
        {
            Dato.Modelo.Descuento _entidadToIDAdd = db.DescuentoSet.ToList().LastOrDefault();
            Int32 _id = _entidadToIDAdd.ID;

            return(_id);
        }
예제 #3
0
        public Boolean Create(EntidadNegocio.Entidades.Precio _precio)
        {
            Dato.Modelo.Precio precioToAdd = new Dato.Modelo.Precio();
            Boolean            resul       = false;

            precioToAdd.ID             = _precio.ID;
            precioToAdd.Codigo         = _precio.Codigo;
            precioToAdd.Descripcion    = _precio.Descripcion;
            precioToAdd.PrecioUnitario = _precio.PrecioUnitario;
            if (_precio.Status == EntidadNegocio.Enumerados.EnumEstatus.Registro.Activo)
            {
                precioToAdd.Estatus = 1;
            }
            else
            {
                precioToAdd.Estatus = 0;
            }

            //valido claves primaria
            if (db.DescuentoSet.FirstOrDefault(b => b.ID == precioToAdd.ID) != null)
            {
                MessageBox.Show(EntidadNegocio.Entidades.Mensajes.Info_ErrorAlGuardarViolacionPK, EntidadNegocio.Entidades.Mensajes.Titulo_Error, MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
            else
            {
                if (db.Connection.State != System.Data.ConnectionState.Open)
                {
                    db.Connection.Open();
                }

                DbTransaction dbTransaction = db.Connection.BeginTransaction();

                try
                {
                    // Guardar y confirmar.
                    db.AddToPrecioSet(precioToAdd);
                    db.SaveChanges();
                    dbTransaction.Commit();
                    /// Si la transaccion es exitosa enviamos true
                    Dato.Modelo.Descuento _entidadToIDAdd = db.DescuentoSet.ToList().LastOrDefault();
                    Int32 _id = _entidadToIDAdd.ID;
                    _entidadToIDAdd.ID = _id;
                    resul = true;
                }
                catch (Exception ex)
                {
                    dbTransaction.Rollback();
                    HandleException excepcion = new HandleException();
                    String          msjLog    = "Error en " + ObtenerMetodoEnEjecucion(false).ToString() + ".\n" + excepcion.RegistrarExcepcion(ex, ObtenerMetodoEnEjecucion(false).ToString());
                    excepcion.EscribirLogExcepcion(msjLog); String clientMessage = excepcion.HandleExceptionEx(ex); excepcion = null;
                    resul = false;
                }
            }

            return(resul);
        }
예제 #4
0
        public Boolean Delete(EntidadNegocio.Entidades.Descuento _descuento)
        {
            Int32 id = _descuento.ID; Boolean resul = false;

            Dato.Modelo.Descuento descuentoToDelete = db.DescuentoSet.First(d => d.ID == id);

            descuentoToDelete.ID     = _descuento.ID;
            descuentoToDelete.Codigo = _descuento.Codigo;
            String _Descripcion = _descuento.Descripcion;

            descuentoToDelete.Descripcion         = _Descripcion;
            descuentoToDelete.PorcentajeDescuento = _descuento.PorcentajeDescuento;
            if (_descuento.Status == EntidadNegocio.Enumerados.EnumEstatus.Registro.Activo)
            {
                descuentoToDelete.Estatus = 1;
            }
            else
            {
                descuentoToDelete.Estatus = 0;
            }

            //valido si el descuento que se borra es de cabecera o de linea
            if (_Descripcion.Contains("Cabecera") || _Descripcion.Contains("Linea"))
            {
                MessageBox.Show(String.Format("Ningun descuento de Cabecera o de Linea puede ser eliminado."), EntidadNegocio.Entidades.Mensajes.Titulo_Error, MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
            else
            {
                if (db.Connection.State != System.Data.ConnectionState.Open)
                {
                    db.Connection.Open();
                }

                DbTransaction dbTransaction = db.Connection.BeginTransaction();

                try
                {
                    // Delete
                    db.DeleteObject(descuentoToDelete);
                    db.SaveChanges();
                    dbTransaction.Commit();
                    /// Si la transaccion es exitosa enviamos true
                    resul = true;
                }
                catch (Exception ex)
                {
                    HandleException excepcion = new HandleException();
                    String          msjLog    = "Error en " + ObtenerMetodoEnEjecucion(false).ToString() + ".\n" + excepcion.RegistrarExcepcion(ex, ObtenerMetodoEnEjecucion(false).ToString());
                    excepcion.EscribirLogExcepcion(msjLog); String clientMessage = excepcion.HandleExceptionEx(ex); excepcion = null;
                    resul = false;
                }
            }

            return(resul);
        }
예제 #5
0
        public Boolean Edit(EntidadNegocio.Entidades.Descuento _descuento)
        {
            Int32 id = _descuento.ID; Boolean resul = false;

            Dato.Modelo.Descuento descuentoToUpdate = db.DescuentoSet.First(d => d.ID == id);

            descuentoToUpdate.ID                  = _descuento.ID;
            descuentoToUpdate.Codigo              = _descuento.Codigo;
            descuentoToUpdate.Descripcion         = _descuento.Descripcion;
            descuentoToUpdate.PorcentajeDescuento = _descuento.PorcentajeDescuento;
            if (_descuento.Status == EntidadNegocio.Enumerados.EnumEstatus.Registro.Activo)
            {
                descuentoToUpdate.Estatus = 1;
            }
            else
            {
                descuentoToUpdate.Estatus = 0;
            }

            if (db.Connection.State != System.Data.ConnectionState.Open)
            {
                db.Connection.Open();
            }

            DbTransaction dbTransaction = db.Connection.BeginTransaction();

            try
            {
                // Guardar y confirmar.
                db.SaveChanges();
                dbTransaction.Commit();
                /// Si la transaccion es exitosa enviamos true
                resul = true;
            }
            catch (Exception ex)
            {
                dbTransaction.Rollback();
                HandleException excepcion = new HandleException();
                String          msjLog    = "Error en " + ObtenerMetodoEnEjecucion(false).ToString() + ".\n" + excepcion.RegistrarExcepcion(ex, ObtenerMetodoEnEjecucion(false).ToString());
                excepcion.EscribirLogExcepcion(msjLog); String clientMessage = excepcion.HandleExceptionEx(ex); excepcion = null;
                resul = false;
            }

            return(resul);
        }
예제 #6
0
        public EntidadNegocio.Entidades.PagoCabecera Details(int id)
        {
            Dato.Modelo.PagoCabecera _pagoCabeceraDetail = new Dato.Modelo.PagoCabecera();
            _pagoCabeceraDetail = new Dato.Modelo.PagoCabecera();
            EntidadNegocio.Entidades.PagoCabecera pagoCabeceraDetail = new EntidadNegocio.Entidades.PagoCabecera();
            Dato.Modelo.Cliente cliente = db.ClienteSet.First(c => c.ID == id); Int32 iIDCliente = cliente.ID;
            Dato.Modelo.Cantidad_Alquileres_Por_Pagar_VW clienteAlq = dbVW.Cantidad_Alquileres_Por_Pagar_VW_Set.First(c => c.IDCliente == iIDCliente);
            List <Dato.Modelo.Alquiler> listAlquiler = db.AlquilerSet.Where(a => a.IDCliente == iIDCliente && a.Estatus == 1).ToList();
            Double _dMontoEstimado = 0; _dMontoEstimado = (from e in listAlquiler select e.PrecioEstimado).Sum().Value;

            Dato.Modelo.Descuento descuento = db.DescuentoSet.First(d => d.Codigo == "DEC1");
            Double   _dPorcentajeDescuento  = 0; _dPorcentajeDescuento = descuento.PorcentajeDescuento ?? 0;
            Double   _dDescuento            = _dPorcentajeDescuento * _dMontoEstimado;
            Double   _dMontoTotal           = _dMontoEstimado - _dDescuento;
            Int32    _iIDCliente            = iIDCliente;
            Int32    _idCabecera            = UltimoID();
            DateTime _dFecha = DateTime.Now;

            pagoCabeceraDetail.Fecha = _dFecha;
            if (clienteAlq.NumAlquiler >= 3 && clienteAlq.NumAlquiler <= 5)
            {
                pagoCabeceraDetail.MontoExento = _dMontoEstimado;
                pagoCabeceraDetail.Descuento   = _dDescuento;
                pagoCabeceraDetail.MontoTotal  = _dMontoTotal;
            }
            else
            {
                pagoCabeceraDetail.MontoExento = _dMontoEstimado;
                pagoCabeceraDetail.Descuento   = 0;
                pagoCabeceraDetail.MontoTotal  = _dMontoEstimado;
            }
            pagoCabeceraDetail.IDCliente             = _iIDCliente;
            pagoCabeceraDetail.Cliente               = new EntidadNegocio.Entidades.Cliente();
            pagoCabeceraDetail.Cliente.ID            = _iIDCliente;
            pagoCabeceraDetail.Cliente.Nombre        = cliente.Nombre;
            pagoCabeceraDetail.Cliente.Telefono      = cliente.Telefono;
            pagoCabeceraDetail.Cliente.Correo        = cliente.Correo;
            pagoCabeceraDetail.Cliente.Direccion     = cliente.Direccion;
            pagoCabeceraDetail.Cliente.NumAlquileres = clienteAlq.NumAlquiler ?? 0;
            return(pagoCabeceraDetail);
        }