Use shared page state classes
This commit is contained in:
@ -29,7 +29,7 @@
|
||||
</RadzenColumn>
|
||||
<RadzenColumn Size="12" SizeMD="6">
|
||||
<RadzenStack Orientation="Orientation.Horizontal" AlignItems="AlignItems.Center" JustifyContent="JustifyContent.End" Gap="0.5rem">
|
||||
<RadzenButton Icon="sync" Text="@syncText" Disabled="@(state != PrivatePageState.Idle)" Click="@SyncRegistriesAsync" ButtonStyle="ButtonStyle.Primary" />
|
||||
<RadzenButton Icon="sync" Text="@syncText" Disabled="@(state != SyncedPageState.Idle)" Click="@SyncRegistriesAsync" ButtonStyle="ButtonStyle.Primary" />
|
||||
</RadzenStack>
|
||||
</RadzenColumn>
|
||||
</RadzenRow>
|
||||
@ -38,7 +38,7 @@
|
||||
<RadzenAlert Visible="@hasError" AlertStyle="AlertStyle.Danger" Variant="Variant.Flat" Shade="Shade.Lighter" AllowClose="false">
|
||||
@errorMessage
|
||||
</RadzenAlert>
|
||||
<RadzenDataGrid TItem="Registry" Data="@registries" RowExpand="@RowExpandAsync" IsLoading="@(state != PrivatePageState.Idle)" AllowFiltering="true" AllowPaging="true" ShowPagingSummary="true" PageSizeOptions=@(new int[] { 5, 10, 20, 30 }) AllowSorting="true" ExpandMode="DataGridExpandMode.Single">
|
||||
<RadzenDataGrid TItem="Registry" Data="@registries" RowExpand="@RowExpandAsync" IsLoading="@(state != SyncedPageState.Idle)" AllowFiltering="true" AllowPaging="true" ShowPagingSummary="true" PageSizeOptions=@(new int[] { 5, 10, 20, 30 }) AllowSorting="true" ExpandMode="DataGridExpandMode.Single">
|
||||
<Template Context="registry">
|
||||
<RadzenDataGrid Data="@registry.Elements" AllowFiltering="true" AllowSorting="true">
|
||||
<Columns>
|
||||
@ -64,16 +64,8 @@
|
||||
</AuthorizedContent>
|
||||
|
||||
@code {
|
||||
enum PrivatePageState
|
||||
{
|
||||
Init,
|
||||
Loading,
|
||||
Idle,
|
||||
OperationWaiting
|
||||
}
|
||||
|
||||
IEnumerable<Registry> registries;
|
||||
PrivatePageState state;
|
||||
SyncedPageState state;
|
||||
string syncText = "...";
|
||||
bool hasError;
|
||||
string errorMessage;
|
||||
@ -84,16 +76,16 @@
|
||||
|
||||
if (firstRender)
|
||||
{
|
||||
ChangeState(PrivatePageState.Init);
|
||||
ChangeState(SyncedPageState.Init);
|
||||
|
||||
var finalState = PrivatePageState.Idle;
|
||||
var finalState = SyncedPageState.Idle;
|
||||
var state = await AuthenticationStateProvider.GetAuthenticationStateAsync();
|
||||
if (state.User.IsInRole(AppRole.ADMINISTRATOR_TYPE) || state.User.IsInRole(AppRole.OPERATOR_TYPE))
|
||||
{
|
||||
var operationInProgress = await HeadquartersService.HasActiveCampaignAsync(Campaign.CampaignType.ExportPrivateRegistryElements_15_7_0_1);
|
||||
if (operationInProgress)
|
||||
{
|
||||
finalState = PrivatePageState.OperationWaiting;
|
||||
finalState = SyncedPageState.SyncWaiting;
|
||||
}
|
||||
|
||||
CampaignManagementState.OnCampaignCreated += OnCampaignCreated;
|
||||
@ -108,13 +100,13 @@
|
||||
|
||||
async Task SyncRegistriesAsync()
|
||||
{
|
||||
if (state == PrivatePageState.OperationWaiting) return;
|
||||
if (state == SyncedPageState.SyncWaiting) return;
|
||||
|
||||
ChangeState(PrivatePageState.OperationWaiting);
|
||||
ChangeState(SyncedPageState.SyncWaiting);
|
||||
|
||||
if (await HeadquartersService.HasActiveCampaignAsync(Campaign.CampaignType.ExportPrivateRegistryElements_15_7_0_1))
|
||||
{
|
||||
ChangeState(PrivatePageState.Idle);
|
||||
ChangeState(SyncedPageState.Idle);
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -147,7 +139,7 @@
|
||||
});
|
||||
}
|
||||
|
||||
void ChangeState(PrivatePageState state)
|
||||
void ChangeState(SyncedPageState state)
|
||||
{
|
||||
if (this.state == state) return;
|
||||
|
||||
@ -161,16 +153,16 @@
|
||||
{
|
||||
switch (state)
|
||||
{
|
||||
case PrivatePageState.Init:
|
||||
case SyncedPageState.Init:
|
||||
syncText = "...";
|
||||
break;
|
||||
|
||||
case PrivatePageState.Loading:
|
||||
case PrivatePageState.Idle:
|
||||
case SyncedPageState.Loading:
|
||||
case SyncedPageState.Idle:
|
||||
syncText = "Синхронизировать";
|
||||
break;
|
||||
|
||||
case PrivatePageState.OperationWaiting:
|
||||
case SyncedPageState.SyncWaiting:
|
||||
syncText = "Идет синхронизация...";
|
||||
break;
|
||||
}
|
||||
@ -180,7 +172,7 @@
|
||||
{
|
||||
if (campaign.Type == Campaign.CampaignType.ExportPrivateRegistryElements_15_7_0_1)
|
||||
{
|
||||
InvokeAsync(() => ChangeState(PrivatePageState.OperationWaiting));
|
||||
InvokeAsync(() => ChangeState(SyncedPageState.SyncWaiting));
|
||||
}
|
||||
}
|
||||
|
||||
@ -194,7 +186,7 @@
|
||||
|
||||
async Task RefreshRegistries()
|
||||
{
|
||||
await InvokeAsync(() => ChangeState(PrivatePageState.Loading));
|
||||
await InvokeAsync(() => ChangeState(SyncedPageState.Loading));
|
||||
|
||||
var refreshedRegistries = await RegistryService.GetAllRegistriesAsync(false);
|
||||
|
||||
@ -202,7 +194,7 @@
|
||||
{
|
||||
registries = refreshedRegistries;
|
||||
|
||||
ChangeState(PrivatePageState.Idle);
|
||||
ChangeState(SyncedPageState.Idle);
|
||||
});
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user