From c358e55aa22a2075c2aeec49eadfbc3e98913fd3 Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:02:06 +0100 Subject: [PATCH 01/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Pages/ModifQuiz.razor.cs'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../WF-WebAdmin/Pages/ModifQuiz.razor.cs | 324 +++++++++--------- 1 file changed, 162 insertions(+), 162 deletions(-) diff --git a/WF-WebAdmin/WF-WebAdmin/Pages/ModifQuiz.razor.cs b/WF-WebAdmin/WF-WebAdmin/Pages/ModifQuiz.razor.cs index 170cc53..1ac9887 100644 --- a/WF-WebAdmin/WF-WebAdmin/Pages/ModifQuiz.razor.cs +++ b/WF-WebAdmin/WF-WebAdmin/Pages/ModifQuiz.razor.cs @@ -1,162 +1,162 @@ -using Blazorise.DataGrid; -using Microsoft.AspNetCore.Components; -using Microsoft.Extensions.Localization; -using System.Security.Claims; -using WF_WebAdmin.Model; -using WF_WebAdmin.Service; - -namespace WF_WebAdmin.Pages -{ - public partial class ModifQuiz - { - private Quiz[] quiz; - - private int MaxValue = 5; - - private int totalItem; - - private bool showEditQuiz = false; - - private Quiz? selectedQuiz; - - private bool showPopupDelete = false; - - private int page = 1; - - [Inject] - public ILogger Logger { get; set; } - - [Inject] - public IStringLocalizer Localizer { get; set; } - - [Inject] - public IQuizService QuizService { get; set; } - - /// - /// Handles the data reading event for a data grid, fetching quiz data based on the specified page and page size. - /// This method makes an asynchronous call to retrieve a specific page of quizzes and updates the `quiz` list and pagination details. - /// If the cancellation token is requested, it exits early without making further calls or updates. - /// - /// The event arguments containing pagination details such as page size and page number. - private async Task OnReadData(DataGridReadDataEventArgs e) - { - // Check if the cancellation token has been requested - if (e.CancellationToken.IsCancellationRequested) - { - return; - } - - // Fetch the quiz data for the specified page and page size - var response = await QuizService.getSommeQuiz(e.PageSize, e.Page); - - // If cancellation hasn't been requested, process the data - if (!e.CancellationToken.IsCancellationRequested) - { - // Get the total number of quizzes for pagination purposes - totalItem = await QuizService.getNbQuiz(); - - // Update the quiz data for the current page - quiz = response.ToArray(); - - // Update the current page number - page = e.Page; - } - } - - /// - /// Handles the event when the "Edit" button is clicked for a quiz. - /// This method checks if a valid quiz is passed. If so, it sets the `selectedQuiz` to the clicked quiz and shows the quiz edit modal. - /// - /// The quiz object that was clicked for editing. - private void OnEditButtonClicked(Quiz quiz) - { - // If the quiz is null, return early - if (quiz == null) return; - - // Set the selected quiz to the one clicked by the user - selectedQuiz = quiz; - - // Show the modal or UI for editing the quiz - showEditQuiz = true; - } - - - /// - /// Closes the open popups and resets any related states. - /// This method hides the quiz edit popup, the delete confirmation popup, and resets the selected quiz to `null`. - /// - private void ClosePopup() - { - // Hide the edit quiz popup - showEditQuiz = false; - - // Hide the delete confirmation popup - showPopupDelete = false; - - // Reset the selected quiz to null - selectedQuiz = null; - } - - - - /// - /// Edits the selected quiz by updating it in the quiz service. - /// This method asynchronously sends the updated quiz data to the service for persistence. - /// After updating the quiz, it clears the selected quiz and closes any open popups. - /// - private async Task EditQuiz() - { - // Update the quiz in the service - LoggerSaveStub.Log(Logger, LogLevel.Information, $"Editing the question {selectedQuiz.Question}"); - await QuizService.updateQuiz(selectedQuiz); - - // Clear the selected quiz after successful update - selectedQuiz = null; - - // Close the popups after the edit operation - ClosePopup(); - } - - - /// - /// Handles the event when the delete action is triggered for a quiz. - /// This method sets the selected quiz to the one passed as a parameter and shows the delete confirmation popup. - /// - /// The quiz to be deleted. - private void OnDelete(Quiz q) - { - // Set the selected quiz to the one passed in - selectedQuiz = q; - - // Show the delete confirmation popup - showPopupDelete = true; - } - - - /// - /// Removes the selected quiz from the quiz service and updates the quiz list. - /// This method first checks if a quiz is selected, and if so, it deletes the quiz by calling the service. - /// After removal, it clears the `selectedQuiz`, updates the quiz list, and closes the delete confirmation popup. - /// - private async void RemoveQuote() - { - // Check if a quiz is selected for deletion - if (selectedQuiz != null) - { - // Remove the selected quiz from the service by its ID - LoggerSaveStub.Log(Logger, LogLevel.Information, $"Delete the question {selectedQuiz.Question}"); - await QuizService.removeQuiz(selectedQuiz.Id); - - // Clear the selected quiz after successful removal - selectedQuiz = null; - - // Update the quiz list by fetching the latest data - var response = await QuizService.getSommeQuiz(MaxValue, page); - quiz = response.ToArray(); - } - - // Close the delete confirmation popup - showPopupDelete = false; - } - } -} +using Blazorise.DataGrid; +using Microsoft.AspNetCore.Components; +using Microsoft.Extensions.Localization; +using System.Security.Claims; +using WF_WebAdmin.Model; +using WF_WebAdmin.Service; + +namespace WF_WebAdmin.Pages +{ + public partial class ModifQuiz + { + private Quiz[] quiz; + + private int MaxValue = 5; + + private int totalItem; + + private bool showEditQuiz = false; + + private Quiz? selectedQuiz; + + private bool showPopupDelete = false; + + private int page = 1; + + [Inject] + public ILogger Logger { get; set; } + + [Inject] + public IStringLocalizer Localizer { get; set; } + + [Inject] + public IQuizService QuizService { get; set; } + + /// + /// Handles the data reading event for a data grid, fetching quiz data based on the specified page and page size. + /// This method makes an asynchronous call to retrieve a specific page of quizzes and updates the `quiz` list and pagination details. + /// If the cancellation token is requested, it exits early without making further calls or updates. + /// + /// The event arguments containing pagination details such as page size and page number. + private async Task OnReadData(DataGridReadDataEventArgs e) + { + // Check if the cancellation token has been requested + if (e.CancellationToken.IsCancellationRequested) + { + return; + } + + // Fetch the quiz data for the specified page and page size + var response = await QuizService.getSommeQuiz(e.PageSize, e.Page); + + // If cancellation hasn't been requested, process the data + if (!e.CancellationToken.IsCancellationRequested) + { + // Get the total number of quizzes for pagination purposes + totalItem = await QuizService.getNbQuiz(); + + // Update the quiz data for the current page + quiz = response.ToArray(); + + // Update the current page number + page = e.Page; + } + } + + /// + /// Handles the event when the "Edit" button is clicked for a quiz. + /// This method checks if a valid quiz is passed. If so, it sets the `selectedQuiz` to the clicked quiz and shows the quiz edit modal. + /// + /// The quiz object that was clicked for editing. + private void OnEditButtonClicked(Quiz quiz) + { + // If the quiz is null, return early + if (quiz == null) return; + + // Set the selected quiz to the one clicked by the user + selectedQuiz = quiz; + + // Show the modal or UI for editing the quiz + showEditQuiz = true; + } + + + /// + /// Closes the open popups and resets any related states. + /// This method hides the quiz edit popup, the delete confirmation popup, and resets the selected quiz to `null`. + /// + private void ClosePopup() + { + // Hide the edit quiz popup + showEditQuiz = false; + + // Hide the delete confirmation popup + showPopupDelete = false; + + // Reset the selected quiz to null + selectedQuiz = null; + } + + + + /// + /// Edits the selected quiz by updating it in the quiz service. + /// This method asynchronously sends the updated quiz data to the service for persistence. + /// After updating the quiz, it clears the selected quiz and closes any open popups. + /// + private async Task EditQuiz() + { + // Update the quiz in the service + LoggerSaveStub.Log(Logger, LogLevel.Information, $"Editing the question {selectedQuiz.Question}"); + await QuizService.updateQuiz(selectedQuiz); + + // Clear the selected quiz after successful update + selectedQuiz = null; + + // Close the popups after the edit operation + ClosePopup(); + } + + + /// + /// Handles the event when the delete action is triggered for a quiz. + /// This method sets the selected quiz to the one passed as a parameter and shows the delete confirmation popup. + /// + /// The quiz to be deleted. + private void OnDelete(Quiz q) + { + // Set the selected quiz to the one passed in + selectedQuiz = q; + + // Show the delete confirmation popup + showPopupDelete = true; + } + + + /// + /// Removes the selected quiz from the quiz service and updates the quiz list. + /// This method first checks if a quiz is selected, and if so, it deletes the quiz by calling the service. + /// After removal, it clears the `selectedQuiz`, updates the quiz list, and closes the delete confirmation popup. + /// + private async Task RemoveQuote() + { + // Check if a quiz is selected for deletion + if (selectedQuiz != null) + { + // Remove the selected quiz from the service by its ID + LoggerSaveStub.Log(Logger, LogLevel.Information, $"Delete the question {selectedQuiz.Question}"); + await QuizService.removeQuiz(selectedQuiz.Id); + + // Clear the selected quiz after successful removal + selectedQuiz = null; + + // Update the quiz list by fetching the latest data + var response = await QuizService.getSommeQuiz(MaxValue, page); + quiz = response.ToArray(); + } + + // Close the delete confirmation popup + showPopupDelete = false; + } + } +} From 5ad531d6bb63cdf1bc4f5f7b300777a1b1d0c291 Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:03:44 +0100 Subject: [PATCH 02/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Pages/AddQuiz.razor.cs'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../WF-WebAdmin/Pages/AddQuiz.razor.cs | 280 +++++++++--------- 1 file changed, 140 insertions(+), 140 deletions(-) diff --git a/WF-WebAdmin/WF-WebAdmin/Pages/AddQuiz.razor.cs b/WF-WebAdmin/WF-WebAdmin/Pages/AddQuiz.razor.cs index 8a66ce0..c88d921 100644 --- a/WF-WebAdmin/WF-WebAdmin/Pages/AddQuiz.razor.cs +++ b/WF-WebAdmin/WF-WebAdmin/Pages/AddQuiz.razor.cs @@ -1,140 +1,140 @@ -using Microsoft.AspNetCore.Components; -using WF_WebAdmin.Service; -using WF_WebAdmin.Model; -using Microsoft.AspNetCore.Mvc; -using System.Text.RegularExpressions; -using Microsoft.Extensions.Localization; -using Microsoft.Extensions.Logging; -using System.Security.Claims; - - -namespace WF_WebAdmin.Pages -{ - public partial class AddQuiz - { - [Inject] - public ILogger Logger { get; set; } - - [Inject] - public IStringLocalizer Localizer { get; set; } - - [Inject] - private IQuizService quizService { get; set; } - - [Inject] - public NavigationManager NavigationManager { get; set; } - - private QuizModel QuizModel = new(); - - /// - /// Handles the valid submission of a quiz form. - /// This method is triggered when the form is successfully validated and the user submits the quiz data. - /// It retrieves the current quiz count, increments it, and then adds a new quiz entry to the quiz service. - /// Finally, it navigates to the "modifquiz" page. - /// - - private async void HandleValidSubmit() - { - // Declare a variable to hold the ID of the new quiz. - int id; - - // Get the current number of quizzes from the quiz service. - id = await quizService.getNbQuiz(); - - // Increment the quiz ID for the new quiz. - id++; - - // Create a new quiz and add it using the quiz service. - LoggerSaveStub.Log(Logger, LogLevel.Information, $"Creation of the {QuizModel.Question} question"); - await quizService.addQuiz(new Quiz( - id, // New quiz ID - validateInformation(QuizModel.Question), // Validated question - validateInformation(QuizModel.AnswerA), // Validated answer A - validateInformation(QuizModel.AnswerB), // Validated answer B - validateInformation(QuizModel.AnswerC), // Validated answer C - validateInformation(QuizModel.AnswerD), // Validated answer D - validateReponse(QuizModel.CAnswer) // Validated correct answer - )); - - // Navigate to the "modifquiz" page after adding the quiz. - NavigationManager.NavigateTo("modifquiz"); - } - - - - /// - /// Handles the change of the correct answer for the quiz. - /// This method is triggered when the user selects or changes the correct answer for the quiz question. - /// It updates the QuizModel's Correct Answer property with the selected answer. - /// - /// The selected answer that will be marked as the correct answer. - /// The value of the selected option, typically used for validation or additional logic. - private void OnCAwnserChange(string item, object checkedValue) - { - // Update the correct answer in the QuizModel with the selected answer. - QuizModel.CAnswer = item; - } - - - /// - /// Validates the provided string item. - /// This method is used to validate input data, but the validation logic is not yet implemented. - /// - /// The string input to be validated. - /// - /// Returns the input string as it is for now. The validation logic is yet to be implemented. - /// - private static string validateInformation(string item) - { - return item; // VALIDATION A FAIRE - } - - /// - /// Validates the provided answer item (A, B, C, or D) for the quiz. - /// This method ensures that the input corresponds to one of the allowed values for the correct answer. - /// If the input is invalid or null, it throws an exception and returns a default value ("A") in case of error. - /// - /// The answer item (A, B, C, or D) to be validated. - /// - /// Returns the input item if valid (A, B, C, or D). If the item is invalid or null, it returns a default value ("A"). - /// - private static string validateReponse(string item) - { - try - { - // Check if the item is not null or empty - if (!string.IsNullOrEmpty(item)) - { - // Validate that the item is one of the allowed values: A, B, C, or D - switch (item) - { - case "A": - break; - case "B": - break; - case "C": - break; - case "D": - break; - default: - // Throw exception if the item is not one of the allowed answers - throw new InvalidDataException("Invalid item (validateReponse) : item must be A,B,C or D " + item + " given."); - } - } - else - { - // Throw exception if the item is null or empty - throw new ArgumentNullException("Invalid item (validateReponse): null given."); - } - - // Return the validated item - return item; - } - catch (Exception ex) - { - // In case of an exception, return a default answer ("A") - return "A"; // Default Argument - } - } - } -} +using Microsoft.AspNetCore.Components; +using WF_WebAdmin.Service; +using WF_WebAdmin.Model; +using Microsoft.AspNetCore.Mvc; +using System.Text.RegularExpressions; +using Microsoft.Extensions.Localization; +using Microsoft.Extensions.Logging; +using System.Security.Claims; + + +namespace WF_WebAdmin.Pages +{ + public partial class AddQuiz + { + [Inject] + public ILogger Logger { get; set; } + + [Inject] + public IStringLocalizer Localizer { get; set; } + + [Inject] + private IQuizService quizService { get; set; } + + [Inject] + public NavigationManager NavigationManager { get; set; } + + private QuizModel QuizModel = new(); + + /// + /// Handles the valid submission of a quiz form. + /// This method is triggered when the form is successfully validated and the user submits the quiz data. + /// It retrieves the current quiz count, increments it, and then adds a new quiz entry to the quiz service. + /// Finally, it navigates to the "modifquiz" page. + /// + + private async Task HandleValidSubmit() + { + // Declare a variable to hold the ID of the new quiz. + int id; + + // Get the current number of quizzes from the quiz service. + id = await quizService.getNbQuiz(); + + // Increment the quiz ID for the new quiz. + id++; + + // Create a new quiz and add it using the quiz service. + LoggerSaveStub.Log(Logger, LogLevel.Information, $"Creation of the {QuizModel.Question} question"); + await quizService.addQuiz(new Quiz( + id, // New quiz ID + validateInformation(QuizModel.Question), // Validated question + validateInformation(QuizModel.AnswerA), // Validated answer A + validateInformation(QuizModel.AnswerB), // Validated answer B + validateInformation(QuizModel.AnswerC), // Validated answer C + validateInformation(QuizModel.AnswerD), // Validated answer D + validateReponse(QuizModel.CAnswer) // Validated correct answer + )); + + // Navigate to the "modifquiz" page after adding the quiz. + NavigationManager.NavigateTo("modifquiz"); + } + + + + /// + /// Handles the change of the correct answer for the quiz. + /// This method is triggered when the user selects or changes the correct answer for the quiz question. + /// It updates the QuizModel's Correct Answer property with the selected answer. + /// + /// The selected answer that will be marked as the correct answer. + /// The value of the selected option, typically used for validation or additional logic. + private void OnCAwnserChange(string item, object checkedValue) + { + // Update the correct answer in the QuizModel with the selected answer. + QuizModel.CAnswer = item; + } + + + /// + /// Validates the provided string item. + /// This method is used to validate input data, but the validation logic is not yet implemented. + /// + /// The string input to be validated. + /// + /// Returns the input string as it is for now. The validation logic is yet to be implemented. + /// + private static string validateInformation(string item) + { + return item; // VALIDATION A FAIRE + } + + /// + /// Validates the provided answer item (A, B, C, or D) for the quiz. + /// This method ensures that the input corresponds to one of the allowed values for the correct answer. + /// If the input is invalid or null, it throws an exception and returns a default value ("A") in case of error. + /// + /// The answer item (A, B, C, or D) to be validated. + /// + /// Returns the input item if valid (A, B, C, or D). If the item is invalid or null, it returns a default value ("A"). + /// + private static string validateReponse(string item) + { + try + { + // Check if the item is not null or empty + if (!string.IsNullOrEmpty(item)) + { + // Validate that the item is one of the allowed values: A, B, C, or D + switch (item) + { + case "A": + break; + case "B": + break; + case "C": + break; + case "D": + break; + default: + // Throw exception if the item is not one of the allowed answers + throw new InvalidDataException("Invalid item (validateReponse) : item must be A,B,C or D " + item + " given."); + } + } + else + { + // Throw exception if the item is null or empty + throw new ArgumentNullException("Invalid item (validateReponse): null given."); + } + + // Return the validated item + return item; + } + catch (Exception ex) + { + // In case of an exception, return a default answer ("A") + return "A"; // Default Argument + } + } + } +} From 611de183624cbb11f1758043f1300b364e39560a Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:04:14 +0100 Subject: [PATCH 03/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Pages/Edit.razor.cs'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- WF-WebAdmin/WF-WebAdmin/Pages/Edit.razor.cs | 200 ++++++++++---------- 1 file changed, 100 insertions(+), 100 deletions(-) diff --git a/WF-WebAdmin/WF-WebAdmin/Pages/Edit.razor.cs b/WF-WebAdmin/WF-WebAdmin/Pages/Edit.razor.cs index 3f0ab80..dad1e46 100644 --- a/WF-WebAdmin/WF-WebAdmin/Pages/Edit.razor.cs +++ b/WF-WebAdmin/WF-WebAdmin/Pages/Edit.razor.cs @@ -1,100 +1,100 @@ -using Microsoft.AspNetCore.Components; -using System.Security.Claims; -using WF_WebAdmin.Model; -using WF_WebAdmin.Service; - -namespace WF_WebAdmin.Pages -{ - public partial class Edit - { - [Parameter] - public int Id { get; set; } - - [Inject] - public ILogger Logger { get; set; } - - [Inject] - private IQuoteService quoteService { get; set; } - - [Inject] - public NavigationManager NavigationManager { get; set; } - - private Quote q{ get; set; } - - private QuoteModel quoteModel = new(); - - private List charac = new List(); - - private List src = new List(); - - - /// - /// Asynchronously initializes the component by loading data related to a quote. - /// This method fetches a specific quote based on the provided ID and populates the `quoteModel` - /// with the quote's content, language, character, source, and other associated data. - /// It also loads additional data such as character and source information for the quote. - /// - protected override async Task OnInitializedAsync() - { - // Fetch the quote data based on the provided ID. - q = await quoteService.getOnequote(Id); - - // Populate the quoteModel with the data from the retrieved quote. - quoteModel.Content = q.Content; - quoteModel.Langue = q.Langue; - quoteModel.Charac = q.Charac; - quoteModel.TitleSrc = q.TitleSrc; - quoteModel.Id = q.Id; - quoteModel.Like = q.Like; - quoteModel.ImgPath = q.ImgPath; - quoteModel.DateSrc = q.DateSrc; - quoteModel.UserProposition = q.UserProposition; - quoteModel.IsValid = q.IsValid; - - // Fetch additional data related to the quote, such as character and source. - charac = await quoteService.getChar(); - src = await quoteService.getSrc(); - } - - /// - /// Handles the submission of a valid form for updating a quote. - /// This method takes the data from `quoteModel`, updates the selected quote (`q`) with the new values, - /// and then calls the `quoteService.updateQuote` method to persist the changes. - /// After updating, it navigates to the "modifquote" page. - /// - protected async void HandleValidSubmit() - { - // Update the properties of the selected quote (`q`) with the data from `quoteModel`. - LoggerSaveStub.Log(Logger, LogLevel.Information, $"Editing the quote {q.Content}"); - q.Content = quoteModel.Content; - q.Langue = quoteModel.Langue; - q.TitleSrc = quoteModel.TitleSrc; - q.Charac = quoteModel.Charac; - - // Call the quote service to update the quote in the data source. - await quoteService.updateQuote(q); - - // Navigate to the "modifquote" page after updating the quote. - NavigationManager.NavigateTo("modifquote"); - } - - - - /// - /// Handles the language change event for the quote. - /// This method updates the `Langue` property of the `quoteModel` based on the selected language (`item`). - /// It only accepts "fr" (French) or "en" (English) as valid language options. - /// - /// The selected language ("fr" or "en") passed to the method. - /// The checked value (unused in this method but may be used for other purposes). - private void OnlangChange(string item, object checkedValue) - { - // Check if the selected language is either "fr" or "en" - if (item == "fr" || item == "en") - { - // Update the Langue property of the quoteModel with the selected language - quoteModel.Langue = item; - } - } - } -} +using Microsoft.AspNetCore.Components; +using System.Security.Claims; +using WF_WebAdmin.Model; +using WF_WebAdmin.Service; + +namespace WF_WebAdmin.Pages +{ + public partial class Edit + { + [Parameter] + public int Id { get; set; } + + [Inject] + public ILogger Logger { get; set; } + + [Inject] + private IQuoteService quoteService { get; set; } + + [Inject] + public NavigationManager NavigationManager { get; set; } + + private Quote q{ get; set; } + + private QuoteModel quoteModel = new(); + + private List charac = new List(); + + private List src = new List(); + + + /// + /// Asynchronously initializes the component by loading data related to a quote. + /// This method fetches a specific quote based on the provided ID and populates the `quoteModel` + /// with the quote's content, language, character, source, and other associated data. + /// It also loads additional data such as character and source information for the quote. + /// + protected override async Task OnInitializedAsync() + { + // Fetch the quote data based on the provided ID. + q = await quoteService.getOnequote(Id); + + // Populate the quoteModel with the data from the retrieved quote. + quoteModel.Content = q.Content; + quoteModel.Langue = q.Langue; + quoteModel.Charac = q.Charac; + quoteModel.TitleSrc = q.TitleSrc; + quoteModel.Id = q.Id; + quoteModel.Like = q.Like; + quoteModel.ImgPath = q.ImgPath; + quoteModel.DateSrc = q.DateSrc; + quoteModel.UserProposition = q.UserProposition; + quoteModel.IsValid = q.IsValid; + + // Fetch additional data related to the quote, such as character and source. + charac = await quoteService.getChar(); + src = await quoteService.getSrc(); + } + + /// + /// Handles the submission of a valid form for updating a quote. + /// This method takes the data from `quoteModel`, updates the selected quote (`q`) with the new values, + /// and then calls the `quoteService.updateQuote` method to persist the changes. + /// After updating, it navigates to the "modifquote" page. + /// + protected async Task HandleValidSubmit() + { + // Update the properties of the selected quote (`q`) with the data from `quoteModel`. + LoggerSaveStub.Log(Logger, LogLevel.Information, $"Editing the quote {q.Content}"); + q.Content = quoteModel.Content; + q.Langue = quoteModel.Langue; + q.TitleSrc = quoteModel.TitleSrc; + q.Charac = quoteModel.Charac; + + // Call the quote service to update the quote in the data source. + await quoteService.updateQuote(q); + + // Navigate to the "modifquote" page after updating the quote. + NavigationManager.NavigateTo("modifquote"); + } + + + + /// + /// Handles the language change event for the quote. + /// This method updates the `Langue` property of the `quoteModel` based on the selected language (`item`). + /// It only accepts "fr" (French) or "en" (English) as valid language options. + /// + /// The selected language ("fr" or "en") passed to the method. + /// The checked value (unused in this method but may be used for other purposes). + private void OnlangChange(string item, object checkedValue) + { + // Check if the selected language is either "fr" or "en" + if (item == "fr" || item == "en") + { + // Update the Langue property of the quoteModel with the selected language + quoteModel.Langue = item; + } + } + } +} From d2188b3de8a698883d101bb77b53041c1ae013f8 Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:05:19 +0100 Subject: [PATCH 04/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Pages/ModifQuote.razor.cs'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../WF-WebAdmin/Pages/ModifQuote.razor.cs | 270 +++++++++--------- 1 file changed, 135 insertions(+), 135 deletions(-) diff --git a/WF-WebAdmin/WF-WebAdmin/Pages/ModifQuote.razor.cs b/WF-WebAdmin/WF-WebAdmin/Pages/ModifQuote.razor.cs index f7b188f..bafd81b 100644 --- a/WF-WebAdmin/WF-WebAdmin/Pages/ModifQuote.razor.cs +++ b/WF-WebAdmin/WF-WebAdmin/Pages/ModifQuote.razor.cs @@ -1,135 +1,135 @@ -using Blazorise.DataGrid; -using Microsoft.AspNetCore.Components; -using Microsoft.Extensions.Localization; -using Microsoft.Extensions.Logging; -using System.Security.Claims; -using WF_WebAdmin.Model; -using WF_WebAdmin.Service; - -namespace WF_WebAdmin.Pages -{ - public partial class ModifQuote - { - private Quote[] quotes; - - private int MaxValue = 5; - - private int totalItem; - - /*private bool showEditQuote = false;*/ - - private Quote? selectedQuote; - - private bool showPopupDelete = false; - - private int page = 1; - - [Inject] - public ILogger Logger { get; set; } - - [Inject] - public IStringLocalizer Localizer { get; set; } - - [Inject] - public IQuoteService QuoteService { get; set; } - - - /// - /// Handles the data reading event for a data grid, fetching quote data based on the specified page and page size. - /// This method makes an asynchronous call to retrieve a specific page of quotes and updates the `quotes` list and pagination details. - /// If the cancellation token is requested, it exits early without making further calls or updates. - /// - /// The event arguments containing pagination details such as page size and page number. - private async Task OnReadData(DataGridReadDataEventArgs e) - { - // Check if the cancellation token has been requested - if (e.CancellationToken.IsCancellationRequested) - { - return; - } - - // Fetch the quote data for the specified page and page size - var response = await QuoteService.getSomeQuote(e.PageSize, e.Page); - - // If cancellation hasn't been requested, process the data - if (!e.CancellationToken.IsCancellationRequested) - { - // Get the total number of quotes for pagination purposes - totalItem = await QuoteService.getNbQuote(); - - // Update the quotes data for the current page - quotes = response.ToArray(); - - // Update the current page number - page = e.Page; - } - } - - /*private void OnEditButtonClicked(Quote quote) - { - if (selectedQuote == null) return; - selectedQuote = quote; - showEditQuote = true; - }*/ - - /// - /// Closes the open popups and resets any related states. - /// This method hides the delete confirmation popup and clears the selected quote. - /// - private void ClosePopup() - { - // Hide the delete confirmation popup - showPopupDelete = false; - - // Reset the selected quote to null - selectedQuote = null; - } - - /*private async Task EditQuote() - { - await QuoteService.updateQuote(selectedQuote); - selectedQuote = null; - ClosePopup(); - }*/ - - /// - /// Handles the event when the delete action is triggered for a quote. - /// This method sets the selected quote to the one passed as a parameter and displays the delete confirmation popup. - /// - /// The quote that is being deleted. - private void OnDelete(Quote q) - { - // Set the selected quote to the one passed in - selectedQuote = q; - - // Display the delete confirmation popup - showPopupDelete = true; - } - - /// - /// Removes the selected quote by calling the remove service and updates the quote list. - /// This method checks if a quote is selected. If so, it removes the quote using the `QuoteService`, clears the selected quote, - /// and fetches the updated list of quotes. It also closes the delete confirmation popup after the operation. - /// - private async void RemoveQuote() - { - // Check if a quote is selected for removal - if (selectedQuote != null) - { - // Remove the selected quote using the QuoteService - LoggerSaveStub.Log(Logger, LogLevel.Information, $"The quote {selectedQuote.Content} has been deleted"); - await QuoteService.removeQuote(selectedQuote); - - // Clear the selected quote after removal - selectedQuote = null; - - // Update the quotes list by fetching the latest quotes data - var response = await QuoteService.getSomeQuote(MaxValue, page); - quotes = response.ToArray(); - } - - // Close the delete confirmation popup - showPopupDelete = false; - } - } -} +using Blazorise.DataGrid; +using Microsoft.AspNetCore.Components; +using Microsoft.Extensions.Localization; +using Microsoft.Extensions.Logging; +using System.Security.Claims; +using WF_WebAdmin.Model; +using WF_WebAdmin.Service; + +namespace WF_WebAdmin.Pages +{ + public partial class ModifQuote + { + private Quote[] quotes; + + private int MaxValue = 5; + + private int totalItem; + + /*private bool showEditQuote = false;*/ + + private Quote? selectedQuote; + + private bool showPopupDelete = false; + + private int page = 1; + + [Inject] + public ILogger Logger { get; set; } + + [Inject] + public IStringLocalizer Localizer { get; set; } + + [Inject] + public IQuoteService QuoteService { get; set; } + + + /// + /// Handles the data reading event for a data grid, fetching quote data based on the specified page and page size. + /// This method makes an asynchronous call to retrieve a specific page of quotes and updates the `quotes` list and pagination details. + /// If the cancellation token is requested, it exits early without making further calls or updates. + /// + /// The event arguments containing pagination details such as page size and page number. + private async Task OnReadData(DataGridReadDataEventArgs e) + { + // Check if the cancellation token has been requested + if (e.CancellationToken.IsCancellationRequested) + { + return; + } + + // Fetch the quote data for the specified page and page size + var response = await QuoteService.getSomeQuote(e.PageSize, e.Page); + + // If cancellation hasn't been requested, process the data + if (!e.CancellationToken.IsCancellationRequested) + { + // Get the total number of quotes for pagination purposes + totalItem = await QuoteService.getNbQuote(); + + // Update the quotes data for the current page + quotes = response.ToArray(); + + // Update the current page number + page = e.Page; + } + } + + /*private void OnEditButtonClicked(Quote quote) + { + if (selectedQuote == null) return; + selectedQuote = quote; + showEditQuote = true; + }*/ + + /// + /// Closes the open popups and resets any related states. + /// This method hides the delete confirmation popup and clears the selected quote. + /// + private void ClosePopup() + { + // Hide the delete confirmation popup + showPopupDelete = false; + + // Reset the selected quote to null + selectedQuote = null; + } + + /*private async Task EditQuote() + { + await QuoteService.updateQuote(selectedQuote); + selectedQuote = null; + ClosePopup(); + }*/ + + /// + /// Handles the event when the delete action is triggered for a quote. + /// This method sets the selected quote to the one passed as a parameter and displays the delete confirmation popup. + /// + /// The quote that is being deleted. + private void OnDelete(Quote q) + { + // Set the selected quote to the one passed in + selectedQuote = q; + + // Display the delete confirmation popup + showPopupDelete = true; + } + + /// + /// Removes the selected quote by calling the remove service and updates the quote list. + /// This method checks if a quote is selected. If so, it removes the quote using the `QuoteService`, clears the selected quote, + /// and fetches the updated list of quotes. It also closes the delete confirmation popup after the operation. + /// + private async Task RemoveQuote() + { + // Check if a quote is selected for removal + if (selectedQuote != null) + { + // Remove the selected quote using the QuoteService + LoggerSaveStub.Log(Logger, LogLevel.Information, $"The quote {selectedQuote.Content} has been deleted"); + await QuoteService.removeQuote(selectedQuote); + + // Clear the selected quote after removal + selectedQuote = null; + + // Update the quotes list by fetching the latest quotes data + var response = await QuoteService.getSomeQuote(MaxValue, page); + quotes = response.ToArray(); + } + + // Close the delete confirmation popup + showPopupDelete = false; + } + } +} From 319ae7342244b2dfd6e4f2a4a107415a20de7050 Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:06:37 +0100 Subject: [PATCH 05/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Pages/=5FLayout.cshtml'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- WF-WebAdmin/WF-WebAdmin/Pages/_Layout.cshtml | 79 ++++++++++---------- 1 file changed, 40 insertions(+), 39 deletions(-) diff --git a/WF-WebAdmin/WF-WebAdmin/Pages/_Layout.cshtml b/WF-WebAdmin/WF-WebAdmin/Pages/_Layout.cshtml index 8d65dee..bf3af26 100644 --- a/WF-WebAdmin/WF-WebAdmin/Pages/_Layout.cshtml +++ b/WF-WebAdmin/WF-WebAdmin/Pages/_Layout.cshtml @@ -1,39 +1,40 @@ -@using Microsoft.AspNetCore.Components.Web -@namespace WF_WebAdmin.Pages -@addTagHelper *, Microsoft.AspNetCore.Mvc.TagHelpers - - - - - - - - - - - - - - - @RenderBody() - -
- - An error has occurred. This application may no longer respond until reloaded. - - - An unhandled exception has occurred. See browser dev tools for details. - - Reload - 🗙 -
- - - - - - - - - - +@using Microsoft.AspNetCore.Components.Web +@namespace WF_WebAdmin.Pages +@addTagHelper *, Microsoft.AspNetCore.Mvc.TagHelpers + + + + + Layout + + + + + + + + + + + @RenderBody() + +
+ + An error has occurred. This application may no longer respond until reloaded. + + + An unhandled exception has occurred. See browser dev tools for details. + + Reload + 🗙 +
+ + + + + + + + + + From de00eac7837c0bb35e20aaf9ca87976896434521 Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:12:35 +0100 Subject: [PATCH 06/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Pages/=5FLayout.cshtml'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- WF-WebAdmin/WF-WebAdmin/Pages/_Layout.cshtml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/WF-WebAdmin/WF-WebAdmin/Pages/_Layout.cshtml b/WF-WebAdmin/WF-WebAdmin/Pages/_Layout.cshtml index bf3af26..acf620f 100644 --- a/WF-WebAdmin/WF-WebAdmin/Pages/_Layout.cshtml +++ b/WF-WebAdmin/WF-WebAdmin/Pages/_Layout.cshtml @@ -5,7 +5,7 @@ - Layout + layout From 05b13c040a21e6b20528a07ab8a981309d24c980 Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:12:53 +0100 Subject: [PATCH 07/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Pages/Error.cshtml'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- WF-WebAdmin/WF-WebAdmin/Pages/Error.cshtml | 84 +++++++++++----------- 1 file changed, 42 insertions(+), 42 deletions(-) diff --git a/WF-WebAdmin/WF-WebAdmin/Pages/Error.cshtml b/WF-WebAdmin/WF-WebAdmin/Pages/Error.cshtml index 8f9fd5d..445ceaf 100644 --- a/WF-WebAdmin/WF-WebAdmin/Pages/Error.cshtml +++ b/WF-WebAdmin/WF-WebAdmin/Pages/Error.cshtml @@ -1,42 +1,42 @@ -@page -@model WF_WebAdmin.Pages.ErrorModel - - - - - - - - Error - - - - - -
-
-

Error.

-

An error occurred while processing your request.

- - @if (Model.ShowRequestId) - { -

- Request ID: @Model.RequestId -

- } - -

Development Mode

-

- Swapping to the Development environment displays detailed information about the error that occurred. -

-

- The Development environment shouldn't be enabled for deployed applications. - It can result in displaying sensitive information from exceptions to end users. - For local debugging, enable the Development environment by setting the ASPNETCORE_ENVIRONMENT environment variable to Development - and restarting the app. -

-
-
- - - +@page +@model WF_WebAdmin.Pages.ErrorModel + + + + + + + + error + + + + + +
+
+

Error.

+

An error occurred while processing your request.

+ + @if (Model.ShowRequestId) + { +

+ Request ID: @Model.RequestId +

+ } + +

Development Mode

+

+ Swapping to the Development environment displays detailed information about the error that occurred. +

+

+ The Development environment shouldn't be enabled for deployed applications. + It can result in displaying sensitive information from exceptions to end users. + For local debugging, enable the Development environment by setting the ASPNETCORE_ENVIRONMENT environment variable to Development + and restarting the app. +

+
+
+ + + From 72ff55a8893461b12ab542daa7b4bc029fb5a715 Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:13:25 +0100 Subject: [PATCH 08/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Pages/=5FLayout.cshtml'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- WF-WebAdmin/WF-WebAdmin/Pages/_Layout.cshtml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/WF-WebAdmin/WF-WebAdmin/Pages/_Layout.cshtml b/WF-WebAdmin/WF-WebAdmin/Pages/_Layout.cshtml index acf620f..6db6afe 100644 --- a/WF-WebAdmin/WF-WebAdmin/Pages/_Layout.cshtml +++ b/WF-WebAdmin/WF-WebAdmin/Pages/_Layout.cshtml @@ -25,7 +25,7 @@ An unhandled exception has occurred. See browser dev tools for details. - Reload + reload 🗙 From 72e29790a3624858f79ce3206769d13868654753 Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:14:47 +0100 Subject: [PATCH 09/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Pages/Error.cshtml'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- WF-WebAdmin/WF-WebAdmin/Pages/Error.cshtml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/WF-WebAdmin/WF-WebAdmin/Pages/Error.cshtml b/WF-WebAdmin/WF-WebAdmin/Pages/Error.cshtml index 445ceaf..961dd63 100644 --- a/WF-WebAdmin/WF-WebAdmin/Pages/Error.cshtml +++ b/WF-WebAdmin/WF-WebAdmin/Pages/Error.cshtml @@ -27,12 +27,12 @@

Development Mode

- Swapping to the Development environment displays detailed information about the error that occurred. + Swapping to the development environment displays detailed information about the error that occurred.

The Development environment shouldn't be enabled for deployed applications. It can result in displaying sensitive information from exceptions to end users. - For local debugging, enable the Development environment by setting the ASPNETCORE_ENVIRONMENT environment variable to Development + For local debugging, enable the development environment by setting the ASPNETCORE_ENVIRONMENT environment variable to Development and restarting the app.

From f6936c7caa922cd7ca31eddaf2fb5ae49c029d9a Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:18:12 +0100 Subject: [PATCH 10/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Service/QuoteServiceLocal.cs'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../WF-WebAdmin/Service/QuoteServiceLocal.cs | 396 +++++++++--------- 1 file changed, 198 insertions(+), 198 deletions(-) diff --git a/WF-WebAdmin/WF-WebAdmin/Service/QuoteServiceLocal.cs b/WF-WebAdmin/WF-WebAdmin/Service/QuoteServiceLocal.cs index 4271681..0afa4ab 100644 --- a/WF-WebAdmin/WF-WebAdmin/Service/QuoteServiceLocal.cs +++ b/WF-WebAdmin/WF-WebAdmin/Service/QuoteServiceLocal.cs @@ -1,198 +1,198 @@ -using WF_WebAdmin.Converter; -using WF_WebAdmin.Model; -using Npgsql; - -namespace WF_WebAdmin.Service -{ - public class QuoteServiceLocal: IQuoteService - { - private readonly string? _connectionString = "Host=localhost;Port=5432;Username=loguichard3;Password=Reglisse15.;Database=dbloguichard3"; - - - - /// - /// Asynchronously adds a new quote to the database and returns the corresponding . - /// - /// The object to be added to the database. - /// A task representing the asynchronous operation, with a result containing the added quote's data. - /// - /// This method converts the provided object into a using . - /// It then inserts the quote into the PostgreSQL database using a parameterized SQL query with the help of Npgsql. - /// After successfully inserting the quote, the corresponding is returned to the caller. - /// Error handling is in place to catch any issues during the database insertion process, with the exception message logged in case of failure. - /// - public async Task AddQuoteAsync(Quote quote) - { - QuoteExtension extension = new QuoteExtension(); - QuoteDTO quoteDTO = extension.QuoteToDTO(quote); - - // Utilisation de NpgsqlConnection pour PostgreSQL - using (var connection = new NpgsqlConnection(_connectionString)) - { - // Définir la requête SQL d'insertion - var commandText = "INSERT INTO Quote (content, langue, reason, id_source, id_caracter, id_user_verif, img_path) " + - "VALUES (@content, @langue, @reason, @source, @character, @user, @img_path)"; - - // Créer une commande Npgsql - var command = new NpgsqlCommand(commandText, connection); - - - /* - // Ajouter des paramètres à la commande - command.Parameters.AddWithValue("@content", quote.Content); - command.Parameters.AddWithValue("@langue", quote.Langue); - command.Parameters.AddWithValue("@reason", "À vérifier"); // Vous pouvez changer ça si nécessaire - command.Parameters.AddWithValue("@source", quote.Source); - command.Parameters.AddWithValue("@character", quote.Character); - command.Parameters.AddWithValue("@user", quote.User); // Assurez-vous que `quote.User` est correctement défini - command.Parameters.AddWithValue("@img_path", quote.ImgPath); - */ - - - try - { - // Ouvrir la connexion à la base de données - await connection.OpenAsync(); - - // Exécuter la commande d'insertion - await command.ExecuteNonQueryAsync(); - } - catch (Exception ex) - { - // Gérer les erreurs ici (par exemple, afficher ou enregistrer les erreurs) - Console.WriteLine($"Une erreur est survenue lors de l'ajout de la citation : {ex.Message}"); - } - finally - { - // Fermer la connexion (automatiquement géré avec `using`, mais ajouté pour explicitement montrer le processus) - await connection.CloseAsync(); - } - } - - // Retourner l'objet DTO pour que vous puissiez l'utiliser ailleurs dans votre application - return quoteDTO; - } - - - /// - /// Asynchronously handles the removal of a quote and returns the corresponding . - /// - /// The object to be removed. - /// A task representing the asynchronous operation, with a result corresponding to the removed quote. - /// - /// This method takes a object, converts it into a using the - /// , and then returns the DTO. Note that while this function is named `RemoveQuote`, - /// it currently only converts the quote to a DTO and does not actually perform any database removal operation. - /// You may need to implement additional logic to remove the quote from the database. - /// - public Task RemoveQuote(Quote quote) - { - QuoteExtension extension = new QuoteExtension(); - QuoteDTO quoteDTO = extension.QuoteToDTO(quote); - - // Return the DTO as the result of this asynchronous operation (though no removal logic is currently implemented) - return Task.FromResult(quoteDTO); - } - - - /// - /// Asynchronously validates a quote and returns the corresponding . - /// - /// The object to be validated. - /// A task representing the asynchronous operation, with a result corresponding to the validated quote. - /// - /// This method takes a object, converts it into a using the - /// , and returns the DTO. The method is named `validQuote`, but currently, it only - /// converts the quote into a DTO and does not perform any actual validation logic. - /// If you intend to validate the quote (e.g., updating its status in a database), you will need to implement - /// the actual validation logic separately. - /// - public Task validQuote(Quote quote) - { - QuoteExtension extension = new QuoteExtension(); - QuoteDTO quoteDTO = extension.QuoteToDTO(quote); - - // Return the DTO as the result of this asynchronous operation (though no validation logic is currently implemented) - return Task.FromResult(quoteDTO); - } - - - /// - /// Asynchronously updates a quote and returns the corresponding . - /// - /// The object to be updated. - /// A task representing the asynchronous operation, with a result corresponding to the updated quote. - /// - /// This method takes a object, converts it into a using the - /// , and returns the DTO. The method is named `updateQuote`, but currently, it only - /// converts the quote into a DTO and does not perform any actual update logic. - /// If you intend to update the quote (e.g., modifying the quote in a database or data source), - /// you will need to implement the actual update logic separately. - /// - public Task updateQuote(Quote quote) - { - QuoteExtension extension = new QuoteExtension(); - QuoteDTO quoteDTO = extension.QuoteToDTO(quote); - - // Return the DTO as the result of this asynchronous operation (though no update logic is currently implemented) - return Task.FromResult(quoteDTO); - } - - - - public Task addQuote(Quote quote) - { - throw new NotImplementedException(); - } - - public Task removeQuote(Quote quote) - { - throw new NotImplementedException(); - } - - public Task> getAllQuote() - { - throw new NotImplementedException(); - } - - public Task> getSomeQuote(int nb, int page) - { - throw new NotImplementedException(); - } - - public Task> reserchQuote(string reserch, List argument) - { - throw new NotImplementedException(); - } - - public Task> getAllQuoteInvalid() - { - throw new NotImplementedException(); - } - - public Task> getSomeQuoteInvalid(int nb, int page) - { - throw new NotImplementedException(); - } - - public Task getOnequote(int id) - { - throw new NotImplementedException(); - } - - public Task getNbQuote() - { - throw new NotImplementedException(); - } - - public Task> getChar() - { - throw new NotImplementedException(); - } - - public Task> getSrc() - { - throw new NotImplementedException(); - } - } -} +using WF_WebAdmin.Converter; +using WF_WebAdmin.Model; +using Npgsql; + +namespace WF_WebAdmin.Service +{ + public class QuoteServiceLocal: IQuoteService + { + private readonly string? _connectionString = "Host=localhost;Port=5432;Username=;Password=;Database="; + + + + /// + /// Asynchronously adds a new quote to the database and returns the corresponding . + /// + /// The object to be added to the database. + /// A task representing the asynchronous operation, with a result containing the added quote's data. + /// + /// This method converts the provided object into a using . + /// It then inserts the quote into the PostgreSQL database using a parameterized SQL query with the help of Npgsql. + /// After successfully inserting the quote, the corresponding is returned to the caller. + /// Error handling is in place to catch any issues during the database insertion process, with the exception message logged in case of failure. + /// + public async Task AddQuoteAsync(Quote quote) + { + QuoteExtension extension = new QuoteExtension(); + QuoteDTO quoteDTO = extension.QuoteToDTO(quote); + + // Utilisation de NpgsqlConnection pour PostgreSQL + using (var connection = new NpgsqlConnection(_connectionString)) + { + // Définir la requête SQL d'insertion + var commandText = "INSERT INTO Quote (content, langue, reason, id_source, id_caracter, id_user_verif, img_path) " + + "VALUES (@content, @langue, @reason, @source, @character, @user, @img_path)"; + + // Créer une commande Npgsql + var command = new NpgsqlCommand(commandText, connection); + + + /* + // Ajouter des paramètres à la commande + command.Parameters.AddWithValue("@content", quote.Content); + command.Parameters.AddWithValue("@langue", quote.Langue); + command.Parameters.AddWithValue("@reason", "À vérifier"); // Vous pouvez changer ça si nécessaire + command.Parameters.AddWithValue("@source", quote.Source); + command.Parameters.AddWithValue("@character", quote.Character); + command.Parameters.AddWithValue("@user", quote.User); // Assurez-vous que `quote.User` est correctement défini + command.Parameters.AddWithValue("@img_path", quote.ImgPath); + */ + + + try + { + // Ouvrir la connexion à la base de données + await connection.OpenAsync(); + + // Exécuter la commande d'insertion + await command.ExecuteNonQueryAsync(); + } + catch (Exception ex) + { + // Gérer les erreurs ici (par exemple, afficher ou enregistrer les erreurs) + Console.WriteLine($"Une erreur est survenue lors de l'ajout de la citation : {ex.Message}"); + } + finally + { + // Fermer la connexion (automatiquement géré avec `using`, mais ajouté pour explicitement montrer le processus) + await connection.CloseAsync(); + } + } + + // Retourner l'objet DTO pour que vous puissiez l'utiliser ailleurs dans votre application + return quoteDTO; + } + + + /// + /// Asynchronously handles the removal of a quote and returns the corresponding . + /// + /// The object to be removed. + /// A task representing the asynchronous operation, with a result corresponding to the removed quote. + /// + /// This method takes a object, converts it into a using the + /// , and then returns the DTO. Note that while this function is named `RemoveQuote`, + /// it currently only converts the quote to a DTO and does not actually perform any database removal operation. + /// You may need to implement additional logic to remove the quote from the database. + /// + public Task RemoveQuote(Quote quote) + { + QuoteExtension extension = new QuoteExtension(); + QuoteDTO quoteDTO = extension.QuoteToDTO(quote); + + // Return the DTO as the result of this asynchronous operation (though no removal logic is currently implemented) + return Task.FromResult(quoteDTO); + } + + + /// + /// Asynchronously validates a quote and returns the corresponding . + /// + /// The object to be validated. + /// A task representing the asynchronous operation, with a result corresponding to the validated quote. + /// + /// This method takes a object, converts it into a using the + /// , and returns the DTO. The method is named `validQuote`, but currently, it only + /// converts the quote into a DTO and does not perform any actual validation logic. + /// If you intend to validate the quote (e.g., updating its status in a database), you will need to implement + /// the actual validation logic separately. + /// + public Task validQuote(Quote quote) + { + QuoteExtension extension = new QuoteExtension(); + QuoteDTO quoteDTO = extension.QuoteToDTO(quote); + + // Return the DTO as the result of this asynchronous operation (though no validation logic is currently implemented) + return Task.FromResult(quoteDTO); + } + + + /// + /// Asynchronously updates a quote and returns the corresponding . + /// + /// The object to be updated. + /// A task representing the asynchronous operation, with a result corresponding to the updated quote. + /// + /// This method takes a object, converts it into a using the + /// , and returns the DTO. The method is named `updateQuote`, but currently, it only + /// converts the quote into a DTO and does not perform any actual update logic. + /// If you intend to update the quote (e.g., modifying the quote in a database or data source), + /// you will need to implement the actual update logic separately. + /// + public Task updateQuote(Quote quote) + { + QuoteExtension extension = new QuoteExtension(); + QuoteDTO quoteDTO = extension.QuoteToDTO(quote); + + // Return the DTO as the result of this asynchronous operation (though no update logic is currently implemented) + return Task.FromResult(quoteDTO); + } + + + + public Task addQuote(Quote quote) + { + throw new NotImplementedException(); + } + + public Task removeQuote(Quote quote) + { + throw new NotImplementedException(); + } + + public Task> getAllQuote() + { + throw new NotImplementedException(); + } + + public Task> getSomeQuote(int nb, int page) + { + throw new NotImplementedException(); + } + + public Task> reserchQuote(string reserch, List argument) + { + throw new NotImplementedException(); + } + + public Task> getAllQuoteInvalid() + { + throw new NotImplementedException(); + } + + public Task> getSomeQuoteInvalid(int nb, int page) + { + throw new NotImplementedException(); + } + + public Task getOnequote(int id) + { + throw new NotImplementedException(); + } + + public Task getNbQuote() + { + throw new NotImplementedException(); + } + + public Task> getChar() + { + throw new NotImplementedException(); + } + + public Task> getSrc() + { + throw new NotImplementedException(); + } + } +} From 6b6a8599821089b309ea5a936679aba68fa3bbe8 Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:24:37 +0100 Subject: [PATCH 11/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Pages/DeleteUser.razor.cs'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../WF-WebAdmin/Pages/DeleteUser.razor.cs | 216 +++++++++--------- 1 file changed, 108 insertions(+), 108 deletions(-) diff --git a/WF-WebAdmin/WF-WebAdmin/Pages/DeleteUser.razor.cs b/WF-WebAdmin/WF-WebAdmin/Pages/DeleteUser.razor.cs index 6d54c06..4008bf9 100644 --- a/WF-WebAdmin/WF-WebAdmin/Pages/DeleteUser.razor.cs +++ b/WF-WebAdmin/WF-WebAdmin/Pages/DeleteUser.razor.cs @@ -1,7 +1,7 @@ using Blazorise.DataGrid; using Microsoft.AspNetCore.Components; using Microsoft.Extensions.Configuration.UserSecrets; -using Microsoft.Extensions.Logging; +using Microsoft.Extensions.Logging; using Microsoft.Extensions.Localization; using System.Collections.Generic; using WF_WebAdmin.Model; @@ -11,12 +11,12 @@ namespace WF_WebAdmin.Pages { public partial class DeleteUser { - [Inject] - public ILogger Logger { get; set; } + [Inject] + public ILogger Logger { get; set; } + + private List users; - private List users; - - private bool showDeletePopup = false; + private bool showModifyPopup = false; private User userToDelete = null; private User selectedUser; @@ -37,180 +37,180 @@ namespace WF_WebAdmin.Pages [Inject] private IUserService userService { get; set; } - [Inject] + [Inject] public IStringLocalizer Localizer { get; set; } - /// - /// This method is called when the component is initialized. - /// It is an asynchronous method that retrieves a list of users from the user service. - /// The method fetches a subset of users with a specified maximum value and page number (1 in this case). - /// + /// + /// This method is called when the component is initialized. + /// It is an asynchronous method that retrieves a list of users from the user service. + /// The method fetches a subset of users with a specified maximum value and page number (1 in this case). + /// protected override async Task OnInitializedAsync() { - // Retrieve a list of users using the user service. The number of users and page number are specified. - // MaxValue determines how many users to retrieve, and '1' refers to the first page of results. + // Retrieve a list of users using the user service. The number of users and page number are specified. + // MaxValue determines how many users to retrieve, and '1' refers to the first page of results. users = await userService.getSomeUser(MaxValue, 1); } - - - /// - /// Handles the event when data is read in the data grid. - /// This method is triggered during pagination or when data is loaded into the grid. - /// It asynchronously fetches a page of users based on the requested page size and page number, - /// and updates the list of users and total item count if the operation is not cancelled. - /// - /// The event arguments containing pagination details (page size and page number) and a cancellation token. + + + /// + /// Handles the event when data is read in the data grid. + /// This method is triggered during pagination or when data is loaded into the grid. + /// It asynchronously fetches a page of users based on the requested page size and page number, + /// and updates the list of users and total item count if the operation is not cancelled. + /// + /// The event arguments containing pagination details (page size and page number) and a cancellation token. private async Task OnReadData(DataGridReadDataEventArgs e) { - // If the cancellation token is requested, exit the method without processing the request. + // If the cancellation token is requested, exit the method without processing the request. if (e.CancellationToken.IsCancellationRequested) { return; } - // Fetch a page of users from the user service using the page size and page number provided by the event arguments. + // Fetch a page of users from the user service using the page size and page number provided by the event arguments. var response = await userService.getSomeUser(e.PageSize, e.Page); - // If the operation is not cancelled, update the total number of users and the list of users. + // If the operation is not cancelled, update the total number of users and the list of users. if (!e.CancellationToken.IsCancellationRequested) { - totalItem = await userService.getNbUser(); // Get the total number of users - users = new List(response.ToArray()); // Store the retrieved users in the users list - page = e.Page; // Update the current page number + totalItem = await userService.getNbUser(); // Get the total number of users + users = new List(response.ToArray()); // Store the retrieved users in the users list + page = e.Page; // Update the current page number } } // ------- Popup remove user ------- - - /// - /// Displays a confirmation popup to confirm the deletion of a user. - /// This method is triggered when the user intends to delete a user, - /// and it sets the user to be deleted and shows the confirmation popup. - /// - /// The user to be deleted, which is passed to the method for confirmation. + + /// + /// Displays a confirmation popup to confirm the deletion of a user. + /// This method is triggered when the user intends to delete a user, + /// and it sets the user to be deleted and shows the confirmation popup. + /// + /// The user to be deleted, which is passed to the method for confirmation. private void ShowConfirmation(User user) { - // Set the user to be deleted and show the confirmation popup. - userToDelete = user; // Store the user to be deleted in a variable - showPopupDelete = true; // Display the confirmation popup + // Set the user to be deleted and show the confirmation popup. + userToDelete = user; // Store the user to be deleted in a variable + showPopupDelete = true; // Display the confirmation popup } - - /// - /// Displays a confirmation popup for modifying a user's information. - /// This method is triggered when the user intends to modify a specific user's data, - /// and it sets the selected user and shows the modification confirmation popup. - /// - /// The user whose information is to be modified, passed to the method for confirmation. + + /// + /// Displays a confirmation popup for modifying a user's information. + /// This method is triggered when the user intends to modify a specific user's data, + /// and it sets the selected user and shows the modification confirmation popup. + /// + /// The user whose information is to be modified, passed to the method for confirmation. private void ShowModifyConfirmation(User user) { - // Set the selected user and show the modification confirmation popup. - selectedUser = user; // Store the user to be modified - showModifyPopup = true; // Display the confirmation popup for modification + // Set the selected user and show the modification confirmation popup. + selectedUser = user; // Store the user to be modified + showModifyPopup = true; // Display the confirmation popup for modification } - - /// - /// Removes the specified user from the system. - /// This method is triggered when the user confirms the deletion of a user. - /// It calls the user service to remove the user, closes the confirmation popup, - /// and then refreshes the list of users by fetching the updated data. - /// + + /// + /// Removes the specified user from the system. + /// This method is triggered when the user confirms the deletion of a user. + /// It calls the user service to remove the user, closes the confirmation popup, + /// and then refreshes the list of users by fetching the updated data. + /// private async Task RemoveUser() { - // Check if there is a user to delete + // Check if there is a user to delete if (userToDelete != null) { - // Remove the selected user from the system using the user service + // Remove the selected user from the system using the user service LoggerSaveStub.Log(Logger, LogLevel.Information, $"Delete user {userToDelete.Name}"); await userService.removeUser(userToDelete); - - // Close the confirmation popup after the deletion + + // Close the confirmation popup after the deletion ClosePopup(); - - // Refresh the list of users by fetching the updated data from the user service + + // Refresh the list of users by fetching the updated data from the user service var response = await userService.getSomeUser(MaxValue, page); - - // Update the users list with the latest data + + // Update the users list with the latest data users = new List(response.ToArray()); } } - - /// - /// Modifies the selected user's information. - /// This method is triggered when the user confirms the modification of a user's details. - /// It calls the user service to update the user's information and then closes the modification popup. - /// + + /// + /// Modifies the selected user's information. + /// This method is triggered when the user confirms the modification of a user's details. + /// It calls the user service to update the user's information and then closes the modification popup. + /// private async Task ModifyUser() { - // Update the selected user's information using the user service + // Update the selected user's information using the user service LoggerSaveStub.Log(Logger, LogLevel.Information, $"Modification of user {selectedUser.Name}"); await userService.updateUser(selectedUser); - - // Close the modification popup after the update is complete + + // Close the modification popup after the update is complete ClosePopup(); } - - /// - /// Closes all open popups in the UI by setting their visibility flags to false. - /// This method is typically called after an action (like deleting or modifying a user) - /// to hide any active popups and reset the UI state. - /// + + /// + /// Closes all open popups in the UI by setting their visibility flags to false. + /// This method is typically called after an action (like deleting or modifying a user) + /// to hide any active popups and reset the UI state. + /// private void ClosePopup() { - // Set all popup visibility flags to false to hide the popups - showDeletePopup = false; // Close the delete confirmation popup - showModifyPopup = false; // Close the modify confirmation popup - showPopupDelete = false; // Close any additional delete popups - showPopupAdmin = false; // Close the admin-related popup (if any) + // Set all popup visibility flags to false to hide the popups + showDeletePopup = false; // Close the delete confirmation popup + showModifyPopup = false; // Close the modify confirmation popup + showPopupDelete = false; // Close any additional delete popups + showPopupAdmin = false; // Close the admin-related popup (if any) } // ------- Popup admin ------- - /// - /// Displays a confirmation popup to confirm the promotion of a user to admin status. - /// This method is triggered when the user intends to promote a specific user to admin. - /// It sets the selected user to be promoted and shows the confirmation popup for admin promotion. - /// - /// The user to be promoted to admin, passed to the method for confirmation. + /// + /// Displays a confirmation popup to confirm the promotion of a user to admin status. + /// This method is triggered when the user intends to promote a specific user to admin. + /// It sets the selected user to be promoted and shows the confirmation popup for admin promotion. + /// + /// The user to be promoted to admin, passed to the method for confirmation. private void ShowConfirmationAdmin(User user) { - // Set the user to be promoted to admin and show the confirmation popup. - userToAdmin = user; // Store the user to be promoted - showPopupAdmin = true; // Display the confirmation popup for admin promotion + // Set the user to be promoted to admin and show the confirmation popup. + userToAdmin = user; // Store the user to be promoted + showPopupAdmin = true; // Display the confirmation popup for admin promotion } - /// - /// Toggles the admin status of the selected user. - /// This method checks the current admin status of the user, and if the user is not an admin, - /// it promotes them to admin. If the user is already an admin, it demotes them. - /// After the change, the user's information is updated, and the confirmation popup is closed. - /// + /// + /// Toggles the admin status of the selected user. + /// This method checks the current admin status of the user, and if the user is not an admin, + /// it promotes them to admin. If the user is already an admin, it demotes them. + /// After the change, the user's information is updated, and the confirmation popup is closed. + /// private async Task setAdmin() { - // Check if the user is not already an admin + // Check if the user is not already an admin if (!userToAdmin.IsAdmin) { - // Promote the user to admin - LoggerSaveStub.Log(Logger, LogLevel.Information, $"User {userToAdmin.Name} is now administrator"); + // Promote the user to admin + LoggerSaveStub.Log(Logger, LogLevel.Information, $"User {userToAdmin.Name} is now administrator"); userToAdmin.IsAdmin = true; - await userService.updateUser(userToAdmin); // Update the user status in the service - ClosePopup(); // Close the confirmation popup + await userService.updateUser(userToAdmin); // Update the user status in the service + ClosePopup(); // Close the confirmation popup } else { - // Demote the user from admin to normal user - LoggerSaveStub.Log(Logger, LogLevel.Information, $"User {userToAdmin.Name} is no longer an administator"); + // Demote the user from admin to normal user + LoggerSaveStub.Log(Logger, LogLevel.Information, $"User {userToAdmin.Name} is no longer an administator"); userToAdmin.IsAdmin = false; - await userService.updateUser(userToAdmin); // Update the user status in the service - ClosePopup(); // Close the confirmation popup + await userService.updateUser(userToAdmin); // Update the user status in the service + ClosePopup(); // Close the confirmation popup } } From 95db35940ce7a2e0583108186c37052de848e625 Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:25:17 +0100 Subject: [PATCH 12/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Pages/Error.cshtml.cs'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- WF-WebAdmin/WF-WebAdmin/Pages/Error.cshtml.cs | 80 +++++++++---------- 1 file changed, 40 insertions(+), 40 deletions(-) diff --git a/WF-WebAdmin/WF-WebAdmin/Pages/Error.cshtml.cs b/WF-WebAdmin/WF-WebAdmin/Pages/Error.cshtml.cs index 76bb3fe..a7a539c 100644 --- a/WF-WebAdmin/WF-WebAdmin/Pages/Error.cshtml.cs +++ b/WF-WebAdmin/WF-WebAdmin/Pages/Error.cshtml.cs @@ -1,40 +1,40 @@ -using Microsoft.AspNetCore.Mvc; -using Microsoft.AspNetCore.Mvc.RazorPages; -using System.Diagnostics; - -namespace WF_WebAdmin.Pages -{ - [ResponseCache(Duration = 0, Location = ResponseCacheLocation.None, NoStore = true)] - [IgnoreAntiforgeryToken] - public class ErrorModel : PageModel - { - public string? RequestId { get; set; } - - public bool ShowRequestId => !string.IsNullOrEmpty(RequestId); - - private readonly ILogger _logger; - - - /// - /// Initializes a new instance of the class. - /// This constructor is used to inject the into the model for logging purposes. - /// - /// An instance of the used for logging error-related information. - public ErrorModel(ILogger logger) - { - _logger = logger; - } - - - /// - /// Handles the GET request for the page or endpoint. - /// This method retrieves the request ID for tracing purposes, using the `Activity.Current?.Id` - /// if it's available, or the `HttpContext.TraceIdentifier` as a fallback if no current activity ID is present. - /// - public void OnGet() - { - // Retrieve the current request ID for tracing - RequestId = Activity.Current?.Id ?? HttpContext.TraceIdentifier; - } - } -} +using Microsoft.AspNetCore.Mvc; +using Microsoft.AspNetCore.Mvc.RazorPages; +using System.Diagnostics; + +namespace WF_WebAdmin.Pages +{ + [ResponseCache(Duration = 0, Location = ResponseCacheLocation.None, NoStore = true)] + [IgnoreAntiforgeryToken] + public class ErrorModel : PageModel + { + public string? RequestId { get; set; } + + public bool ShowRequestId => !string.IsNullOrEmpty(RequestId); + + + + + /// + /// Initializes a new instance of the class. + /// This constructor is used to inject the into the model for logging purposes. + /// + /// An instance of the used for logging error-related information. + public ErrorModel(ILogger logger) + { + _logger = logger; + } + + + /// + /// Handles the GET request for the page or endpoint. + /// This method retrieves the request ID for tracing purposes, using the `Activity.Current?.Id` + /// if it's available, or the `HttpContext.TraceIdentifier` as a fallback if no current activity ID is present. + /// + public void OnGet() + { + // Retrieve the current request ID for tracing + RequestId = Activity.Current?.Id ?? HttpContext.TraceIdentifier; + } + } +} From 02aa7a1b15f5cbbe215d2923e78487a749e10d0d Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:26:38 +0100 Subject: [PATCH 13/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/wwwroot/css/site.css'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- WF-WebAdmin/WF-WebAdmin/wwwroot/css/site.css | 528 ++++++++++--------- 1 file changed, 267 insertions(+), 261 deletions(-) diff --git a/WF-WebAdmin/WF-WebAdmin/wwwroot/css/site.css b/WF-WebAdmin/WF-WebAdmin/wwwroot/css/site.css index 7995488..389b97b 100644 --- a/WF-WebAdmin/WF-WebAdmin/wwwroot/css/site.css +++ b/WF-WebAdmin/WF-WebAdmin/wwwroot/css/site.css @@ -1,262 +1,268 @@ -@import url('open-iconic/font/css/open-iconic-bootstrap.min.css'); -@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,100..900;1,100..900&display=swap'); - -html, body { - font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif; - background: white; - color: black; -} - -h1:focus { - outline: none; -} - -a, .btn-link { - color: #ffffff; - text-decoration: none; -} - -.btn-primary { - color: #fff; - background-color: #1b6ec2; - border-color: #1861ac; -} - -.content { - padding-top: 1.1rem; -} - -.valid.modified:not([type=checkbox]) { - outline: 1px solid #26b050; -} - -.invalid { - outline: 1px solid red; -} - -.validation-message { - color: red; -} - -#blazor-error-ui { - background: lightyellow; - bottom: 0; - box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2); - display: none; - left: 0; - padding: 0.6rem 1.25rem 0.7rem 1.25rem; - position: fixed; - width: 100%; - z-index: 1000; -} - - #blazor-error-ui .dismiss { - cursor: pointer; - position: absolute; - right: 0.75rem; - top: 0.5rem; - } - -.blazor-error-boundary { - background: url() no-repeat 1rem/1.8rem, #b32121; - padding: 1rem 1rem 1rem 3.7rem; - color: white; -} - - .blazor-error-boundary::after { - content: "An error has occurred." - } - - -button { - border: none; - border-radius: 25px; - background-color: lightgrey; - padding: 1vh; -} - -/*Page DeleteUser*/ -.userDiv, .QuoteDiv { - margin-right: 20px; - margin-bottom: 10px; - border-radius: 25px; - background-color: #C3C4C5; -} - -.imgProfil { - border-radius: 25px; - width: 150px; /* Taille standard */ - height: 150px; /* Taille standard */ - object-fit: cover; -} - -.imgQuote { - border-radius: 20px; - width: 300px; /* Taille standard */ - height: 300px; /* Taille standard */ - object-fit: cover; -} - -.pseudo, .mail, .idUser, .dateCrea, .idQuote, .contentQuote, .CaracterQuote, .SourceQuote, .langueQuote, .UserPropositionQuote { - margin-left: 10px; -} - -/*ModifQuote*/ - -.imgTab{ - width: 5vw; - height: 5vw; - object-fit: contain; -} - -/*Popup DeleteUser*/ -.divPopup { - position: fixed; - top: 0; - left: 0; - width: 100%; - height: 100%; - border-radius:20px; - display: flex; - justify-content: center; - align-items: center; - z-index: 2; -} - -.contentPopup { - padding: 20px; - border-radius: 20px; - border: 3px solid black; - display: flex; - background-color: white; - flex-direction: column; - gap: 10px; - width: 300px; - text-align: center; -} - -table { - border-collapse: collapse; - width: 100%; -} - -td { - padding: 10px 20px; - border: none; -} - -.boutons { - display: flex; - justify-content: space-between; - gap: 10px; -} - -.boutons button { - border: none; - background-color: transparent; - padding: 5px; - cursor: pointer; -} - -.boutons button img { - width: 24px; - height: 24px; - object-fit: contain; -} - - -.buttonSubmitDiv { - text-align: center; -} - -h1 { - text-align: center; - font-size: 32px; - margin-top: 10%; - font-family: "Roboto", serif; -} - -p { - margin-bottom: 2%; - font-size: 20px; - font-family: "Roboto", serif; -} - -.login { - width: 35vw; - margin-left: 30.5vw; - margin-top: 3vh; - border-radius: 25px; - padding: 2vw; - background-color: #cfcfcf; -} - - -/*Page login*/ -.buttonSudmite { - border: none; - padding: 2%; - margin-top: 5%; - border-radius: 25px; - width: 50%; - font-size: 1.25em; - background-color: white; - font-family: "Roboto", serif; -} - -.connexion { - width: 94%; - height: 40px; - padding-left: 3%; - margin-left: 1%; - margin-top: -1%; - border-radius: 25px; - border: none; - font-size: 15px; -} - - - -.ErrorMsg { - color: red; -} - -table { - border-collapse: collapse; - width: 100%; -} - -td { - padding: 10px 20px; - border: none; -} - -.boutons { - display: flex; - justify-content: space-between; - gap: 10px; -} - -.boutons button { - border: none; - background-color: transparent; - padding: 5px; - cursor: pointer; -} - -.boutons button img { - width: 24px; - height: 24px; - object-fit: contain; -} - - -.imageProfil { - height: auto; - width: 30px; - border-radius: 45%; -} - -.buttonProfil{ - background-color:transparent; +@import url('open-iconic/font/css/open-iconic-bootstrap.min.css'); +@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,100..900;1,100..900&display=swap'); + +html, body { + font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif; + background: white; + color: black; +} + + + + +h1 { + text-align: center; + font-size: 32px; + margin-top: 10%; + font-family: "Roboto", serif; +} + + +h1:focus { + outline: none; +} + +a, .btn-link { + color: #ffffff; + text-decoration: none; +} + +.btn-primary { + color: #fff; + background-color: #1b6ec2; + border-color: #1861ac; +} + +.content { + padding-top: 1.1rem; +} + +.valid.modified:not([type=checkbox]) { + outline: 1px solid #26b050; +} + +.invalid { + outline: 1px solid red; +} + +.validation-message { + color: red; +} + +#blazor-error-ui { + background: lightyellow; + bottom: 0; + box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2); + display: none; + left: 0; + padding: 0.6rem 1.25rem 0.7rem 1.25rem; + position: fixed; + width: 100%; + z-index: 1000; +} + + #blazor-error-ui .dismiss { + cursor: pointer; + position: absolute; + right: 0.75rem; + top: 0.5rem; + } + +.blazor-error-boundary { + background: url() no-repeat 1rem/1.8rem, #b32121; + padding: 1rem 1rem 1rem 3.7rem; + color: white; +} + + .blazor-error-boundary::after { + content: "An error has occurred." + } + + +button { + border: none; + border-radius: 25px; + background-color: lightgrey; + padding: 1vh; +} + +/*Page DeleteUser*/ +.userDiv, .QuoteDiv { + margin-right: 20px; + margin-bottom: 10px; + border-radius: 25px; + background-color: #C3C4C5; +} + +.imgProfil { + border-radius: 25px; + width: 150px; /* Taille standard */ + height: 150px; /* Taille standard */ + object-fit: cover; +} + +.imgQuote { + border-radius: 20px; + width: 300px; /* Taille standard */ + height: 300px; /* Taille standard */ + object-fit: cover; +} + +.pseudo, .mail, .idUser, .dateCrea, .idQuote, .contentQuote, .CaracterQuote, .SourceQuote, .langueQuote, .UserPropositionQuote { + margin-left: 10px; +} + +/*ModifQuote*/ + +.imgTab{ + width: 5vw; + height: 5vw; + object-fit: contain; +} + +/*Popup DeleteUser*/ +.divPopup { + position: fixed; + top: 0; + left: 0; + width: 100%; + height: 100%; + border-radius:20px; + display: flex; + justify-content: center; + align-items: center; + z-index: 2; +} + +.contentPopup { + padding: 20px; + border-radius: 20px; + border: 3px solid black; + display: flex; + background-color: white; + flex-direction: column; + gap: 10px; + width: 300px; + text-align: center; +} + +table { + border-collapse: collapse; + width: 100%; +} + +td { + padding: 10px 20px; + border: none; +} + +.boutons { + display: flex; + justify-content: space-between; + gap: 10px; +} + +.boutons button { + border: none; + background-color: transparent; + padding: 5px; + cursor: pointer; +} + +.boutons button img { + width: 24px; + height: 24px; + object-fit: contain; +} + + +.buttonSubmitDiv { + text-align: center; +} + + + +p { + margin-bottom: 2%; + font-size: 20px; + font-family: "Roboto", serif; +} + +.login { + width: 35vw; + margin-left: 30.5vw; + margin-top: 3vh; + border-radius: 25px; + padding: 2vw; + background-color: #cfcfcf; +} + + +/*Page login*/ +.buttonSudmite { + border: none; + padding: 2%; + margin-top: 5%; + border-radius: 25px; + width: 50%; + font-size: 1.25em; + background-color: white; + font-family: "Roboto", serif; +} + +.connexion { + width: 94%; + height: 40px; + padding-left: 3%; + margin-left: 1%; + margin-top: -1%; + border-radius: 25px; + border: none; + font-size: 15px; +} + + + +.ErrorMsg { + color: red; +} + +table { + border-collapse: collapse; + width: 100%; +} + +td { + padding: 10px 20px; + border: none; +} + +.boutons { + display: flex; + justify-content: space-between; + gap: 10px; +} + +.boutons button { + border: none; + background-color: transparent; + padding: 5px; + cursor: pointer; +} + +.boutons button img { + width: 24px; + height: 24px; + object-fit: contain; +} + + +.imageProfil { + height: auto; + width: 30px; + border-radius: 45%; +} + +.buttonProfil{ + background-color:transparent; } \ No newline at end of file From adc57b1ba97de2c0234321e9d54e34f1f09876df Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:29:25 +0100 Subject: [PATCH 14/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Converter/QuoteDto.cs'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../Converter/{QuoteDTO.cs => QuoteDto.cs} | 22 +++++++++---------- 1 file changed, 11 insertions(+), 11 deletions(-) rename WF-WebAdmin/WF-WebAdmin/Converter/{QuoteDTO.cs => QuoteDto.cs} (99%) diff --git a/WF-WebAdmin/WF-WebAdmin/Converter/QuoteDTO.cs b/WF-WebAdmin/WF-WebAdmin/Converter/QuoteDto.cs similarity index 99% rename from WF-WebAdmin/WF-WebAdmin/Converter/QuoteDTO.cs rename to WF-WebAdmin/WF-WebAdmin/Converter/QuoteDto.cs index 26a68a8..fc3e969 100644 --- a/WF-WebAdmin/WF-WebAdmin/Converter/QuoteDTO.cs +++ b/WF-WebAdmin/WF-WebAdmin/Converter/QuoteDto.cs @@ -24,20 +24,20 @@ namespace WF_WebAdmin.Converter public QuoteDTO(int id_quote,string content,int likes,string langue,bool isValide,string? reason,int? id_caracter,string name_charac,int? id_source,string title,DateTime date,int? id_user_verif,string name_user ,int? id_img,string img_path) { this.Id = id_quote; - this.Content = content; + this.Content = content; this.Likes = likes; this.Langue = langue; this.IsValide = isValide; - this.Reason = reason; - this.IdCaracter = id_caracter; - this.NameCharac = name_charac; - this.IdSource = id_source; - this.TitleSrc = title; - this.DateSrc = date; - this.IdUserVerif = id_user_verif; - this.NameUser = name_user; - this.IdImg = id_img; - this.ImgPath =img_path; + this.Reason = reason; + this.IdCaracter = id_caracter; + this.NameCharac = name_charac; + this.IdSource = id_source; + this.TitleSrc = title; + this.DateSrc = date; + this.IdUserVerif = id_user_verif; + this.NameUser = name_user; + this.IdImg = id_img; + this.ImgPath =img_path; } } } From 0408cc51fe5fd87673c3448190461706e2bc2f8d Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:29:37 +0100 Subject: [PATCH 15/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Converter/CommentaryDto.cs'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../WF-WebAdmin/Converter/{CommentaryDTO.cs => CommentaryDto.cs} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename WF-WebAdmin/WF-WebAdmin/Converter/{CommentaryDTO.cs => CommentaryDto.cs} (100%) diff --git a/WF-WebAdmin/WF-WebAdmin/Converter/CommentaryDTO.cs b/WF-WebAdmin/WF-WebAdmin/Converter/CommentaryDto.cs similarity index 100% rename from WF-WebAdmin/WF-WebAdmin/Converter/CommentaryDTO.cs rename to WF-WebAdmin/WF-WebAdmin/Converter/CommentaryDto.cs From bfe46f272ced75ca6d125473255801395d708857 Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:29:52 +0100 Subject: [PATCH 16/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Converter/DailyQuoteDto.cs'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../WF-WebAdmin/Converter/{DailyQuoteDTO.cs => DailyQuoteDto.cs} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename WF-WebAdmin/WF-WebAdmin/Converter/{DailyQuoteDTO.cs => DailyQuoteDto.cs} (100%) diff --git a/WF-WebAdmin/WF-WebAdmin/Converter/DailyQuoteDTO.cs b/WF-WebAdmin/WF-WebAdmin/Converter/DailyQuoteDto.cs similarity index 100% rename from WF-WebAdmin/WF-WebAdmin/Converter/DailyQuoteDTO.cs rename to WF-WebAdmin/WF-WebAdmin/Converter/DailyQuoteDto.cs From 45d8ba09cac42ee1d3dcc37ffd2279a86a52243e Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:30:06 +0100 Subject: [PATCH 17/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Converter/UserDto.cs'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- WF-WebAdmin/WF-WebAdmin/Converter/{UserDTO.cs => UserDto.cs} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename WF-WebAdmin/WF-WebAdmin/Converter/{UserDTO.cs => UserDto.cs} (100%) diff --git a/WF-WebAdmin/WF-WebAdmin/Converter/UserDTO.cs b/WF-WebAdmin/WF-WebAdmin/Converter/UserDto.cs similarity index 100% rename from WF-WebAdmin/WF-WebAdmin/Converter/UserDTO.cs rename to WF-WebAdmin/WF-WebAdmin/Converter/UserDto.cs From a06a14ffccf4aa4f634c94770eb2252652b2de2d Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:32:18 +0100 Subject: [PATCH 18/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Converter/UserDto.cs'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- WF-WebAdmin/WF-WebAdmin/Converter/UserDto.cs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/WF-WebAdmin/WF-WebAdmin/Converter/UserDto.cs b/WF-WebAdmin/WF-WebAdmin/Converter/UserDto.cs index 53a6032..a7eb8b8 100644 --- a/WF-WebAdmin/WF-WebAdmin/Converter/UserDto.cs +++ b/WF-WebAdmin/WF-WebAdmin/Converter/UserDto.cs @@ -10,7 +10,7 @@ namespace WF_WebAdmin.Converter public DateTime DateCreation { get; set; } public Boolean IsAdmin { get; set; } - public List Comments { get; set; } + public List? Comments { get; set; } public UserDTO(string image, string name, string email, DateTime dateCreation) { From 5a5d83fa029bd418272be8422dbd1bf58a1e428a Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:33:27 +0100 Subject: [PATCH 19/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Model/Character.cs'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- WF-WebAdmin/WF-WebAdmin/Model/Character.cs | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/WF-WebAdmin/WF-WebAdmin/Model/Character.cs b/WF-WebAdmin/WF-WebAdmin/Model/Character.cs index a5e1d87..31ae52e 100644 --- a/WF-WebAdmin/WF-WebAdmin/Model/Character.cs +++ b/WF-WebAdmin/WF-WebAdmin/Model/Character.cs @@ -1,8 +1,8 @@ -namespace WF_WebAdmin.Model -{ - public class Character - { - public int id_caracter { get; set; } - public string caracter { get; set; } - } -} +namespace WF_WebAdmin.Model +{ + public class Character + { + public int id_caracter { get; set; } + public string? caracter { get; set; } + } +} From 9a71fea118ae854da620a549e79d7b3802fe986b Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:34:16 +0100 Subject: [PATCH 20/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Model/LoggerSaveStub.cs'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../WF-WebAdmin/Model/LoggerSaveStub.cs | 66 +++++++------------ 1 file changed, 25 insertions(+), 41 deletions(-) diff --git a/WF-WebAdmin/WF-WebAdmin/Model/LoggerSaveStub.cs b/WF-WebAdmin/WF-WebAdmin/Model/LoggerSaveStub.cs index 0920ee3..9c8b0ae 100644 --- a/WF-WebAdmin/WF-WebAdmin/Model/LoggerSaveStub.cs +++ b/WF-WebAdmin/WF-WebAdmin/Model/LoggerSaveStub.cs @@ -1,41 +1,25 @@ -using Microsoft.AspNetCore.Components; -using Microsoft.Extensions.Configuration.UserSecrets; -using Microsoft.Extensions.Logging; -using Microsoft.VisualBasic; -using System; -using System.Diagnostics; -using System.Security.Claims; -using WF_WebAdmin.Pages; -using WF_WebAdmin.Service; - -namespace WF_WebAdmin.Model -{ - public static partial class LoggerSaveStub - { - public static void Log(ILogger logs,LogLevel logLevel,string message) - { - - ILogsService logsService = new LogsServiceStub(); - logsService.addLogs( new Logs( logLevel , message ) ); - - logs.Log(logLevel, message ); - } - } -} - -/* -[Inject] -public ILogger< Class > Logger { get; set; } - -LoggerSaveStub.Log(Logger,LogLevel. level , message ); - - -LogLevel: -Trace = 0, -Debug = 1, -Information = 2, -Warning = 3, -Error = 4, -Critical = 5, -None = 6, -*/ \ No newline at end of file +using Microsoft.AspNetCore.Components; +using Microsoft.Extensions.Configuration.UserSecrets; +using Microsoft.Extensions.Logging; +using Microsoft.VisualBasic; +using System; +using System.Diagnostics; +using System.Security.Claims; +using WF_WebAdmin.Pages; +using WF_WebAdmin.Service; + +namespace WF_WebAdmin.Model +{ + public static partial class LoggerSaveStub + { + public static void Log(ILogger logs,LogLevel logLevel,string message) + { + + ILogsService logsService = new LogsServiceStub(); + logsService.addLogs( new Logs( logLevel , message ) ); + + logs.Log(logLevel, message ); + } + } +} + From 866156ca35cdda2232c394ca8cbc30256abfb053 Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:35:01 +0100 Subject: [PATCH 21/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Model/Quiz.cs'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- WF-WebAdmin/WF-WebAdmin/Model/Quiz.cs | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/WF-WebAdmin/WF-WebAdmin/Model/Quiz.cs b/WF-WebAdmin/WF-WebAdmin/Model/Quiz.cs index a72be08..af6691a 100644 --- a/WF-WebAdmin/WF-WebAdmin/Model/Quiz.cs +++ b/WF-WebAdmin/WF-WebAdmin/Model/Quiz.cs @@ -3,7 +3,7 @@ namespace WF_WebAdmin.Model public class Quiz { public int Id { get; set; } - public string Question { get; set; } + public string? Question { get; set; } public string AnswerA { get; set; } public string AnswerB { get; set; } public string AnswerC { get; set; } @@ -25,8 +25,8 @@ namespace WF_WebAdmin.Model UserProposition = userProposition; } - public Quiz(int id, string question, string answerA, string answerB, string answerC, string answerD, string cAnswer) - { + public Quiz(int id, string question, string answerA, string answerB, string answerC, string answerD, string cAnswer) + { Id = id; Question = question; AnswerA = answerA; @@ -35,7 +35,7 @@ namespace WF_WebAdmin.Model AnswerD = answerD; CAnswer = cAnswer; IsValid = true; - UserProposition = "Admin"; + UserProposition = "Admin"; } public Quiz() {} From d45847c03a21f726a4d5da6dd3ada3539b9a6f27 Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:36:07 +0100 Subject: [PATCH 22/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Model/QuizModel.cs'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- WF-WebAdmin/WF-WebAdmin/Model/QuizModel.cs | 60 +++++++++++----------- 1 file changed, 30 insertions(+), 30 deletions(-) diff --git a/WF-WebAdmin/WF-WebAdmin/Model/QuizModel.cs b/WF-WebAdmin/WF-WebAdmin/Model/QuizModel.cs index ce5c8fa..ae49203 100644 --- a/WF-WebAdmin/WF-WebAdmin/Model/QuizModel.cs +++ b/WF-WebAdmin/WF-WebAdmin/Model/QuizModel.cs @@ -1,30 +1,30 @@ -using System.ComponentModel.DataAnnotations; - -namespace WF_WebAdmin.Model -{ - public class QuizModel - { - [Required] - [StringLength(200, ErrorMessage = "La question ne peut pas depasser les 200 caractère.")] - public string Question { get; set; } - - [Required] - [StringLength(50, ErrorMessage = "La réponse ne peut pas depasser les 50 caractère.")] - public string AnswerA { get; set; } - - [Required] - [StringLength(50, ErrorMessage = "La réponse ne peut pas depasser les 50 caractère.")] - public string AnswerB { get; set; } - - [Required] - [StringLength(50, ErrorMessage = "La réponse ne peut pas depasser les 50 caractère.")] - public string AnswerC { get; set; } - - [Required] - [StringLength(50, ErrorMessage = "La réponse ne peut pas depasser les 50 caractère.")] - public string AnswerD { get; set; } - - [Required] - public string CAnswer { get; set; } - } -} +using System.ComponentModel.DataAnnotations; + +namespace WF_WebAdmin.Model +{ + public class QuizModel + { + [Required] + [StringLength(200, ErrorMessage = "La question ne peut pas depasser les 200 caractère.")] + public string? Question { get; set; } + + [Required] + [StringLength(50, ErrorMessage = "La réponse ne peut pas depasser les 50 caractère.")] + public string AnswerA { get; set; } + + [Required] + [StringLength(50, ErrorMessage = "La réponse ne peut pas depasser les 50 caractère.")] + public string AnswerB { get; set; } + + [Required] + [StringLength(50, ErrorMessage = "La réponse ne peut pas depasser les 50 caractère.")] + public string AnswerC { get; set; } + + [Required] + [StringLength(50, ErrorMessage = "La réponse ne peut pas depasser les 50 caractère.")] + public string AnswerD { get; set; } + + [Required] + public string CAnswer { get; set; } + } +} From 925528a92210147fa9907d58b89681d1be7edc70 Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:36:51 +0100 Subject: [PATCH 23/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Model/QuizModel.cs'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- WF-WebAdmin/WF-WebAdmin/Model/QuizModel.cs | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/WF-WebAdmin/WF-WebAdmin/Model/QuizModel.cs b/WF-WebAdmin/WF-WebAdmin/Model/QuizModel.cs index ae49203..26ec722 100644 --- a/WF-WebAdmin/WF-WebAdmin/Model/QuizModel.cs +++ b/WF-WebAdmin/WF-WebAdmin/Model/QuizModel.cs @@ -10,21 +10,21 @@ namespace WF_WebAdmin.Model [Required] [StringLength(50, ErrorMessage = "La réponse ne peut pas depasser les 50 caractère.")] - public string AnswerA { get; set; } + public string? AnswerA { get; set; } [Required] [StringLength(50, ErrorMessage = "La réponse ne peut pas depasser les 50 caractère.")] - public string AnswerB { get; set; } + public string? AnswerB { get; set; } [Required] [StringLength(50, ErrorMessage = "La réponse ne peut pas depasser les 50 caractère.")] - public string AnswerC { get; set; } + public string? AnswerC { get; set; } [Required] [StringLength(50, ErrorMessage = "La réponse ne peut pas depasser les 50 caractère.")] - public string AnswerD { get; set; } + public string? AnswerD { get; set; } [Required] - public string CAnswer { get; set; } + public string? CAnswer { get; set; } } } From 6e4f1d8398d05d3f19504ec894ff05fcb230d91c Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:37:16 +0100 Subject: [PATCH 24/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Model/Quote.cs'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- WF-WebAdmin/WF-WebAdmin/Model/Quote.cs | 102 ++++++++----------------- 1 file changed, 33 insertions(+), 69 deletions(-) diff --git a/WF-WebAdmin/WF-WebAdmin/Model/Quote.cs b/WF-WebAdmin/WF-WebAdmin/Model/Quote.cs index ffc7f05..df14e88 100644 --- a/WF-WebAdmin/WF-WebAdmin/Model/Quote.cs +++ b/WF-WebAdmin/WF-WebAdmin/Model/Quote.cs @@ -1,69 +1,33 @@ -using Microsoft.AspNetCore.DataProtection.KeyManagement; - -namespace WF_WebAdmin.Model -{ - public class Quote - { - public int Id { get; set; } - public string Content { get; set; } - public int Like { get; set; } - public string Langue { get; set; } - public string Charac { get; set; } - public string ImgPath { get; set; } - public string TitleSrc { get; set; } - public DateTime DateSrc { get; set; } - public string UserProposition { get; set; } - public bool IsValid { get; set; } - - public Quote(int id, string content, string charac, string imgPath, string titleSrc, DateTime dateSrc, int like, string langue, string userProposition, bool isvalid) - { - Id = id; - Content = content; - Charac = charac; - ImgPath = imgPath; - TitleSrc = titleSrc; - DateSrc = dateSrc; - Like = like; - Langue = langue; - UserProposition = userProposition; - IsValid = isvalid; - } - /* - public int Id { get; set; } - public string Content { get; set; } - public int Likes { get; set; } - public string Langue { get; set; } - public bool IsValide { get; set; } - public string? Reason { get; set; } - public int IdCaracter { get; set; } - public int IdSource { get; set; } - public int? IdUserVerif { get; set; } - - public Quote(int id, string content, int likes, string langue, bool isValide, string? reason, int idCaracter, int idSource, int idUserVerif) - { - Id = id; - Content = content; - Likes = likes; - Langue = langue; - IsValide = isValide; - Reason = reason; - IdCaracter = idCaracter; - IdSource = idSource; - IdUserVerif = idUserVerif; - } - - public Quote(int id, string content, int likes, string langue, bool isValide, string? reason, int idCaracter, int idSource, int? idUserVerif) - { - Id = id; - Content = content; - Likes = likes; - Langue = langue; - IsValide = isValide; - Reason = reason; - IdCaracter = idCaracter; - IdSource = idSource; - IdUserVerif = idUserVerif; - } - */ - } -} +using Microsoft.AspNetCore.DataProtection.KeyManagement; + +namespace WF_WebAdmin.Model +{ + public class Quote + { + public int Id { get; set; } + public string Content { get; set; } + public int Like { get; set; } + public string Langue { get; set; } + public string Charac { get; set; } + public string ImgPath { get; set; } + public string TitleSrc { get; set; } + public DateTime DateSrc { get; set; } + public string UserProposition { get; set; } + public bool IsValid { get; set; } + + public Quote(int id, string content, string charac, string imgPath, string titleSrc, DateTime dateSrc, int like, string langue, string userProposition, bool isvalid) + { + Id = id; + Content = content; + Charac = charac; + ImgPath = imgPath; + TitleSrc = titleSrc; + DateSrc = dateSrc; + Like = like; + Langue = langue; + UserProposition = userProposition; + IsValid = isvalid; + } + + } +} From 1c7397fe8764234b979aa721b0efe91c457419f2 Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:38:27 +0100 Subject: [PATCH 25/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Model/QuoteModel.cs'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- WF-WebAdmin/WF-WebAdmin/Model/QuoteModel.cs | 54 ++++++++++----------- 1 file changed, 27 insertions(+), 27 deletions(-) diff --git a/WF-WebAdmin/WF-WebAdmin/Model/QuoteModel.cs b/WF-WebAdmin/WF-WebAdmin/Model/QuoteModel.cs index 1db3196..6a8ba04 100644 --- a/WF-WebAdmin/WF-WebAdmin/Model/QuoteModel.cs +++ b/WF-WebAdmin/WF-WebAdmin/Model/QuoteModel.cs @@ -1,27 +1,27 @@ -using System.ComponentModel.DataAnnotations; - -namespace WF_WebAdmin.Model -{ - public class QuoteModel - { - public int Id { get; set; } - - [Required] - [StringLength(300, ErrorMessage = "La citation ne peut pas dépasser les 300 caractère.")] - public string Content { get; set; } - - public int Like { get; set; } - - [Required] - [StringLength(2, ErrorMessage = "La langue ne peut pas dépasser 2 caractère.")] - public string Langue { get; set; } - - - public string Charac { get; set; } - public string ImgPath { get; set; } - public string TitleSrc { get; set; } - public DateTime DateSrc { get; set; } - public string UserProposition { get; set; } - public bool IsValid { get; set; } - } -} +using System.ComponentModel.DataAnnotations; + +namespace WF_WebAdmin.Model +{ + public class QuoteModel + { + public int Id { get; set; } + + [Required] + [StringLength(300, ErrorMessage = "La citation ne peut pas dépasser les 300 caractère.")] + public string? Content { get; set; } + + public int Like { get; set; } + + [Required] + [StringLength(2, ErrorMessage = "La langue ne peut pas dépasser 2 caractère.")] + public string? Langue { get; set; } + + + public string? Charac { get; set; } + public string? ImgPath { get; set; } + public string? TitleSrc { get; set; } + public DateTime DateSrc { get; set; } + public string? UserProposition { get; set; } + public bool IsValid { get; set; } + } +} From 8e700eeca2b59293643f8b2876c29daff6032eda Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:39:06 +0100 Subject: [PATCH 26/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Model/Source.cs'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- WF-WebAdmin/WF-WebAdmin/Model/Source.cs | 22 +++++++++++----------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/WF-WebAdmin/WF-WebAdmin/Model/Source.cs b/WF-WebAdmin/WF-WebAdmin/Model/Source.cs index 99c390a..0c68db3 100644 --- a/WF-WebAdmin/WF-WebAdmin/Model/Source.cs +++ b/WF-WebAdmin/WF-WebAdmin/Model/Source.cs @@ -1,11 +1,11 @@ -namespace WF_WebAdmin.Model -{ - public class Source - { - public int id_source { get; set; } - - public string title { get; set; } - - public int date { get; set; } - } -} +namespace WF_WebAdmin.Model +{ + public class Source + { + public int id_source { get; set; } + + public string? title { get; set; } + + public int date { get; set; } + } +} From 52b377fef8e8884b601f4954a2c9d87af498f687 Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:39:51 +0100 Subject: [PATCH 27/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Model/User.cs'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- WF-WebAdmin/WF-WebAdmin/Model/User.cs | 52 +++++++++++++-------------- 1 file changed, 26 insertions(+), 26 deletions(-) diff --git a/WF-WebAdmin/WF-WebAdmin/Model/User.cs b/WF-WebAdmin/WF-WebAdmin/Model/User.cs index 9e398dd..5916a3f 100644 --- a/WF-WebAdmin/WF-WebAdmin/Model/User.cs +++ b/WF-WebAdmin/WF-WebAdmin/Model/User.cs @@ -1,26 +1,26 @@ -namespace WF_WebAdmin.Model -{ - public class User - { - public int Id { get; set; } - public string Image { get; set; } - public string Name { get; set; } - public string Email { get; set; } - public DateTime DateCreation { get; set; } - - public Boolean IsAdmin { get; set; } - - public List Comments { get; set; } - - public User(string image, string name, string email, DateTime dateCreation, bool isAdmin) - { - this.Image = image; - this.Name = name; - this.Email = email; - this.DateCreation = dateCreation; - IsAdmin = isAdmin; - } - - public User() { } - } -} +namespace WF_WebAdmin.Model +{ + public class User + { + public int Id { get; set; } + public string? Image { get; set; } + public string Name { get; set; } + public string Email { get; set; } + public DateTime DateCreation { get; set; } + + public Boolean IsAdmin { get; set; } + + public List? Comments { get; set; } + + public User(string image, string name, string email, DateTime dateCreation, bool isAdmin) + { + this.Image = image; + this.Name = name; + this.Email = email; + this.DateCreation = dateCreation; + IsAdmin = isAdmin; + } + + public User() { } + } +} From 7fe7395d9e735e9d448a4f6af5b9a6dbf09bd505 Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:40:23 +0100 Subject: [PATCH 28/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Model/UserLogin.cs'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- WF-WebAdmin/WF-WebAdmin/Model/UserLogin.cs | 44 +++++++++++----------- 1 file changed, 22 insertions(+), 22 deletions(-) diff --git a/WF-WebAdmin/WF-WebAdmin/Model/UserLogin.cs b/WF-WebAdmin/WF-WebAdmin/Model/UserLogin.cs index b8f12b1..99c0121 100644 --- a/WF-WebAdmin/WF-WebAdmin/Model/UserLogin.cs +++ b/WF-WebAdmin/WF-WebAdmin/Model/UserLogin.cs @@ -1,22 +1,22 @@ -using System; -namespace WF_WebAdmin.Model -{ - public class UserLogin - { - public int Id { get; set; } - public string Image { get; set; } - public string Name { get; set;} - public Boolean IsAdmin { get; set; } - public string Mdp { get; set; } - public UserLogin(int id,string image, string name, bool isAdmin, string mdp) - { - Id = id; - this.Image = image; - this.Name = name; - this.IsAdmin = isAdmin; - this.Mdp = mdp; - } - - public UserLogin() { } - } -} +using System; +namespace WF_WebAdmin.Model +{ + public class UserLogin + { + public int Id { get; set; } + public string? Image { get; set; } + public string Name { get; set;} + public Boolean IsAdmin { get; set; } + public string Mdp { get; set; } + public UserLogin(int id,string image, string name, bool isAdmin, string mdp) + { + Id = id; + this.Image = image; + this.Name = name; + this.IsAdmin = isAdmin; + this.Mdp = mdp; + } + + public UserLogin() { } + } +} From d735893b9dc6f65fda2d6fd3c90b5294eacfbf92 Mon Sep 17 00:00:00 2001 From: Louis GUICHARD-MONTGUERS Date: Sat, 8 Feb 2025 19:41:59 +0100 Subject: [PATCH 29/30] =?UTF-8?q?Mise=20=C3=A0=20jour=20de=20'WF-WebAdmin/?= =?UTF-8?q?WF-WebAdmin/Pages/Accueil.razor.cs'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../WF-WebAdmin/Pages/Accueil.razor.cs | 84 +++++++++---------- 1 file changed, 42 insertions(+), 42 deletions(-) diff --git a/WF-WebAdmin/WF-WebAdmin/Pages/Accueil.razor.cs b/WF-WebAdmin/WF-WebAdmin/Pages/Accueil.razor.cs index 93c7fd9..28f02a6 100644 --- a/WF-WebAdmin/WF-WebAdmin/Pages/Accueil.razor.cs +++ b/WF-WebAdmin/WF-WebAdmin/Pages/Accueil.razor.cs @@ -1,42 +1,42 @@ -using Blazorise.DataGrid; -using Microsoft.AspNetCore.Components; -using Microsoft.Extensions.Localization; -using System.Security.Claims; -using WF_WebAdmin.Model; - - -namespace WF_WebAdmin.Pages -{ - public partial class Accueil - { - private Quote[] Dailyquote; - [Inject] - public ILogger Logger { get; set; } - - [Inject] - public HttpClient Http { get; set; } - - [Inject] - public NavigationManager NavigationManager { get; set; } - - [Inject] - public IStringLocalizer Localizer { get; set; } - - - /// - /// This method is called during the initialization of the Blazor component. - /// It is asynchronous and is used to load data or perform actions before the component is rendered. - /// - protected override async Task OnInitializedAsync() - { - Dailyquote = await Http.GetFromJsonAsync($"{NavigationManager.BaseUri}fake-dataDailyQuote.json"); - - } - private void RandomDailyquote() - { - //fonction a compléter - LoggerSaveStub.Log(Logger, LogLevel.Information, "Random change of quote of the day"); - } - } -} - +using Blazorise.DataGrid; +using Microsoft.AspNetCore.Components; +using Microsoft.Extensions.Localization; +using System.Security.Claims; +using WF_WebAdmin.Model; + + +namespace WF_WebAdmin.Pages +{ + public partial class Accueil + { + private Quote[]? Dailyquote; + [Inject] + public ILogger? Logger { get; set; } + + [Inject] + public HttpClient? Http { get; set; } + + [Inject] + public NavigationManager? NavigationManager { get; set; } + + [Inject] + public IStringLocalizer? Localizer { get; set; } + + + /// + /// This method is called during the initialization of the Blazor component. + /// It is asynchronous and is used to load data or perform actions before the component is rendered. + /// + protected override async Task OnInitializedAsync() + { + Dailyquote = await Http.GetFromJsonAsync($"{NavigationManager.BaseUri}fake-dataDailyQuote.json"); + + } + private void RandomDailyquote() + { + //fonction a compléter + LoggerSaveStub.Log(Logger, LogLevel.Information, "Random change of quote of the day"); + } + } +} + From 9dcb5418160bf2d7ad1474273084e892238c1139 Mon Sep 17 00:00:00 2001 From: Kentin BRONGNIART Date: Sat, 8 Feb 2025 21:13:09 +0100 Subject: [PATCH 30/30] debut graph --- .../WF-WebAdmin/Pages/ComposentComplex.razor | 14 +++ .../Pages/ComposentComplex.razor.cs | 92 +++++++++++++++++++ WF-WebAdmin/WF-WebAdmin/Program.cs | 3 + WF-WebAdmin/WF-WebAdmin/Shared/NavMenu.razor | 5 + WF-WebAdmin/WF-WebAdmin/WF-WebAdmin.csproj | 1 + .../wwwroot/fake-dataCommentary.json | 2 +- 6 files changed, 116 insertions(+), 1 deletion(-) create mode 100644 WF-WebAdmin/WF-WebAdmin/Pages/ComposentComplex.razor create mode 100644 WF-WebAdmin/WF-WebAdmin/Pages/ComposentComplex.razor.cs diff --git a/WF-WebAdmin/WF-WebAdmin/Pages/ComposentComplex.razor b/WF-WebAdmin/WF-WebAdmin/Pages/ComposentComplex.razor new file mode 100644 index 0000000..ba982d0 --- /dev/null +++ b/WF-WebAdmin/WF-WebAdmin/Pages/ComposentComplex.razor @@ -0,0 +1,14 @@ +@page "/graph" +@using Syncfusion.Blazor.Charts + + + + + + + + + + + + diff --git a/WF-WebAdmin/WF-WebAdmin/Pages/ComposentComplex.razor.cs b/WF-WebAdmin/WF-WebAdmin/Pages/ComposentComplex.razor.cs new file mode 100644 index 0000000..5d22acb --- /dev/null +++ b/WF-WebAdmin/WF-WebAdmin/Pages/ComposentComplex.razor.cs @@ -0,0 +1,92 @@ +using Microsoft.AspNetCore.Components; +using MudBlazor; +using Syncfusion.Blazor.Charts.Chart.Internal; +using System; +using System.Collections.Generic; +using System.Globalization; +using System.Linq; +using System.Threading.Tasks; +using WF_WebAdmin.Model; +using WF_WebAdmin.Service; + + +namespace WF_WebAdmin.Pages +{ + public class SalesInfo + { + public string Month { get; set; } + public double SalesValue { get; set; } + } + public partial class ComposentComplex : ComponentBase + { + [Inject] public ICommentaryService CommentaryService { get; set; } = default!; + + public List Labels { get; set; } = new(); + public List ChartData { get; set; } = new(); + public List AvailableYears { get; set; } = new(); + public int SelectedYear { get; set; } + + private List AllComments = new(); + + + public List Sales = new List + { + new SalesInfo { Month = "Jan", SalesValue = 35 }, + new SalesInfo { Month = "Feb", SalesValue = 28 }, + new SalesInfo { Month = "Mar", SalesValue = 34 }, + new SalesInfo { Month = "Apr", SalesValue = 28 }, + new SalesInfo { Month = "May", SalesValue = 40 }, + new SalesInfo { Month = "Jun", SalesValue = 32 }, + new SalesInfo { Month = "Jul", SalesValue = 35 }, + new SalesInfo { Month = "Aug", SalesValue = 55 }, + new SalesInfo { Month = "Sep", SalesValue = 38 }, + new SalesInfo { Month = "Oct", SalesValue = 30 }, + new SalesInfo { Month = "Nov", SalesValue = 25 }, + new SalesInfo { Month = "Dec", SalesValue = 32 } + }; + protected override async Task OnInitializedAsync() + { + // Charger tous les commentaires + AllComments = await CommentaryService.GetCommentsAsync(); + + if (!AllComments.Any()) + { + Labels = new List { "Aucun commentaire" }; + ChartData = new List { new double[] { 0 } }; + return; + } + + AvailableYears = AllComments + .Select(c => c.DateCreation.Year) + .Distinct() + .OrderBy(y => y) + .ToList(); + + SelectedYear = AvailableYears.Max(); + + UpdateChartData(SelectedYear); + } + private void UpdateChartData(int newYear) + { + SelectedYear = newYear; + + var filteredComments = AllComments + .Where(c => c.DateCreation.Year == SelectedYear) + .ToList(); + + if (!filteredComments.Any()) + { + Labels = new List { "Aucun commentaire" }; + ChartData = new List { new double[] { 0 } }; + return; + } + + foreach (var sale in Sales) + { + sale.SalesValue = filteredComments.Count(c => c.DateCreation.Month.ToString("MMM", CultureInfo.InvariantCulture) == sale.Month); + } + + } + + } +} diff --git a/WF-WebAdmin/WF-WebAdmin/Program.cs b/WF-WebAdmin/WF-WebAdmin/Program.cs index 765abff..527dcba 100644 --- a/WF-WebAdmin/WF-WebAdmin/Program.cs +++ b/WF-WebAdmin/WF-WebAdmin/Program.cs @@ -14,6 +14,7 @@ using Blazored.Modal; using WF_WebAdmin.Service; using Microsoft.Extensions.Logging; using MudBlazor.Services; +using Syncfusion.Blazor; [assembly: RootNamespace("WF_WebAdmin")] @@ -32,6 +33,8 @@ builder.Services.AddScoped(); builder.Services.AddMudServices(); builder.Logging.AddConfiguration(builder.Configuration.GetSection("Logging")); +builder.Services.AddSyncfusionBlazor(); + builder.Services .AddBlazorise() .AddBootstrapProviders() diff --git a/WF-WebAdmin/WF-WebAdmin/Shared/NavMenu.razor b/WF-WebAdmin/WF-WebAdmin/Shared/NavMenu.razor index a9174b8..9de0104 100644 --- a/WF-WebAdmin/WF-WebAdmin/Shared/NavMenu.razor +++ b/WF-WebAdmin/WF-WebAdmin/Shared/NavMenu.razor @@ -59,6 +59,11 @@ Stats commentaires + diff --git a/WF-WebAdmin/WF-WebAdmin/WF-WebAdmin.csproj b/WF-WebAdmin/WF-WebAdmin/WF-WebAdmin.csproj index 47115cb..f11e9db 100644 --- a/WF-WebAdmin/WF-WebAdmin/WF-WebAdmin.csproj +++ b/WF-WebAdmin/WF-WebAdmin/WF-WebAdmin.csproj @@ -18,6 +18,7 @@ + diff --git a/WF-WebAdmin/WF-WebAdmin/wwwroot/fake-dataCommentary.json b/WF-WebAdmin/WF-WebAdmin/wwwroot/fake-dataCommentary.json index 5b39c76..b77e700 100644 --- a/WF-WebAdmin/WF-WebAdmin/wwwroot/fake-dataCommentary.json +++ b/WF-WebAdmin/WF-WebAdmin/wwwroot/fake-dataCommentary.json @@ -143,7 +143,7 @@ "id_comment": 21, "quote": 7, "users": 21, - "dateC": "2024-8-30", + "dateC": "2024-08-30", "comment": "Belle pensée." }, {