Merge remote-tracking branch 'origin/patch_dev' into dev
This commit is contained in:
@@ -20,16 +20,23 @@ namespace Webzine.WebApplication.Controllers
|
||||
private readonly ILogger<TitreController> logger;
|
||||
private readonly ITitreRepository titreRepository;
|
||||
|
||||
// Pour les commentaires.
|
||||
private readonly ICommentaireRepository commentaireRepository;
|
||||
|
||||
/// <summary>
|
||||
/// Initializes a new instance of the <see cref="TitreController"/> class.
|
||||
/// Initialise une nouvelle instance de la classe <see cref="TitreController"/>.
|
||||
/// </summary>
|
||||
/// <param name="logger">Service de journalisation injecte.</param>
|
||||
/// <param name="titreRepository">Repository des titres injecte.</param>
|
||||
public TitreController(ILogger<TitreController> logger, ITitreRepository titreRepository)
|
||||
public TitreController(
|
||||
ILogger<TitreController> logger,
|
||||
ITitreRepository titreRepository,
|
||||
ICommentaireRepository commentaireRepository)
|
||||
{
|
||||
this.logger = logger;
|
||||
this.titreRepository = titreRepository;
|
||||
this.commentaireRepository = commentaireRepository;
|
||||
|
||||
this.logger.LogInformation("Initialisation du controleur TitreController.");
|
||||
}
|
||||
@@ -101,19 +108,19 @@ namespace Webzine.WebApplication.Controllers
|
||||
[HttpPost]
|
||||
public IActionResult Comment([Bind(Prefix = "CommentForm")] TitreComment model)
|
||||
{
|
||||
var titreToUpdate = this.titreRepository.Find(model.IdTitre);
|
||||
|
||||
if (!this.ModelState.IsValid)
|
||||
{
|
||||
var titre = this.titreRepository.Find(model.IdTitre);
|
||||
if (titre == null)
|
||||
if (titreToUpdate == 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));
|
||||
return this.View("Index", this.BuildTitreDetailViewModel(titreToUpdate, model));
|
||||
}
|
||||
|
||||
var titreToUpdate = this.titreRepository.Find(model.IdTitre);
|
||||
if (titreToUpdate != null)
|
||||
{
|
||||
var commentaire = new Commentaire
|
||||
@@ -124,8 +131,7 @@ namespace Webzine.WebApplication.Controllers
|
||||
IdTitre = model.IdTitre,
|
||||
};
|
||||
|
||||
titreToUpdate.Commentaires.Add(commentaire);
|
||||
this.titreRepository.Update(titreToUpdate);
|
||||
this.commentaireRepository.Add(commentaire);
|
||||
}
|
||||
|
||||
return this.RedirectToAction("Index", new { id = model.IdTitre });
|
||||
|
||||
Reference in New Issue
Block a user