#117 Mise en place de la suppression d'un artiste. La DbContext a été modifiée pour supprimer les titres d'un artiste à la suppression d'un artiste.

This commit is contained in:
josephine.vetu
2026-03-26 18:51:38 +01:00
parent c95f77b6e6
commit d15961eb5a
5 changed files with 47 additions and 19 deletions

View File

@@ -49,7 +49,7 @@ namespace Webzine.EntitiesContext
entity.HasMany(a => a.Titres) entity.HasMany(a => a.Titres)
.WithOne(t => t.Artiste) .WithOne(t => t.Artiste)
.HasForeignKey(t => t.IdArtiste) .HasForeignKey(t => t.IdArtiste)
.OnDelete(DeleteBehavior.Restrict); .OnDelete(DeleteBehavior.Cascade);
}); });
modelBuilder.Entity<Style>(entity => modelBuilder.Entity<Style>(entity =>

View File

@@ -24,6 +24,7 @@ namespace Webzine.Repository.Contracts
/// <param name="id">L'identifiant de l'artiste.</param> /// <param name="id">L'identifiant de l'artiste.</param>
/// <returns></returns> /// <returns></returns>
Artiste Find(int id); Artiste Find(int id);
/// <summary> /// <summary>
/// Récupère un artiste par son nom. Si aucun artiste n'est trouvé, retourne null. /// Récupère un artiste par son nom. Si aucun artiste n'est trouvé, retourne null.
/// </summary> /// </summary>

View File

@@ -63,6 +63,7 @@ namespace Webzine.Repository
this.context.Artistes.Remove(artiste); this.context.Artistes.Remove(artiste);
this.context.SaveChanges(); this.context.SaveChanges();
this.logger.LogInformation("L'artiste {IdArtiste} a bien été supprimé", artiste.IdArtiste);
} }
catch (DbUpdateException dbex) catch (DbUpdateException dbex)
{ {

View File

@@ -1,27 +1,31 @@
using Microsoft.AspNetCore.Mvc; using Microsoft.AspNetCore.Mvc;
using Webzine.Entity; using Webzine.Entity;
using Webzine.Entity.Fixtures;
using Webzine.Repository.Contracts; using Webzine.Repository.Contracts;
using Webzine.WebApplication.Areas.Administration.ViewModels.Artiste; using Webzine.WebApplication.Areas.Administration.ViewModels.Artiste;
namespace Webzine.WebApplication.Areas.Administration.Controllers; namespace Webzine.WebApplication.Areas.Administration.Controllers;
/// <summary>
/// Contrôleur pour la gestion des artistes dans l'administration du webzine.
/// </summary>
[Area("Administration")] [Area("Administration")]
public class ArtisteController : Controller public class ArtisteController : Controller
{ {
// Injection du logger via le constructeur // Injection du logger via le constructeur
private readonly ILogger<ArtisteController> logger; private readonly ILogger<ArtisteController> logger;
private readonly IArtisteRepository _artisteRepository; private readonly IArtisteRepository artisteRepository;
private readonly List<Artiste> _artistes = new List<Artiste>();
/// <summary>
public ArtisteController(ILogger<ArtisteController> logger, /// Initialise une nouvelle instance de la classe <see cref="ArtisteController"/>.
/// </summary>
/// <param name="logger">Logger.</param>
/// <param name="artisteRepository">Repository pour les artistes.</param>
public ArtisteController(
ILogger<ArtisteController> logger,
IArtisteRepository artisteRepository) IArtisteRepository artisteRepository)
{ {
this.logger = logger; this.logger = logger;
this.logger.LogDebug(1, "initialisation du ArtisteController d'administration"); this.artisteRepository = artisteRepository;
this._artisteRepository = artisteRepository;
this._artistes.AddRange(this._artisteRepository.FindAll());
} }
/// <summary> /// <summary>
@@ -31,10 +35,11 @@ public class ArtisteController : Controller
/// <returns>Redirection.</returns> /// <returns>Redirection.</returns>
public IActionResult Index() public IActionResult Index()
{ {
IEnumerable<Artiste> artistes = this.artisteRepository.FindAll();
var _artistes_ordre = this._artistes.OrderBy(t => t.Nom).ToList(); var artistes_ordre = artistes.OrderBy(t => t.Nom).ToList();
return View(_artistes_ordre); return View(artistes_ordre);
} }
/// <summary> /// <summary>
@@ -47,7 +52,7 @@ public class ArtisteController : Controller
{ {
Id = 0, Id = 0,
Nom = string.Empty, Nom = string.Empty,
Biographie = string.Empty Biographie = string.Empty,
}; };
return View(model); return View(model);
@@ -60,13 +65,13 @@ public class ArtisteController : Controller
/// <returns>Redirection.</returns> /// <returns>Redirection.</returns>
public IActionResult Edit(int id) public IActionResult Edit(int id)
{ {
var artiste = this._artistes.First(t => t.IdArtiste == id); var artiste = this.artisteRepository.Find(id);
var model = new AdminArtisteForm var model = new AdminArtisteForm
{ {
Id = artiste.IdArtiste, Id = artiste.IdArtiste,
Nom = artiste.Nom, Nom = artiste.Nom,
Biographie = artiste.Biographie Biographie = artiste.Biographie,
}; };
return View(model); return View(model);
@@ -79,13 +84,32 @@ public class ArtisteController : Controller
/// <returns>Redirection.></returns> /// <returns>Redirection.></returns>
public IActionResult Delete(int id) public IActionResult Delete(int id)
{ {
var artiste = this._artistes.First(t => t.IdArtiste == id); var artiste = this.artisteRepository.Find(id);
var model = new AdminArtisteForm var model = new AdminArtisteForm
{ {
Id = id, Id = id,
Nom = artiste.Nom, Nom = artiste.Nom,
Biographie = artiste.Biographie Biographie = artiste.Biographie,
}; };
return View(model); return View(model);
} }
/// <summary>
/// Méthode POST pour supprimer un artiste.
/// </summary>
/// <param name="model">L'artiste à supprimer.</param>
/// <returns>Redirige vers la page d'index d'admin artiste.</returns>
[HttpPost]
public IActionResult Delete(AdminArtisteForm model)
{
var artiste = this.artisteRepository.Find(model.Id);
if (artiste != null)
{
this.artisteRepository.Delete(artiste);
}
// 3. Redirect back to the list (or wherever you want them to go after)
return this.RedirectToAction("Index");
}
} }

View File

@@ -33,7 +33,9 @@
<i class="fa fa-edit"></i> <i class="fa fa-edit"></i>
</a> </a>
<a asp-action="Delete" asp-route-id="@artiste.IdArtiste"> <a asp-action="Delete"
asp-controller="Artiste"
asp-route-id="@artiste.IdArtiste">
<i class="fa fa-trash"></i> <i class="fa fa-trash"></i>
</a> </a>