parent
45d832b79f
commit
d4421d6d7e
@ -0,0 +1,36 @@
|
|||||||
|
using System.ComponentModel.DataAnnotations;
|
||||||
|
|
||||||
|
namespace BlazorProject.Models;
|
||||||
|
|
||||||
|
public class ItemModel
|
||||||
|
{
|
||||||
|
public int Id { get; set; }
|
||||||
|
|
||||||
|
[Required]
|
||||||
|
[StringLength(50, ErrorMessage = "Le nom affiché ne doit pas dépasser 50 caractères.")]
|
||||||
|
public string DisplayName { get; set; }
|
||||||
|
|
||||||
|
[Required]
|
||||||
|
[StringLength(50, ErrorMessage = "Le nom ne doit pas dépasser 50 caractères.")]
|
||||||
|
[RegularExpression(@"^[a-z''-'\s]{1,50}$", ErrorMessage = "Seulement les caractères en minuscule sont acceptées.")]
|
||||||
|
public string Name { get; set; }
|
||||||
|
|
||||||
|
[Required]
|
||||||
|
[Range(1, 64)]
|
||||||
|
public int StackSize { get; set; }
|
||||||
|
|
||||||
|
[Required]
|
||||||
|
[Range(1, 125)]
|
||||||
|
public int MaxDurability { get; set; }
|
||||||
|
|
||||||
|
public List<string> EnchantCategories { get; set; }
|
||||||
|
|
||||||
|
public List<string> RepairWith { get; set; }
|
||||||
|
|
||||||
|
[Required]
|
||||||
|
[Range(typeof(bool), "true", "true", ErrorMessage = "Vous devez accepter les conditions.")]
|
||||||
|
public bool AcceptCondition { get; set; }
|
||||||
|
|
||||||
|
[Required(ErrorMessage = "L'image de l'item est obligatoire !")]
|
||||||
|
public byte[] ImageContent { get; set; }
|
||||||
|
}
|
@ -0,0 +1,69 @@
|
|||||||
|
@page "/add"
|
||||||
|
|
||||||
|
<h3>Add</h3>
|
||||||
|
|
||||||
|
<EditForm Model="@itemModel" OnValidSubmit="@HandleValidSubmit">
|
||||||
|
<DataAnnotationsValidator />
|
||||||
|
<ValidationSummary />
|
||||||
|
|
||||||
|
<p>
|
||||||
|
<label for="display-name">
|
||||||
|
Display name:
|
||||||
|
<InputText id="display-name" @bind-Value="itemModel.DisplayName" />
|
||||||
|
</label>
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
<label for="name">
|
||||||
|
Name:
|
||||||
|
<InputText id="name" @bind-Value="itemModel.Name" />
|
||||||
|
</label>
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
<label for="stack-size">
|
||||||
|
Stack size:
|
||||||
|
<InputNumber id="stack-size" @bind-Value="itemModel.StackSize" />
|
||||||
|
</label>
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
<label for="max-durability">
|
||||||
|
Max durability:
|
||||||
|
<InputNumber id="max-durability" @bind-Value="itemModel.MaxDurability" />
|
||||||
|
</label>
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
Enchant categories:
|
||||||
|
<div>
|
||||||
|
@foreach (var item in enchantCategories)
|
||||||
|
{
|
||||||
|
<label>
|
||||||
|
<input type="checkbox" @onchange="@(e => OnEnchantCategoriesChange(item, e.Value))" />@item
|
||||||
|
</label>
|
||||||
|
}
|
||||||
|
</div>
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
Repair with:
|
||||||
|
<div>
|
||||||
|
@foreach (var item in repairWith)
|
||||||
|
{
|
||||||
|
<label>
|
||||||
|
<input type="checkbox" @onchange="@(e => OnRepairWithChange(item, e.Value))" />@item
|
||||||
|
</label>
|
||||||
|
}
|
||||||
|
</div>
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
<label>
|
||||||
|
Item image:
|
||||||
|
<InputFile OnChange="@LoadImage" accept=".png" />
|
||||||
|
</label>
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
<label>
|
||||||
|
Accept Condition:
|
||||||
|
<InputCheckbox @bind-Value="itemModel.AcceptCondition" />
|
||||||
|
</label>
|
||||||
|
</p>
|
||||||
|
|
||||||
|
<button type="submit">Submit</button>
|
||||||
|
</EditForm>
|
@ -0,0 +1,125 @@
|
|||||||
|
using Blazored.LocalStorage;
|
||||||
|
using BlazorProject.Models;
|
||||||
|
using Microsoft.AspNetCore.Components;
|
||||||
|
using Microsoft.AspNetCore.Components.Forms;
|
||||||
|
using Microsoft.AspNetCore.Components.WebAssembly.Hosting;
|
||||||
|
|
||||||
|
namespace BlazorProject.Pages;
|
||||||
|
|
||||||
|
public partial class Add
|
||||||
|
{
|
||||||
|
[Inject]
|
||||||
|
public NavigationManager NavigationManager { get; set; }
|
||||||
|
|
||||||
|
[Inject]
|
||||||
|
public ILocalStorageService LocalStorage { get; set; }
|
||||||
|
|
||||||
|
[Inject]
|
||||||
|
public IWebAssemblyHostEnvironment WebHostEnvironment { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// The default enchant categories.
|
||||||
|
/// </summary>
|
||||||
|
private List<string> enchantCategories = new List<string>() { "armor", "armor_head", "armor_chest", "weapon", "digger", "breakable", "vanishable" };
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// The default repair with.
|
||||||
|
/// </summary>
|
||||||
|
private List<string> repairWith = new List<string>() { "oak_planks", "spruce_planks", "birch_planks", "jungle_planks", "acacia_planks", "dark_oak_planks", "crimson_planks", "warped_planks" };
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// The current item model
|
||||||
|
/// </summary>
|
||||||
|
private ItemModel itemModel = new()
|
||||||
|
{
|
||||||
|
EnchantCategories = new List<string>(),
|
||||||
|
RepairWith = new List<string>()
|
||||||
|
};
|
||||||
|
|
||||||
|
private async void HandleValidSubmit()
|
||||||
|
{
|
||||||
|
// Get the current data
|
||||||
|
var currentData = await LocalStorage.GetItemAsync<List<Item>>("data");
|
||||||
|
|
||||||
|
// Simulate the Id
|
||||||
|
itemModel.Id = currentData.Max(s => s.Id) + 1;
|
||||||
|
|
||||||
|
// Add the item to the current data
|
||||||
|
currentData.Add(new Item
|
||||||
|
{
|
||||||
|
Id = itemModel.Id,
|
||||||
|
DisplayName = itemModel.DisplayName,
|
||||||
|
Name = itemModel.Name,
|
||||||
|
RepairWith = itemModel.RepairWith,
|
||||||
|
EnchantCategories = itemModel.EnchantCategories,
|
||||||
|
MaxDurability = itemModel.MaxDurability,
|
||||||
|
StackSize = itemModel.StackSize,
|
||||||
|
CreatedDate = DateTime.Now
|
||||||
|
});
|
||||||
|
|
||||||
|
// Save the image
|
||||||
|
var imagePathInfo = new DirectoryInfo($"{WebHostEnvironment.BaseAddress}/images");
|
||||||
|
|
||||||
|
// Check if the folder "images" exist
|
||||||
|
if (!imagePathInfo.Exists)
|
||||||
|
{
|
||||||
|
imagePathInfo.Create();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Determine the image name
|
||||||
|
var fileName = new FileInfo($"{imagePathInfo}/{itemModel.Name}.png");
|
||||||
|
|
||||||
|
// Write the file content
|
||||||
|
await File.WriteAllBytesAsync(fileName.FullName, itemModel.ImageContent);
|
||||||
|
|
||||||
|
// Save the data
|
||||||
|
await LocalStorage.SetItemAsync("data", currentData);
|
||||||
|
NavigationManager.NavigateTo("List.razor");
|
||||||
|
}
|
||||||
|
|
||||||
|
private async Task LoadImage(InputFileChangeEventArgs e)
|
||||||
|
{
|
||||||
|
// Set the content of the image to the model
|
||||||
|
using (var memoryStream = new MemoryStream())
|
||||||
|
{
|
||||||
|
await e.File.OpenReadStream().CopyToAsync(memoryStream);
|
||||||
|
itemModel.ImageContent = memoryStream.ToArray();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void OnEnchantCategoriesChange(string item, object checkedValue)
|
||||||
|
{
|
||||||
|
if ((bool)checkedValue)
|
||||||
|
{
|
||||||
|
if (!itemModel.EnchantCategories.Contains(item))
|
||||||
|
{
|
||||||
|
itemModel.EnchantCategories.Add(item);
|
||||||
|
}
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (itemModel.EnchantCategories.Contains(item))
|
||||||
|
{
|
||||||
|
itemModel.EnchantCategories.Remove(item);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void OnRepairWithChange(string item, object checkedValue)
|
||||||
|
{
|
||||||
|
if ((bool)checkedValue)
|
||||||
|
{
|
||||||
|
if (!itemModel.RepairWith.Contains(item))
|
||||||
|
{
|
||||||
|
itemModel.RepairWith.Add(item);
|
||||||
|
}
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (itemModel.RepairWith.Contains(item))
|
||||||
|
{
|
||||||
|
itemModel.RepairWith.Remove(item);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,4 @@
|
|||||||
|
@page "/BlazorRoute"
|
||||||
|
@page "/DifferentBlazorRoute"
|
||||||
|
|
||||||
|
<h1>Blazor routing</h1>
|
After Width: | Height: | Size: 2.2 KiB |
After Width: | Height: | Size: 220 KiB |
After Width: | Height: | Size: 58 KiB |
Loading…
Reference in new issue