Les erreurs sont indiquées en TODO. A corriger puis supprimer les commentaires

This commit is contained in:
josephine.vetu
2026-03-23 14:48:23 +01:00
parent acf92c271c
commit b13d5c9209
13 changed files with 35 additions and 29 deletions

View File

@@ -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)
{

View File

@@ -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
{

View File

@@ -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
{

View File

@@ -4,7 +4,7 @@
/// <summary>
/// ViewModel pour afficher un groupe d'artiste.
/// </summary>
public class GroupeArtisteViewModel
public class GroupeArtisteViewModel // TODO groupe view model pas bien, pas pertinent
{
/// <summary>
/// Liste d'artistes.

View File

@@ -16,9 +16,9 @@
<div class="mb-4">
<h4>@Model.Contenu</h4>
<div class="text-muted">
<div class="text-muted"> // TODO y a des balises pour les citations, <blockquote></blockquote>
— <strong>@Model.Auteur</strong>
le @Model.DateCreation.ToString("dd/MM/yyyy HH:mm:ss")
le @Model.DateCreation.ToString("dd/MM/yyyy HH:mm:ss") // TODO à virer, c'est pas très lisible, trouver un format de date plus sympa, ou même afficher "il y a X minutes/heures/jours" comme sur les réseaux sociaux
sur <em>@Model.TitreLibelle</em>
</div>
</div>

View File

@@ -29,17 +29,17 @@
</a>
</div>
<!-- L'ARTIST LE PLUS CHRONICLED -->
<!-- L'ARTIST LE PLUS CHRONICLED --> // TODO faute de frappe, à virer
<div class="col-md-4">
<a asp-area=""
asp-controller="Artiste"
asp-route-nom="@Model.MostChronicledArtistName"
asp-route-nom="@Model.MostChronicledArtistName" // TODO enlever texte décorationnel, pas maintenable
class="text-decoration-none">
<div class="card shadow-sm p-4 bg-light h-100 dashboard-card">
<i class="fa fa-user fa-3x text-primary mb-3"></i>
<h3 class="text-primary">
<h3 class="text-primary"> // TODO c'est déjà par défaut en couleur primaire, pas besoin de le redéfinir
@Model.MostChronicledArtistName
</h3>

View File

@@ -14,7 +14,7 @@
</p>
<div class="mb-4">
@* On affiche le Libellé en gros *@
@* On affiche le Libellé en gros *@ // TODO c'est quoi ces commentaires Baptiste
<h4>@Model.Libelle</h4>
@* On affiche l'ID discrètement en dessous *@