#199 : Correction de bug sur l'ajout des commentaires si le ModelState n'est pas valide.
This commit is contained in:
@@ -38,6 +38,7 @@ namespace Webzine.WebApplication.Controllers
|
||||
/// Affiche le detail d'un titre specifique.
|
||||
/// </summary>
|
||||
/// <param name="id">Identifiant du titre.</param>
|
||||
/// <param name="model">Model de donnée pour un commentaire.</param>
|
||||
/// <returns>Vue des details ou 404 si introuvable.</returns>
|
||||
public IActionResult Index(int id)
|
||||
{
|
||||
@@ -48,34 +49,11 @@ namespace Webzine.WebApplication.Controllers
|
||||
if (titre == null)
|
||||
{
|
||||
this.logger.LogWarning("Titre avec ID {Id} introuvable.", id);
|
||||
return this.RedirectToAction("Index");
|
||||
return this.RedirectToAction("Index", "Accueil");
|
||||
}
|
||||
|
||||
this.titreRepository.IncrementNbLectures(titre);
|
||||
|
||||
var vm = new TitreDetail
|
||||
{
|
||||
Details = new TitreContent
|
||||
{
|
||||
IdTitre = titre.IdTitre,
|
||||
Libelle = titre.Libelle,
|
||||
Chronique = titre.Chronique,
|
||||
DateSortie = titre.DateSortie,
|
||||
NbLikes = titre.NbLikes,
|
||||
UrlJaquette = titre.UrlJaquette,
|
||||
UrlEcoute = titre.UrlEcoute,
|
||||
UrlEmbedEcoute = BuildSpotifyEmbedUrl(titre.UrlEcoute),
|
||||
ArtisteNom = titre.Artiste.Nom,
|
||||
Styles = titre.Styles,
|
||||
Commentaires = titre.Commentaires,
|
||||
},
|
||||
CommentForm = new TitreComment
|
||||
{
|
||||
IdTitre = titre.IdTitre,
|
||||
},
|
||||
};
|
||||
|
||||
return this.View(vm);
|
||||
return this.View(this.BuildTitreDetailViewModel(titre));
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
@@ -121,8 +99,20 @@ namespace Webzine.WebApplication.Controllers
|
||||
/// <param name="model">Donnees du commentaire.</param>
|
||||
/// <returns>Redirection vers la page detail.</returns>
|
||||
[HttpPost]
|
||||
public IActionResult Comment(TitreComment model)
|
||||
public IActionResult Comment([Bind(Prefix = "CommentForm")] TitreComment model)
|
||||
{
|
||||
if (!this.ModelState.IsValid)
|
||||
{
|
||||
var titre = this.titreRepository.Find(model.IdTitre);
|
||||
if (titre == null)
|
||||
{
|
||||
this.logger.LogWarning("Titre avec ID {Id} introuvable pour ajout de commentaire.", model.IdTitre);
|
||||
return this.RedirectToAction("Index", "Accueil");
|
||||
}
|
||||
|
||||
return this.View("Index", this.BuildTitreDetailViewModel(titre, model));
|
||||
}
|
||||
|
||||
var titreToUpdate = this.titreRepository.Find(model.IdTitre);
|
||||
if (titreToUpdate != null)
|
||||
{
|
||||
@@ -141,6 +131,31 @@ namespace Webzine.WebApplication.Controllers
|
||||
return this.RedirectToAction("Index", new { id = model.IdTitre });
|
||||
}
|
||||
|
||||
private TitreDetail BuildTitreDetailViewModel(Titre titre, TitreComment? commentForm = null)
|
||||
{
|
||||
return new TitreDetail
|
||||
{
|
||||
Details = new TitreContent
|
||||
{
|
||||
IdTitre = titre.IdTitre,
|
||||
Libelle = titre.Libelle,
|
||||
Chronique = titre.Chronique,
|
||||
DateSortie = titre.DateSortie,
|
||||
NbLikes = titre.NbLikes,
|
||||
UrlJaquette = titre.UrlJaquette,
|
||||
UrlEcoute = titre.UrlEcoute,
|
||||
UrlEmbedEcoute = BuildSpotifyEmbedUrl(titre.UrlEcoute),
|
||||
ArtisteNom = titre.Artiste.Nom,
|
||||
Styles = titre.Styles,
|
||||
Commentaires = titre.Commentaires,
|
||||
},
|
||||
CommentForm = commentForm ?? new TitreComment
|
||||
{
|
||||
IdTitre = titre.IdTitre,
|
||||
},
|
||||
};
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Mappe une entite Titre vers un item de la liste de titres pour l'affichage dans la vue de style.
|
||||
/// </summary>
|
||||
|
||||
Reference in New Issue
Block a user