Files
Multiplechoicetrainer/MultipleChoiceTrainer/Controllers/QuestionsController.cs
2020-06-10 13:23:29 +02:00

125 lines
4.5 KiB
C#

using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Mvc.Rendering;
using Microsoft.EntityFrameworkCore;
using MultipleChoiceTrainer.Data;
using MultipleChoiceTrainer.Models.DataModels;
namespace MultipleChoiceTrainer.Controllers
{
public class QuestionsController : Controller
{
private readonly ApplicationDbContext _context;
public QuestionsController(ApplicationDbContext context)
{
_context = context;
}
public IActionResult List(int sectionId)
{
return View(_context.Questions.Include(e => e.Choices).Where(e => e.SectionId == sectionId));
}
// GET: Questions/Create
public IActionResult Create(int sectionId)
{
ViewData["Section"] = _context.Sections.Include(e => e.Category).FirstOrDefault(s => s.Id == sectionId);
return View();
}
// POST: Questions/Create
// To protect from overposting attacks, enable the specific properties you want to bind to, for
// more details, see http://go.microsoft.com/fwlink/?LinkId=317598.
[HttpPost]
[ValidateAntiForgeryToken]
public async Task<IActionResult> Create(Question question)
{
if (ModelState.IsValid)
{
question.Choices = question.Choices.ToList().Where(e => !string.IsNullOrEmpty(e.Text) && !string.IsNullOrWhiteSpace(e.Text)).ToList();
_context.Add(question);
await _context.SaveChangesAsync();
var section = _context.Sections.FirstOrDefault(s => s.Id == question.SectionId);
return RedirectToAction(nameof(Index), "Home", new { categoryId = section.CategoryId });
}
ViewData["Section"] = _context.Sections.Include(e => e.Category).FirstOrDefault(s => s.Id == question.SectionId);
return View(question);
}
// GET: Questions/Edit/5
public async Task<IActionResult> Edit(int? id)
{
if (id == null)
{
return NotFound();
}
var question = _context.Questions.Include(e => e.Choices).FirstOrDefault(e => e.Id == id);
if (question == null)
{
return NotFound();
}
ViewData["Section"] = _context.Sections.Include(e => e.Category).FirstOrDefault(s => s.Id == question.SectionId);
return View(question);
}
// POST: Questions/Edit/5
// To protect from overposting attacks, enable the specific properties you want to bind to, for
// more details, see http://go.microsoft.com/fwlink/?LinkId=317598.
[HttpPost]
[ValidateAntiForgeryToken]
public async Task<IActionResult> Edit(int id, Question question)
{
if (id != question.Id)
{
return NotFound();
}
if (ModelState.IsValid)
{
var deletedChoices = question.Choices.Where(e => (string.IsNullOrEmpty(e.Text) || string.IsNullOrWhiteSpace(e.Text)) && e.Id != 0).Select(e => e.Id).ToList();
question.Choices = question.Choices.ToList().Where(e => !string.IsNullOrEmpty(e.Text) && !string.IsNullOrWhiteSpace(e.Text)).ToList();
try
{
_context.Update(question);
await _context.SaveChangesAsync();
if(deletedChoices.Any())
{
var q = _context.Questions.Include(e => e.Choices).First(e => e.Id == id);
q.Choices.RemoveAll(e => deletedChoices.Contains(e.Id));
await _context.SaveChangesAsync();
}
}
catch (DbUpdateConcurrencyException)
{
if (!QuestionExists(question.Id))
{
return NotFound();
}
else
{
throw;
}
}
return RedirectToAction(nameof(List), new { sectionId = question.SectionId });
}
ViewData["Section"] = _context.Sections.Include(e => e.Category).FirstOrDefault(s => s.Id == question.SectionId);
return View(question);
}
private bool QuestionExists(int id)
{
return _context.Questions.Any(e => e.Id == id);
}
}
}