#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:
@@ -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 =>
|
||||||
|
|||||||
@@ -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>
|
||||||
|
|||||||
@@ -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)
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -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");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
@@ -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>
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user