Merge pull request '#173 : Résolution de bug de la recherche depuis l'area admin' (#174) from j3/bug/recherche_admin into dev

Reviewed-on: https://10.4.0.131/gitea/DI1-P4-E1/Webzine/pulls/174
Reviewed-by: c.bobin <clement.bobin@diiage.org>
Reviewed-by: j.vetu <josephine.vetu@diiage.org>
This commit is contained in:
j.vetu
2026-04-01 10:54:08 +02:00
10 changed files with 293 additions and 104 deletions

View File

@@ -50,14 +50,37 @@ public class ArtisteController : Controller
/// <returns>Redirection.</returns>
public IActionResult Create()
{
var model = new AdminArtisteForm
return this.View();
}
/// <summary>
/// Formulaire de création d'un artiste.
/// </summary>
/// <param name="model">Paramètre nécessaire pour la création d'un artiste.</param>
/// <returns>Redirection sur la page Index.</returns>
[HttpPost]
public IActionResult Create(ArtisteCreateViewModel model)
{
// vérifier si les données sont corrects.
if (!this.ModelState.IsValid)
{
Id = 0,
Nom = string.Empty,
Biographie = string.Empty,
// Passer model en paramètre afin que
// l'utilisateur conserve sa saissie.
return this.View(model);
}
// Créer un objet Artiste avecc les paramètres.
var artiste = new Artiste
{
Nom = model.Nom,
Biographie = model.Biographie,
};
return this.View(model);
// Persister les données.
this.artisteRepository.Add(artiste);
// Renvoyer sur la page Index.
return this.RedirectToAction("Index");
}
/// <summary>
@@ -69,14 +92,37 @@ public class ArtisteController : Controller
{
var artiste = this.artisteRepository.Find(id);
var model = new AdminArtisteForm
if (artiste == null)
{
Id = artiste.IdArtiste,
Nom = artiste.Nom,
Biographie = artiste.Biographie,
return this.RedirectToAction("Index");
}
return this.View(artiste);
}
/// <summary>
/// Traitement du formulaire de modification d'un artiste.
/// </summary>
/// <param name="model">Paramètre d'un artiste.</param>
/// <returns>Redirection sur Index.</returns>
[HttpPost]
public IActionResult Edit(ArtisteEditViewModel model)
{
var artiste = new Artiste
{
IdArtiste = model.Id,
Nom = model.Nom,
Biographie = model.Biographie,
};
return this.View(model);
if (!this.ModelState.IsValid)
{
return this.View(artiste);
}
this.artisteRepository.Update(artiste);
return this.RedirectToAction("Index");
}
/// <summary>

View File

