Files
PersonSport/Controllers/PersonController.cs
2026-03-05 15:43:26 +01:00

230 lines
9.3 KiB
C#

using Microsoft.AspNetCore.Mvc;
using System;
using System.Collections.Generic;
using System.Linq;
using PersonSport.Models;
using Microsoft.AspNetCore.Http;
using System.IO;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Authorization;
namespace PersonSport.Controllers {
[Authorize]
public class PersonController : Controller {
private const int FileNameLength = 8;
private readonly IWebHostEnvironment Environment;
public PersonController(IWebHostEnvironment _environment) {
Environment = _environment;
}
public IActionResult Index(string sortOrder) {
List<Person> personer = new();
using (var db = new IdrottContext()) {
personer = sortOrder switch {
"PersonId" => db.Personer.OrderBy(p => p.PersonId).ToList(),
"PersonNamn" => db.Personer.OrderBy(p => p.PersonNamn).ToList(),
"Epost" => db.Personer.OrderBy(p => p.Epost).ToList(),
"Alder" => db.Personer.OrderBy(p => p.Alder).ToList(),
"StartDatum" => db.Personer.OrderBy(p => p.StartDatum).ToList(),
_ => db.Personer.OrderBy(p => p.PersonId).ToList(),
};
}
return View(personer);
}
/* *********************************************************
* Function: Search()
* -----------------------------------------
* Sammanfattning: Söker i databasen efter en viss post genom
* att söka efter namn eller e-postadress.
* Skapar en lista av personer och sparar undan söksträngen.
* Populerar listan genom ett lambda-uttryck som motsvarade söksträngen.
* Denna lista av personer skickas slutligen till Vyn.
* ****************************************************** */
[HttpPost]
public IActionResult Search(IFormCollection fc) {
string search = fc["search"];
List<Person> personer = new();
using (var db = new IdrottContext()) {
personer = db.Personer.Where(p => p.PersonNamn.ToLower().Contains(search.ToLower()) || p.Epost.ToLower().Contains(search.ToLower())).ToList();
}
return View(personer);
}
[AllowAnonymous]
[HttpGet]
public IActionResult Create() {
return View();
}
[AllowAnonymous]
[HttpPost]
public IActionResult Create(IFormCollection fc) {
Person person = new();
try {
person.PersonNamn = fc["PersonNamn"];
person.Epost = fc["Epost"];
person.Visningsbild = fc["Visningsbild"];
person.Alder = int.Parse(fc["Alder"]);
if (person.Visningsbild != "") {
person.Visningsbild = Request.Form.Files[0].FileName;
IFormFileCollection files = Request.Form.Files;
long size = files.Sum(f => f.Length);
string BaseURL = this.Environment.WebRootPath + @"\images\userphoto\";
foreach (var formFile in files) {
string localFileName = DateTime.UtcNow.Ticks.ToString()[FileNameLength..] + ".jpg";
var filePath = BaseURL + localFileName;
person.Visningsbild = localFileName;
// Kontrollerar så att den valda filen är en bildfil
if (formFile.ContentType == "image/jpeg" || formFile.ContentType == "image/jpg" || formFile.ContentType == "image/png" || formFile.ContentType == "image/gif") {
if (formFile.Length > 0) {
using var stream = new FileStream(filePath, FileMode.Create); formFile.CopyTo(stream);
}
else
ViewBag.e = "Där där bilden är 0 bytes. Måste vara lite tråkig eller?";
}
else
ViewBag.e = "Det där var ingen bildfil";
}
}
else
person.Visningsbild = "noimage.jpg";
if (ModelState.IsValid) {
person.StartDatum = DateTime.Now;
using (var db = new IdrottContext()) {
db.Add(person);
db.SaveChanges();
}
TempData["MeddelandeSuccess"] = "Medlemmen är tillagd i systemet.";
return RedirectToAction("Index", "Start");
}
}
catch (Exception) {
throw;
}
TempData["MeddelandeFail"] = "Kunde inte lägga till personen.";
return NotFound();
}
public IActionResult Delete(int id) {
try {
var person = new Person() { PersonId = id };
using (var db = new IdrottContext()) {
db.Attach(person);
db.Remove(person);
db.SaveChanges();
}
TempData["MeddelandeSuccess"] = "Medlemmen är borttagen ur systemet.";
return RedirectToAction(nameof(Index));
}
catch (Exception) {
TempData["MeddelandeFail"] = "Kunde inte ta bort personen.";
throw;
}
}
[HttpGet]
public IActionResult Edit(int id) {
Person p = new();
try {
using (var db = new IdrottContext()) {
var person = db.Personer.Where(p => p.PersonId == id).FirstOrDefault();
p.PersonId = person.PersonId;
p.PersonNamn = person.PersonNamn;
p.Epost = person.Epost;
p.Alder = person.Alder;
p.Visningsbild = person.Visningsbild;
db.SaveChanges();
}
return View(p);
}
catch (Exception) {
throw;
}
}
[HttpPost]
public IActionResult Edit(IFormCollection fc) {
Person person = new();
bool bytaBild = false;
try {
person.PersonId = int.Parse(fc["PersonId"]);
person.PersonNamn = fc["PersonNamn"];
person.Epost = fc["Epost"];
person.Visningsbild = fc["Visningsbild"];
person.Alder = int.Parse(fc["Alder"]);
if (person.Visningsbild == "")
bytaBild = false;
else
bytaBild = true;
if (bytaBild) {
person.Visningsbild = Request.Form.Files[0].FileName;
IFormFileCollection files = Request.Form.Files;
long size = files.Sum(f => f.Length);
string BaseURL = this.Environment.WebRootPath + @"\images\userphoto\";
foreach (var formFile in files) {
string localFileName = DateTime.UtcNow.Ticks.ToString()[FileNameLength..] + ".jpg";
var filePath = BaseURL + localFileName;
person.Visningsbild = localFileName;
// Kontrollerar så att den valda filen är en bildfil
if (formFile.ContentType == "image/jpeg" || formFile.ContentType == "image/jpg" || formFile.ContentType == "image/png" || formFile.ContentType == "image/gif") {
if (formFile.Length > 0) {
using var stream = new FileStream(filePath, FileMode.Create);
formFile.CopyTo(stream);
}
else
ViewBag.e = "Där där bilden är 0 bytes. Måste vara lite tråkig eller?";
}
else
ViewBag.e = "Det där var ingen bildfil";
}
}
else
person.Visningsbild = "noimage.jpg";
if (ModelState.IsValid) {
using (var db = new IdrottContext()) {
var up = db.Personer.Where(p => p.PersonId == person.PersonId).FirstOrDefault();
up.PersonId = person.PersonId;
up.PersonNamn = person.PersonNamn;
up.Epost = person.Epost;
up.Alder = person.Alder;
if (bytaBild)
up.Visningsbild = person.Visningsbild;
db.SaveChanges();
}
TempData["MeddelandeSuccess"] = "Medlemmen är editerat med de nya uppgifterna.";
return RedirectToAction(nameof(Index));
}
}
catch (Exception) {
throw;
}
TempData["MeddelandeFail"] = "Kunde inte editera personen.";
return NotFound();
}
}
}