Les erreurs sont indiquées en TODO. A corriger puis supprimer les commentaires
This commit is contained in:
@@ -22,7 +22,8 @@ namespace Webzine.WebApplication.Areas.Administration.Controllers
|
||||
|
||||
_logger.LogInformation("Initialisation du contrôleur CommentaireController.");
|
||||
|
||||
var factory = new DataFactory();
|
||||
var factory = new DataFactory(); // TODO injecter le factory via DI pour éviter de le recréer à chaque fois
|
||||
// faire une classe statique
|
||||
|
||||
var _artistes = factory.GenerateArtists(10);
|
||||
var _styles = factory.GenerateStyles(10);
|
||||
@@ -84,13 +85,14 @@ namespace Webzine.WebApplication.Areas.Administration.Controllers
|
||||
/// </summary>
|
||||
/// <param name="id">L'identifiant du commentaire à supprimer.</param>
|
||||
/// <returns>La vue de confirmation de suppression avec le ViewModel contenant les détails du commentaire à supprimer, ou une réponse NotFound si le commentaire n'existe pas.</returns>
|
||||
public ActionResult Delete(int id)
|
||||
public ActionResult Delete(int id) // TODO IActionResult
|
||||
{
|
||||
var commentaire = _commentaires
|
||||
.FirstOrDefault(c => c.IdCommentaire == id);
|
||||
|
||||
if (commentaire == null)
|
||||
return NotFound();
|
||||
return NotFound(); // TODO faire une page d'erreur personnalisée pour les 404, et pas juste un message d'erreur dans la console
|
||||
// mettre des accolades dans les if pour éviter les erreurs de maintenance, même pour une seule ligne de code
|
||||
|
||||
var vm = new CommentaireDeleteViewModel
|
||||
{
|
||||
@@ -111,12 +113,13 @@ namespace Webzine.WebApplication.Areas.Administration.Controllers
|
||||
/// <param name="model">Le ViewModel contenant les détails du commentaire à supprimer, utilisé pour afficher les informations en cas d'erreur.</param>
|
||||
/// <returns>Redirection vers la liste des commentaires en cas de succès, ou la vue de confirmation avec le message d'erreur en cas d'échec.</returns>
|
||||
[HttpPost]
|
||||
[ValidateAntiForgeryToken]
|
||||
public ActionResult Delete(int id, CommentaireDeleteViewModel model)
|
||||
[ValidateAntiForgeryToken] // TODO pas utilisée encore, à virer. tag helper form le fait déjà auto
|
||||
public ActionResult Delete(int id, CommentaireDeleteViewModel model) //TODO IActionResult
|
||||
{
|
||||
// TODO ça boucle à l'infini si on supprime pas le commentaire, parce que la vue Delete.cshtml affiche les détails du commentaire à supprimer, et que le commentaire n'est pas supprimé en base de données, donc il réaffiche la même page avec les mêmes données, et ça boucle à l'infini
|
||||
try
|
||||
{
|
||||
return RedirectToAction();
|
||||
return RedirectToAction(); // TODO rediriger vers la liste des commentaires, et pas juste RedirectToAction() qui va faire une erreur
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
|
||||
@@ -36,7 +36,7 @@ namespace Webzine.WebApplication.Areas.Administration.Controllers
|
||||
public ActionResult Index()
|
||||
{
|
||||
// Création de données "bouchon" (mock) pour tester l'affichage
|
||||
var listeStyles = new List<Style>
|
||||
var listeStyles = new List<Style> // TODO remplacer par les données générées dans le constructeur (la Factory)
|
||||
{
|
||||
new Style
|
||||
{
|
||||
|
||||
@@ -90,7 +90,7 @@ public class TitreController : Controller
|
||||
/// <returns>Redirige vers l'action Index après la soumission du formulaire. En cas d'erreur, retourne la vue Create pour permettre à l'utilisateur de corriger les données.</returns>
|
||||
[HttpPost]
|
||||
[ValidateAntiForgeryToken]
|
||||
public ActionResult Create(IFormCollection collection)
|
||||
public ActionResult Create(IFormCollection collection) // TODO IFormCollection c'est quoi
|
||||
{
|
||||
try
|
||||
{
|
||||
|
||||
Reference in New Issue
Block a user