@@ -1,109 +1,170 @@
namespace Webzine.WebApplication.Areas.Administration.Controllers
{
using Microsoft.AspNetCore.Mvc;
namespace Webzine.WebApplication.Areas.Administration.Controllers;
using Webzine.Repository.Contracts;
using Webzine.WebApplication.Areas.Administration.ViewModels.Style;
using Microsoft.AspNetCore.Mvc;
using Webzine.Entity;
using Webzine.Repository.Contracts;
using Webzine.WebApplication.Areas.Administration.ViewModels.Style;
/// <summary>
/// Controleur pour la gestion des styles dans l'administration du webzine.
/// </summary>
[Area("Administration")]
public class StyleController : Controller
{
private readonly ILogger<StyleController> logger;
private readonly IStyleRepository styleRepository;
/// <summary>
/// Contrôleur pour la gestion des styles dans l'administration du webzine.
/// Initializes a new instance of the <see cref="StyleController"/> class.
/// </summary>
[Area("Administration")]
public class StyleController : Controller
/// <param name="logger">Service de journalisation injecte.</param>
/// <param name="styleRepository">Repository des styles injecte.</param>
public StyleController(
ILogger<StyleController> logger,
IStyleRepository styleRepository)
{
private readonly ILogger<StyleController> logger;
private readonly IStyleRepository styleRepository;
this.logger = logger;
this.styleRepository = styleRepository;
/// <summary>
/// Initializes a new instance of the <see cref="StyleController"/> class.
/// Initialise une nouvelle instance de la classe <see cref="StyleController"/>.
/// </summary>
/// <param name="logger">Service de journalisation injecté.</param>
/// <param name="styles">Repository des styles injecté.</param>
public StyleController(
ILogger<StyleController> logger,
IStyleRepository styleRepository)
this.logger.LogInformation("Initialisation du controleur StyleController.");
}
/// <summary>
/// Affiche la liste des styles dans la vue Index.
/// </summary>
/// <returns>La vue Index avec la liste des styles.</returns>
public IActionResult Index()
{
IEnumerable<Style> listeStyles = this.styleRepository.FindAll().Take(10);
return this.View(listeStyles);
}
/// <summary>
/// Affiche la vue de creation d'un nouveau style.
/// </summary>
/// <returns>La vue Create pour ajouter un nouveau style.</returns>
public IActionResult Create()
{
var model = new StyleCreateViewModel
{
this.logger = logger;
Libelle = string.Empty,
};
this.logger.LogInformation("Initialisation du contrôleur StyleController.");
return this.View(model);
}
this.styleRepository = styleRepository;
/// <summary>
/// Cree un nouveau style.
/// </summary>
/// <param name="model">Nouveau style.</param>
/// <returns>IActionResult.</returns>
[HttpPost]
public IActionResult Create(StyleCreateViewModel model)
{
if (!this.ModelState.IsValid)
{
return this.View(model);
}
/// <summary>
/// Affiche la liste des styles dans la vue Index.
/// </summary>
/// <returns>La vue Index avec le ViewModel contenant la liste des styles.</returns>
public IActionResult Index()
var style = new Style
{
var listeStyles = this.styleRepository.FindAll().Take(10);
Libelle = model.Libelle,
};
return this.View(listeStyles);
}
this.styleRepository.Add(style);
/// <summary>
/// Affiche la vue de création d'un nouveau style.
/// </summary>
/// <returns>La vue Create pour ajouter un nouveau style.</returns>
public IActionResult Create()
return this.RedirectToAction("Index");
}
/// <summary>
/// Affiche la vue de confirmation de suppression d'un style.
/// </summary>
/// <param name="id">L'identifiant du style a supprimer.</param>
/// <returns>La vue de confirmation ou une redirection vers l'index si le style n'existe pas.</returns>
public IActionResult Delete(int id)
{
var style = this.styleRepository.Find(id);
if (style == null || style.IdStyle == 0)
{
return this.View();
}
/// <summary>
/// Affiche la vue de confirmation de suppression d'un style, en récupérant les détails du style à supprimer à partir de l'identifiant fourni.
/// </summary>
/// <param name="id">L'identifiant du style à supprimer.</param>
/// <returns>La vue de confirmation de suppression avec le ViewModel contenant les détails du style à supprimer, ou une redirection vers l'index si le style n'existe pas.</returns>
public IActionResult Delete(int id)
{
var style = this.styleRepository.Find(id);
var vm = new StyleDeleteViewModel
{
IdStyle = style.IdStyle,
Libelle = style.Libelle,
};
return this.View(vm);
}
/// <summary>
/// Méthode POST pour supprimer un style.
/// </summary>
/// <param name="model">Le style à supprimer.</param>
/// <returns>Redirige vers la page d'index d'admin style.</returns>
[HttpPost]
public IActionResult Delete(StyleEditViewModel model)
{
var style = this.styleRepository.Find(model.IdStyle);
if (style != null)
{
this.styleRepository.Delete(style);
}
return this.RedirectToAction("Index");
}
/// <summary>
/// Affiche la vue d'édition d'un style existant, en récupérant les détails du style à éditer à partir de l'identifiant fourni.
/// </summary>
/// <param name="id">L'identifiant du style à éditer.</param>
/// <returns>La vue d'édition avec le ViewModel contenant les détails du style à éditer, ou une redirection vers l'index si le style n'existe pas.</returns>
[HttpGet]
public IActionResult Edit(int id)
var model = new StyleDeleteViewModel
{
var style = this.styleRepository.Find(id);
IdStyle = style.IdStyle,
Libelle = style.Libelle,
};
var model = new StyleEditViewModel
{
IdStyle = style.IdStyle,
Libelle = style.Libelle,
};
return this.View(model);
}
/// <summary>
/// Methode POST pour supprimer un style.
/// </summary>
/// <param name="model">Le style a supprimer.</param>
/// <returns>Redirige vers la page d'index d'admin style.</returns>
[HttpPost]
public IActionResult Delete(StyleDeleteViewModel model)
{
var style = this.styleRepository.Find(model.IdStyle);
if (style != null)
{
this.styleRepository.Delete(style);
}
return this.RedirectToAction("Index");
}
/// <summary>
/// Affiche la vue d'edition d'un style existant.
/// </summary>
/// <param name="id">L'identifiant du style a editer.</param>
/// <returns>La vue d'edition ou une redirection vers l'index si le style n'existe pas.</returns>
[HttpGet]
public IActionResult Edit(int id)
{
var style = this.styleRepository.Find(id);
if (style == null || style.IdStyle == 0)
{
return this.RedirectToAction("Index");
}
var model = new StyleEditViewModel
{
IdStyle = style.IdStyle,
Libelle = style.Libelle,
};
return this.View(model);
}
/// <summary>
/// Met a jour un style existant.
/// </summary>
/// <param name="model">Donnees du style a modifier.</param>
/// <returns>Redirige vers la page d'index d'admin style.</returns>
[HttpPost]
public IActionResult Edit(StyleEditViewModel model)
{
if (!this.ModelState.IsValid)
{
return this.View(model);
}
var style = this.styleRepository.Find(model.IdStyle);
if (style == null)
{
return this.RedirectToAction("Index");
}
style.Libelle = model.Libelle;
this.styleRepository.Update(style);
return this.RedirectToAction("Index");
}
}

