Files

137 lines
6.6 KiB
Plaintext
Raw Permalink Normal View History

@using WatchIt.DTO.Models.Controllers.Media.Medium.Response
@using WatchIt.DTO.Models.Controllers.Roles.Role.Response
@using WatchIt.Website.Components.Subcomponents.Common
2024-10-10 02:34:26 +02:00
@using Blazorise.Components
@using WatchIt.DTO.Models.Controllers.People.Person
@using Blazorise.Extensions
@inherits Component
2024-10-10 02:34:26 +02:00
2024-10-19 21:14:38 +02:00
<div class="panel @(Class)">
2024-10-10 02:34:26 +02:00
@if (_loaded)
{
<div class="vstack gap-3">
<div class="container-grid">
<div class="row gx-2">
<div class="col align-self-center">
<h4 class="m-0"><strong>Creator roles</strong></h4>
</div>
@if (!_editingMode)
{
<div class="col-auto">
<button type="button" class="btn btn-secondary" disabled="@(Disabled)" @onclick="@(() => ActivateEditData())">Add</button>
2024-10-10 02:34:26 +02:00
</div>
}
else
{
<div class="col-auto">
<button type="button" class="btn btn-secondary" @onclick="@(CancelEditData)">Cancel</button>
2024-10-10 02:34:26 +02:00
</div>
<div class="col-auto">
<button type="submit" class="btn btn-secondary" disabled="@(_saving)" @onclick="@(SaveData)">
<LoadingButtonContent IsLoading="@(_saving)" Content="Save" LoadingContent="Saving..."/>
2024-10-10 02:34:26 +02:00
</button>
</div>
}
</div>
</div>
@if (!_editingMode)
{
if (_roles.IsNullOrEmpty())
{
<span class="text-center">No items</span>
}
else
{
<table class="table table-sm table-transparent">
<thead>
<tr>
<th scope="col">
Person
</th>
<th scope="col">
Role type
</th>
<th class="table-cell-fit" scope="col">
Actions
</th>
</tr>
</thead>
<tbody class="table-group-divider">
@foreach (Guid roleId in _roles.Keys)
{
RoleCreatorResponse role = _roles[roleId].Data;
PersonResponse person = _peopleDict[role.PersonId];
2024-10-10 02:34:26 +02:00
<tr>
<td class="align-middle">
@(person.Name)
2024-10-10 02:34:26 +02:00
</td>
<td class="align-middle">
@(_roleTypes[role.TypeId])
2024-10-10 02:34:26 +02:00
</td>
<td class="align-middle table-cell-fit">
<div class="hstack gap-1">
<button class="btn btn-outline-secondary btn-sm" type="button" disabled="@(Disabled || _roles[roleId].Deleting)" @onclick="@(() => ActivateEditData(roleId))"><i class="fas fa-edit"></i></button>
<button class="btn btn-outline-danger btn-sm" type="button" disabled="@(Disabled || _roles[roleId].Deleting)" @onclick="@(() => DeleteData(roleId))">
2024-10-10 02:34:26 +02:00
@if (_roles[roleId].Deleting)
{
<span class="spinner-border spinner-border-sm" role="status" aria-hidden="true"></span>
}
else
{
<i class="fa-solid fa-trash"></i>
}
</button>
</div>
</td>
</tr>
}
</tbody>
</table>
}
}
else
{
<EditForm Model="@(_roleRequest)">
2024-10-10 02:34:26 +02:00
<AntiforgeryToken/>
<div class="container-grid">
<div class="row form-group mb-1">
<label for="actorFormPeople" class="col-1 col-form-label">People:</label>
2024-10-10 02:34:26 +02:00
<div class="col">
<Autocomplete ElementId="actorFormPeople"
2024-10-10 02:34:26 +02:00
TItem="PersonResponse"
TValue="long"
Data="@(_peopleDict.Values)"
2024-10-10 02:34:26 +02:00
TextField="@(item => item.Name)"
ValueField="@(item => item.Id)"
@bind-SelectedValue="@(_roleRequest.PersonId)"
2024-10-10 02:34:26 +02:00
Placeholder="Search..."
Filter="AutocompleteFilter.Contains">
<NotFoundContent Context="not_found_context"> Sorry... @not_found_context was not found</NotFoundContent>
</Autocomplete>
</div>
</div>
<div class="row form-group my-1">
<label for="actorFormType" class="col-1 col-form-label">Type:</label>
2024-10-10 02:34:26 +02:00
<div class="col">
<InputSelect id="actorFormType" class="form-control" TValue="short" @bind-Value="@(_roleRequest.TypeId)">
2024-10-10 02:34:26 +02:00
@foreach (KeyValuePair<short, string> type in _roleTypes)
{
<option value="@(type.Key)">@(type.Value)</option>
}
</InputSelect>
</div>
</div>
</div>
</EditForm>
}
</div>
}
else
{
<Loading Color="@(Loading.Colors.Light)"/>
2024-10-10 02:34:26 +02:00
}
</div>