68 lines
2.2 KiB
Plaintext
68 lines
2.2 KiB
Plaintext
@using MoonCore.Blazor.FlyonUi.Components
|
|
@using MoonlightServers.Frontend.UI.Components.Forms
|
|
@using MoonlightServers.Shared.Http.Requests.Admin.StarDockerImages
|
|
|
|
@inherits MoonCore.Blazor.FlyonUi.Modals.BaseModal
|
|
|
|
<div class="p-5">
|
|
<div class="flex items-center gap-4">
|
|
<div class="avatar avatar-placeholder max-sm:hidden">
|
|
<div class="border-base-content/20 rounded-box w-13 border-1">
|
|
<span class="icon-container text-xl"></span>
|
|
</div>
|
|
</div>
|
|
<div class="space-y-1">
|
|
<h3 class="text-base-content text-2xl font-semibold">Add a new docker image</h3>
|
|
<p class="text-base-content/80">Add a new docker image to the star</p>
|
|
</div>
|
|
</div>
|
|
<div class="mt-5">
|
|
<HandleForm @ref="HandleForm" Model="Form" OnValidSubmit="OnValidSubmit">
|
|
<div class="mt-2">
|
|
<label class="label-text">Display Name</label>
|
|
<input class="input" @bind="Form.DisplayName" type="text"/>
|
|
</div>
|
|
<div class="mt-2">
|
|
<label class="label-text">Identifier</label>
|
|
<input class="input" @bind="Form.Identifier" type="text"/>
|
|
</div>
|
|
<div class="mt-2">
|
|
<label class="label-text">Automatic pulling</label>
|
|
<Switch @bind-Value="Form.AutoPulling"/>
|
|
</div>
|
|
</HandleForm>
|
|
</div>
|
|
<div class="mt-5 flex justify-end">
|
|
<button @onclick="HideAsync" type="button" class="btn btn-secondary me-2">
|
|
Cancel
|
|
</button>
|
|
<WButton OnClick="SubmitAsync">
|
|
Create
|
|
</WButton>
|
|
</div>
|
|
</div>
|
|
|
|
@code
|
|
{
|
|
[Parameter] public Func<CreateStarDockerImageRequest, Task> OnSubmit { get; set; }
|
|
|
|
private CreateStarDockerImageRequest Form;
|
|
private HandleForm HandleForm;
|
|
|
|
protected override void OnInitialized()
|
|
{
|
|
// Set default values
|
|
Form = new()
|
|
{
|
|
AutoPulling = true
|
|
};
|
|
}
|
|
|
|
private async Task OnValidSubmit()
|
|
{
|
|
await OnSubmit.Invoke(Form);
|
|
await HideAsync();
|
|
}
|
|
|
|
private Task SubmitAsync() => HandleForm.SubmitAsync();
|
|
} |