public ActionResult Delete(Int32 id, FormCollection form)
        {
            AlquileresMVC.Models.Precio precioToDelete = db.PrecioSet.First(p => p.ID == id);

            String _Descripcion = precioToDelete.Descripcion;

            //valido si el descuento que se borra es de cabecera o de linea
            if (_Descripcion.Contains("Hora") || _Descripcion.Contains("Dia") || _Descripcion.Contains("Semana"))
            {
                ModelState.AddModelError("ID", String.Format("Ningun precio por hora, dia o semana puede ser eliminado."));
            }
            else
            {
                try
                {
                    // Delete
                    db.DeleteObject(precioToDelete);
                    db.SaveChanges();
                    // Retorno a la vista del listar
                    return(RedirectToAction("List"));
                }
                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;
                    ModelState.AddModelError("ID", clientMessage);
                }
            }

            return(View(precioToDelete));
        }
        public ActionResult Create()
        {
            AlquileresMVC.Models.Precio precio        = new AlquileresMVC.Models.Precio();
            AlquileresMVC.Models.Precio precioToIDAdd = db.PrecioSet.ToList().LastOrDefault();
            Int32 _id = precioToIDAdd.ID + 1;

            precio.ID = _id;
            return(View(precio));
        }
        public ActionResult Edit(Int32 id, FormCollection form)
        {
            AlquileresMVC.Models.Precio precioToUpdate = db.PrecioSet.First(p => p.ID == id);

            string[] arreglo = new string[form.AllKeys.ToList().Count];
            Int32    i       = 0;

            foreach (var key in form.AllKeys)
            {
                var value = form[key];
                arreglo[i] = value;
                i++;
            }

            precioToUpdate.Codigo      = arreglo[0];
            precioToUpdate.Descripcion = arreglo[1];
            String precioUnitario = arreglo[2];
            Double precioUnit     = Double.Parse(precioUnitario);

            precioToUpdate.PrecioUnitario = precioUnit;
            String estatus  = arreglo[3];
            Int32  iEstatus = Int32.Parse(estatus);

            precioToUpdate.Estatus = iEstatus;

            TryUpdateModel(precioToUpdate, "Precio");
            TryUpdateModel(precioToUpdate, "Precio", form.ToValueProvider());

            // Si el modelo es valido, guardo en la BD
            if (ModelState.IsValid)
            {
                db.Connection.Open();
                DbTransaction dbTransaction = db.Connection.BeginTransaction();
                try
                {
                    // Guardar y confirmar el cliente.
                    db.SaveChanges();
                    dbTransaction.Commit();
                    /// Si la transaccion es exitosa nos redirigimos a la pagina de detalles como
                    /// cofirmaciĆ³n de que la operacion resulto exitosa
                    return(RedirectToAction("Details/" + precioToUpdate.ID));
                }
                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;
                    ModelState.AddModelError("ID", clientMessage);
                }
            }

            return(View(precioToUpdate));
        }
        public ActionResult Create(FormCollection collection)
        {
            AlquileresMVC.Models.Precio precioToAdd = new AlquileresMVC.Models.Precio();

            string[] arreglo = new string[collection.AllKeys.ToList().Count];
            Int32    i       = 0;

            foreach (var key in collection.AllKeys)
            {
                var value = collection[key];
                arreglo[i] = value;
                i++;
            }

            precioToAdd.Codigo      = arreglo[0];
            precioToAdd.Descripcion = arreglo[1];
            String precioUnitario = arreglo[2];
            Double precioUnit     = Double.Parse(precioUnitario);

            precioToAdd.PrecioUnitario = precioUnit;
            String estatus  = arreglo[3];
            Int32  iEstatus = Int32.Parse(estatus);

            precioToAdd.Estatus = iEstatus;

            TryUpdateModel(precioToAdd, "Precio");
            TryUpdateModel(precioToAdd, "Precio", collection.ToValueProvider());

            //valido claves primaria
            if (db.ClienteSet.FirstOrDefault(c => c.ID == precioToAdd.ID) != null)
            {
                ModelState.AddModelError("ID", String.Format("Violacion Clave primaria", "ID"));
            }
            else
            {
                // Si el modelo es valido, guardo en la BD
                if (ModelState.IsValid)
                {
                    db.Connection.Open();
                    DbTransaction dbTransaction = db.Connection.BeginTransaction();

                    try
                    {
                        // Guardar y confirmar el cliente.
                        db.AddToPrecioSet(precioToAdd);
                        db.SaveChanges();
                        dbTransaction.Commit();
                        /// Si la transaccion es exitosa nos redirigimos a la pagina de detalles como
                        /// cofirmaciĆ³n de que la operacion resulto exitosa
                        Precio _entidadToIDAdd = db.PrecioSet.ToList().LastOrDefault();
                        Int32  _id             = _entidadToIDAdd.ID;
                        _entidadToIDAdd.ID = _id;
                        return(RedirectToAction("Details/" + _entidadToIDAdd.ID));
                    }
                    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;
                        ModelState.AddModelError("ID", clientMessage);
                    }
                }
            }

            return(View(precioToAdd));
        }
 public ActionResult Details(int id)
 {
     AlquileresMVC.Models.Precio precioDetail = db.PrecioSet.First(p => p.ID == id);
     return(View(precioDetail));
 }
 public ActionResult Delete(int id)
 {
     AlquileresMVC.Models.Precio precioToDelete = db.PrecioSet.First(p => p.ID == id);
     ViewData.Model = precioToDelete;
     return(View());
 }
 public ActionResult Edit(Int32 id)
 {
     AlquileresMVC.Models.Precio precioToUpdate = db.PrecioSet.First(p => p.ID == id);
     ViewData.Model = precioToUpdate;
     return(View());
 }