Sinet.Universal.Admin/src/common/Sinet.Universal.Admin.RCL/Pages/App/User/View.razor

273 lines
16 KiB
Plaintext

@page "/app/user/view"
@page "/app/user/view/{Id}"
@using Sinet.Universal.Admin.RCL.Data.App.User
@using Sinet.Universal.Admin.RCL.Data.App.User.Dto
@inherits ProComponentBase
<MRow>
<MCol Md="8">
<MCard Height="298" class="pt-2 pb-2">
<MCardText>
<MRow>
<MCol Cols="@("auto")">
<div style="width:300px;" class="text-center">
@if (string.IsNullOrEmpty(UserData.HeadImg))
{
string color = UserData.Color;
<MAvatar Size="120" Color="@($"{color}-lighten-5")">
<span class="@($"{color}--text text-h3")">@UserData.SampleName</span>
</MAvatar>
}
else
{
<MAvatar Size="120">
<MImage Contain Src="@UserData.HeadImg" />
</MAvatar>
}
<h5 class="mt-1">@UserData.FullName</h5>
<span class="mt-1 text-caption">@UserData.Email</span>
<MRow NoGutters class="mt-4">
<MCol Md="6" class="text-center">
<h5>@UserData.Sales</h5>
<span class="text-body2">Monthly Sales</span>
</MCol>
<MCol Md="6" class="text-center">
<h5>@UserData.Profit</h5>
<span class="text-body2">Annual Profit</span>
</MCol>
</MRow>
</div>
</MCol>
<MDivider Vertical />
<MCol class="ml-3 d-flex flex-column">
<div class="mb-3 d-flex justify-space-between">
<span class="text-body2 neutral-lighten-1--text"><MIcon Small class="mr-2" Color="neutral-lighten-1">mdi-account-outline</MIcon>Username</span>
<span class="text-caption">@UserData.UserName</span>
</div>
<div class="mb-3 d-flex justify-space-between">
<span class="text-body2 neutral-lighten-1--text"><MIcon Small class="mr-2" Color="neutral-lighten-1">mdi-check</MIcon>Status</span>
<span class="text-caption">@UserData.Status</span>
</div>
<div class="mb-3 d-flex justify-space-between">
<span class="text-body2 neutral-lighten-1--text"><MIcon Small class="mr-2" Color="neutral-lighten-1">mdi-star-outline</MIcon>Role</span>
<span class="text-caption">@UserData.Role</span>
</div>
<div class="mb-3 d-flex justify-space-between">
<span class="text-body2 neutral-lighten-1--text"><MIcon Small class="mr-2" Color="neutral-lighten-1">mdi-flag-outline</MIcon>Country</span>
<span class="text-caption">@UserData.Country</span>
</div>
<div class="mb-3 d-flex justify-space-between">
<span class="text-body2 neutral-lighten-1--text"><MIcon Small class="mr-2" Color="neutral-lighten-1">mdi-phone-outline</MIcon>Contact</span>
<span class="text-caption">@UserData.Contact</span>
</div>
<div class="flex-grow-1 d-flex align-end">
<MButton MinWidth="100" class="primary rounded-pill">Edit</MButton>
<MButton Outlined MinWidth="100" Color="red" class="ml-6 rounded-pill">Delete</MButton>
</div>
</MCol>
</MRow>
</MCardText>
</MCard>
</MCol>
<MCol Md="4">
<MCard class="pa-2 fill-height d-flex flex-column justify-space-between">
<MCardText>
<div class="d-flex justify-space-between">
<h6>Current Plan</h6>
<MChip Small class="sample-green--text lighten-green"> @UserData.Plan </MChip>
</div>
<span class="mt-1 neutral-lighten-4--text">July 22, 2021</span>
<div class="mt-6 d-flex flex-column text-body2 neutral-lighten-1--text">
<span>5 Users</span>
<span class="mt-3">10 GB storage</span>
<span class="mt-3">Basic Support</span>
</div>
</MCardText>
<MCardActions class="d-flex justify-center">
<MButton Width="340" class="primary text-capitalize rounded-pill">Upgrade Plan</MButton>
</MCardActions>
</MCard>
</MCol>
</MRow>
<MRow>
<MCol Md="8">
<MCard>
<MCardTitle>
<MIcon Size=20 Color="sample-green" Class="mr-1">mdi-lock-open-outline</MIcon>
<span class="text-h6">Permission</span>
</MCardTitle>
<MCardSubtitle class="ml-6 text-btn neutral-lighten-4--text">
Permission according to roles
</MCardSubtitle>
<MCardText>
<MDataTable HideDefaultFooter Headers="_headers" TItem="PermissionDto" Items="_permissions" ItemKey="r => r.Module" Class="table-header-fill table-border-solid">
<HeaderColContent Context="header">
<span class="text-body neutral-lighten-1--text">@header.Text</span>
</HeaderColContent>
<ItemColContent>
@switch (context.Header.Value)
{
case nameof(PermissionDto.Module):
<span class="text-body neutral-lighten-2--text">@context.Value</span>
break;
case nameof(PermissionDto.Read):
<MCheckbox Class="mt-0" Color="primary" @bind-Value="context.Item.Read"></MCheckbox>
break;
case nameof(PermissionDto.Write):
<MCheckbox Class="mt-0" Color="primary" @bind-Value="context.Item.Write"></MCheckbox>
break;
case nameof(PermissionDto.Create):
<MCheckbox Class="mt-0" Color="primary" @bind-Value="context.Item.Create"></MCheckbox>
break;
case nameof(PermissionDto.Delete):
<MCheckbox Class="mt-0" Color="primary" @bind-Value="context.Item.Delete"></MCheckbox>
break;
default:
@context.Value
break;
}
</ItemColContent>
</MDataTable>
</MCardText>
</MCard>
</MCol>
<MCol Md="4">
<MCard class="pa-2">
<MCardTitle class="text-h8">
User Timeline
</MCardTitle>
<MCardText>
<MTimeline Dense class="mr-n2 ml-n10 pro-timeline-before divider-align-start m-timeline-flat">
<MTimelineItem Class="mt-0" Small Color="transparent">
<IconContent>
<MIcon class="sample-green--text">mdi-adjust</MIcon>
</IconContent>
<ChildContent>
<div class="d-flex justify-space-between align-center">
<span class="text-body">
12 Invoices have been paid
</span>
<span class="neutral-lighten-4--text">
12 min ago
</span>
</div>
<span class="text-body2 mt-1">
Invoices have been paid to the company.
</span>
<p class="mt-4 mb-0 d-flex align-center">
<img class="mr-1" width="20" src="" />
<span class="ml-2 neutral-lighten-2--text">invoice.pdf</span>
</p>
</ChildContent>
</MTimelineItem>
<MTimelineItem Class="mb-4" Small Color="transparent">
<IconContent>
<MIcon class="error--text">mdi-adjust</MIcon>
</IconContent>
<ChildContent>
<div class="d-flex justify-space-between align-center">
<span class="text-body">
Client Meeting
</span>
<span class="neutral-lighten-4--text">
45 min ago
</span>
</div>
<span class="text-body2 mt-1">
Project meeting with john @@10:15am.
</span>
<MListItem class="grow mt-4 pa-0">
<MListItemAvatar class="pa-0">
<MImage Src="/img/avatar/10.svg">
</MImage>
</MListItemAvatar>
<MListItemContent>
<MListItemTitle class="neutral-lighten-1--text">John Doe (Client)</MListItemTitle>
<MListItemSubtitle class="neutral-lighten-2--text">CEO of Infibeam</MListItemSubtitle>
</MListItemContent>
</MListItem>
</ChildContent>
</MTimelineItem>
<MTimelineItem Class="mb-4" Color="transparent" Small>
<IconContent>
<MIcon class="dark-yellow--text">mdi-adjust</MIcon>
</IconContent>
<ChildContent>
<div class="d-flex justify-space-between align-center">
<span class="text-body">
Create a new project for client
</span>
<span class="neutral-lighten-4--text">
2 days ago
</span>
</div>
<span class="text-body2 mt-1">
Add files to new design folder
</span>
</ChildContent>
</MTimelineItem>
</MTimeline>
</MCardText>
</MCard>
</MCol>
</MRow>
<Sinet.Universal.Admin.RCL.Pages.App.Invoice.Components.InvoiceList />
@code {
private List<DataTableHeader<PermissionDto>> _headers = new List<DataTableHeader<PermissionDto>>
{
new() { Text = "MODULE", Sortable = false, Value = nameof(PermissionDto.Module) },
new() { Text = "READ", Sortable = false, Value = nameof(PermissionDto.Read), Align = DataTableHeaderAlign.Center },
new() { Text = "WRITE", Sortable = false, Value = nameof(PermissionDto.Write), Align = DataTableHeaderAlign.Center },
new() { Text = "CREATE", Sortable = false, Value = nameof(PermissionDto.Create), Align = DataTableHeaderAlign.Center },
new() { Text = "DELETE", Sortable = false, Value = nameof(PermissionDto.Delete), Align = DataTableHeaderAlign.Center }
};
private List<PermissionDto> _permissions = UserService.GetPermissionsList();
private UserDto? _userData;
[Inject]
private NavigationManager NavigationManager { get; set; } = null!;
[CascadingParameter]
private IPageTabsProvider? PageTabsProvider { get; set; }
[Parameter]
public string? Id { get; set; }
public UserDto UserData
{
get { return _userData ?? UserService.GetList().First(); }
set { _userData = value; }
}
protected override void OnInitialized()
{
base.OnInitialized();
_userData = UserService.GetList().FirstOrDefault(u => u.Id == Id);
if (CurrentUser != null && _userData != null)
{
_userData.UserName = CurrentUser.Name;
_userData.Email = CurrentUser.Email;
_userData.Mobile = CurrentUser.PhoneNumber;
_userData.Role = CurrentUser.Roles.First();
}
UpdateTabTitle();
}
private void UpdateTabTitle()
{
PageTabsProvider?.UpdateTabTitle(NavigationManager.GetAbsolutePath(), () => T("View of {0}", UserData.FullName));
}
}