public async Task <IHttpActionResult> PutPRATO(int id, PRATO pRATO)
        {
            if (!ModelState.IsValid)
            {
                return(BadRequest(ModelState));
            }

            if (id != pRATO.CODIGO)
            {
                return(BadRequest());
            }

            db.Entry(pRATO).State = EntityState.Modified;

            try
            {
                await db.SaveChangesAsync();
            }
            catch (DbUpdateConcurrencyException)
            {
                if (!PRATOExists(id))
                {
                    return(NotFound());
                }
                else
                {
                    throw;
                }
            }

            return(StatusCode(HttpStatusCode.NoContent));
        }
        public async Task <ActionResult> DeleteConfirmed(int id)
        {
            PRATO pRATO = await db.PRATOS.FindAsync(id);

            db.PRATOS.Remove(pRATO);
            await db.SaveChangesAsync();

            return(RedirectToAction("Index"));
        }
        public async Task <IHttpActionResult> GetPRATO(int id)
        {
            PRATO pRATO = await db.PRATOS.FindAsync(id);

            if (pRATO == null)
            {
                return(NotFound());
            }

            return(Ok(pRATO));
        }
        public async Task <IHttpActionResult> PostPRATO(PRATO pRATO)
        {
            if (!ModelState.IsValid)
            {
                return(BadRequest(ModelState));
            }

            db.PRATOS.Add(pRATO);
            await db.SaveChangesAsync();

            return(CreatedAtRoute("DefaultApi", new { id = pRATO.CODIGO }, pRATO));
        }
        public async Task <ActionResult> Edit([Bind(Include = "CODIGO,CODIGO_RESTAURANTE,DESCRICAO,VALOR,IMAGENS")] PRATO pRATO)
        {
            if (ModelState.IsValid)
            {
                db.Entry(pRATO).State = EntityState.Modified;
                await db.SaveChangesAsync();

                return(RedirectToAction("Index"));
            }
            ViewBag.CODIGO_RESTAURANTE = new SelectList(db.RESTAURANTES, "CODIGO", "NOME", pRATO.CODIGO_RESTAURANTE);
            return(View(pRATO));
        }
        public async Task <IHttpActionResult> DeletePRATO(int id)
        {
            PRATO pRATO = await db.PRATOS.FindAsync(id);

            if (pRATO == null)
            {
                return(NotFound());
            }

            db.PRATOS.Remove(pRATO);
            await db.SaveChangesAsync();

            return(Ok(pRATO));
        }
        // GET: PRATOS/Details/5
        public async Task <ActionResult> Details(int?id)
        {
            if (id == null)
            {
                return(new HttpStatusCodeResult(HttpStatusCode.BadRequest));
            }
            PRATO pRATO = await db.PRATOS.FindAsync(id);

            if (pRATO == null)
            {
                return(HttpNotFound());
            }
            return(View(pRATO));
        }
        // GET: PRATOS/Edit/5
        public async Task <ActionResult> Edit(int?id)
        {
            if (id == null)
            {
                return(new HttpStatusCodeResult(HttpStatusCode.BadRequest));
            }
            PRATO pRATO = await db.PRATOS.FindAsync(id);

            if (pRATO == null)
            {
                return(HttpNotFound());
            }
            ViewBag.CODIGO_RESTAURANTE = new SelectList(db.RESTAURANTES, "CODIGO", "NOME", pRATO.CODIGO_RESTAURANTE);
            return(View(pRATO));
        }