View File

@@ -0,0 +1,21 @@
namespace Webzine.WebApplication.Areas.Administration.ViewModels.Artiste
{
using System.ComponentModel.DataAnnotations;
/// <summary>
/// ViewModel qui sert à la création d'un artiste.
/// </summary>
public class ArtisteCreateViewModel
{
/// <summary>
/// Nom de l'artiste.
/// </summary>
[Required]
public string Nom { get; set; }
/// <summary>
/// Biographie de l'artiste.
/// </summary>
public string Biographie { get; set; }
}
}

View File

@@ -0,0 +1,27 @@
namespace Webzine.WebApplication.Areas.Administration.ViewModels.Artiste
{
using System.ComponentModel.DataAnnotations;
/// <summary>
/// Permet d'éditer un Artiste.
/// </summary>
public class ArtisteEditViewModel
{
/// <summary>
/// Id de l'artiste.
/// </summary>
[Required]
public int Id { get; set; }
/// <summary>
/// Nom de l'artiste.
/// </summary>
[Required]
public string Nom { get; set; }
/// <summary>
/// Biographie de l'artiste.
/// </summary>
public string Biographie { get; set; }
}
}

View File

@@ -4,6 +4,8 @@
namespace Webzine.WebApplication.Areas.Administration.ViewModels.Style
{
using System.ComponentModel.DataAnnotations;
/// <summary>
/// ViewModel pour la création d'un style en administration.
/// </summary>
@@ -12,6 +14,7 @@ namespace Webzine.WebApplication.Areas.Administration.ViewModels.Style
/// <summary>
/// Obtient ou définit le libellé du style.
/// </summary>
[Required]
public string Libelle { get; set; }
}
}

View File

@@ -4,19 +4,22 @@
namespace Webzine.WebApplication.Areas.Administration.ViewModels.Style
{
using System.ComponentModel.DataAnnotations;
/// <summary>
/// ViewModel pour la modification d'un style en administration.
/// </summary>
public class StyleEditViewModel
{
/// <summary>
/// Obtient ou définit le libellé du style.
/// Obtient ou definit l'identifiant du style.
/// </summary>
public int IdStyle { get; set; }
/// <summary>
/// Obtient ou définit le libellé du style.
/// Obtient ou definit le libelle du style.
/// </summary>
[Required]
public string Libelle { get; set; }
}
}

View File

@@ -1,11 +1,41 @@
@model Webzine.WebApplication.Areas.Administration.ViewModels.Artiste.AdminArtisteForm
@model Webzine.WebApplication.Areas.Administration.ViewModels.Artiste.ArtisteCreateViewModel
<h1>Créer un artiste</h1>
<hr />
<form asp-action="Create" method="post">
<div class="container">
<!-- ARTISTE -->
<div class="row mb-3">
<label class="col-md-3 col-form-label">Nom de l'artiste<span class="text-danger">*</span></label>
<div class="col-md-9">
<input asp-for="Nom" class="form-control" />
</div>
</div>
<partial name="_Form" />
<!-- BIOGRAPHIE -->
<div class="row mb-3">
<label class="col-md-3 col-form-label">Biographie</label>
<div class="col-md-9">
<textarea asp-for="Biographie" class="form-control" rows="5"></textarea>
</div>
</div>
<!-- BOUTONS -->
<div class="row mt-4">
<div class="col-md-9 offset-md-3">
<button type="submit" class="btn btn-primary me-2">
Sauvegarder
</button>
</div>
</div>
<br />
<br />
<a asp-action="Index"
class="btn text-primary">
Retour à l'administration des artistes
</a>
</div>
</form>

View File

@@ -1,4 +1,4 @@
@model Webzine.WebApplication.Areas.Administration.ViewModels.Artiste.AdminArtisteForm
@model Webzine.Entity.Artiste
<h1>Editer un artiste</h1>
@@ -6,7 +6,7 @@
<form asp-action="Edit" method="post">
<input type="hidden" asp-for="Id"/>
<input type="hidden" asp-for="IdArtiste"/>
<partial name="_Form" />

View File

@@ -1,4 +1,4 @@
@model Webzine.WebApplication.Areas.Administration.ViewModels.Artiste.AdminArtisteForm
@model Webzine.Entity.Artiste
<div class="container">
<!-- ARTISTE -->
@@ -17,8 +17,6 @@
</div>
</div>
<!-- BOUTONS -->
<div class="row mt-4">
<div class="col-md-9 offset-md-3">

View File

@@ -61,7 +61,7 @@
</ul>
<!-- Barre de recherche -->
<form class="d-flex" asp-controller="Recherche" asp-action="Index" method="get">
<form class="d-flex" asp-area="" asp-controller="Recherche" asp-action="Index" method="get">
<div class="input-group">
<div class="form-outline">
<input class="form-control me-2"