Add accounts page
This commit is contained in:
@ -10,14 +10,18 @@ using System.Security.Claims;
|
||||
|
||||
namespace Hcs.WebApp.Components.Shared
|
||||
{
|
||||
public abstract class SyncedPageBase<TData> : ComponentBase, IDisposable
|
||||
public abstract class DataPageBase<TData> : ComponentBase, IDisposable
|
||||
{
|
||||
protected SyncedPageState state;
|
||||
protected DataPageState state;
|
||||
protected IEnumerable<TData> data;
|
||||
protected string syncButtonText = "...";
|
||||
protected string parseButtonText = "...";
|
||||
|
||||
protected abstract Campaign.CampaignType CampaignType { get; }
|
||||
private readonly List<Campaign.CampaignType> campaignTypes = [];
|
||||
|
||||
protected abstract Campaign.CampaignType? SyncCampaignType { get; }
|
||||
|
||||
protected abstract Campaign.CampaignType? ParseCampaignType { get; }
|
||||
|
||||
[Inject]
|
||||
private AuthenticationStateProvider AuthenticationStateProvider { get; set; }
|
||||
@ -31,20 +35,34 @@ namespace Hcs.WebApp.Components.Shared
|
||||
[Inject]
|
||||
protected DialogService DialogService { get; set; }
|
||||
|
||||
protected override void OnInitialized()
|
||||
{
|
||||
campaignTypes.Clear();
|
||||
|
||||
if (SyncCampaignType.HasValue)
|
||||
{
|
||||
campaignTypes.Add(SyncCampaignType.Value);
|
||||
}
|
||||
if (ParseCampaignType.HasValue)
|
||||
{
|
||||
campaignTypes.Add(ParseCampaignType.Value);
|
||||
}
|
||||
}
|
||||
|
||||
protected override async Task OnAfterRenderAsync(bool firstRender)
|
||||
{
|
||||
if (firstRender)
|
||||
{
|
||||
ChangeState(SyncedPageState.Init);
|
||||
ChangeState(DataPageState.Init);
|
||||
|
||||
var finalState = SyncedPageState.Idle;
|
||||
var finalState = DataPageState.Idle;
|
||||
var state = await AuthenticationStateProvider.GetAuthenticationStateAsync();
|
||||
if (HasPermission(state.User))
|
||||
{
|
||||
var operationInProgress = await HeadquartersService.HasActiveCampaignAsync(CampaignType);
|
||||
var operationInProgress = await HeadquartersService.HasActiveCampaignsAsync(campaignTypes);
|
||||
if (operationInProgress)
|
||||
{
|
||||
finalState = SyncedPageState.SyncWaiting;
|
||||
finalState = DataPageState.DataWaiting;
|
||||
}
|
||||
|
||||
CampaignManagementState.OnCampaignCreated += OnCampaignCreated;
|
||||
@ -69,29 +87,29 @@ namespace Hcs.WebApp.Components.Shared
|
||||
|
||||
protected async Task SyncDataAsync()
|
||||
{
|
||||
if (state == SyncedPageState.SyncWaiting) return;
|
||||
if (state == DataPageState.DataWaiting) return;
|
||||
|
||||
ChangeState(SyncedPageState.SyncWaiting);
|
||||
ChangeState(DataPageState.DataWaiting);
|
||||
|
||||
if (await HeadquartersService.HasActiveCampaignAsync(CampaignType))
|
||||
if (await HeadquartersService.HasActiveCampaignsAsync(campaignTypes))
|
||||
{
|
||||
ChangeState(SyncedPageState.SyncWaiting);
|
||||
ChangeState(DataPageState.DataWaiting);
|
||||
}
|
||||
else
|
||||
{
|
||||
// TODO: Use user id
|
||||
var campaign = await HeadquartersService.InitiateCampaignAsync(CampaignType, "");
|
||||
var campaign = await HeadquartersService.InitiateCampaignAsync(SyncCampaignType!.Value, "");
|
||||
CampaignManagementState.EnqueueCampaign(campaign);
|
||||
}
|
||||
}
|
||||
|
||||
protected async Task ParseDataAsync()
|
||||
{
|
||||
if (state == SyncedPageState.SyncWaiting) return;
|
||||
if (state == DataPageState.DataWaiting) return;
|
||||
|
||||
if (await HeadquartersService.HasActiveCampaignAsync(CampaignType))
|
||||
if (await HeadquartersService.HasActiveCampaignsAsync(campaignTypes))
|
||||
{
|
||||
ChangeState(SyncedPageState.SyncWaiting);
|
||||
ChangeState(DataPageState.DataWaiting);
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -112,10 +130,10 @@ namespace Hcs.WebApp.Components.Shared
|
||||
|
||||
if (dialogResult != null)
|
||||
{
|
||||
ChangeState(SyncedPageState.SyncWaiting);
|
||||
ChangeState(DataPageState.DataWaiting);
|
||||
|
||||
// TODO: Use user id
|
||||
var campaign = await HeadquartersService.InitiateCampaignAsync(CampaignType, "", new CampaignParseArgs()
|
||||
var campaign = await HeadquartersService.InitiateCampaignAsync(ParseCampaignType!.Value, "", new CampaignParseArgs()
|
||||
{
|
||||
fileToParseId = (int)dialogResult
|
||||
});
|
||||
@ -124,7 +142,7 @@ namespace Hcs.WebApp.Components.Shared
|
||||
}
|
||||
}
|
||||
|
||||
private void ChangeState(SyncedPageState state)
|
||||
private void ChangeState(DataPageState state)
|
||||
{
|
||||
if (this.state == state) return;
|
||||
|
||||
@ -138,18 +156,18 @@ namespace Hcs.WebApp.Components.Shared
|
||||
{
|
||||
switch (state)
|
||||
{
|
||||
case SyncedPageState.Init:
|
||||
case DataPageState.Init:
|
||||
syncButtonText = "...";
|
||||
parseButtonText = "...";
|
||||
break;
|
||||
|
||||
case SyncedPageState.Loading:
|
||||
case SyncedPageState.Idle:
|
||||
case DataPageState.Loading:
|
||||
case DataPageState.Idle:
|
||||
syncButtonText = "Синхронизировать";
|
||||
parseButtonText = "Спарсить";
|
||||
break;
|
||||
|
||||
case SyncedPageState.SyncWaiting:
|
||||
case DataPageState.DataWaiting:
|
||||
syncButtonText = "Идет синхронизация...";
|
||||
parseButtonText = "Идет парсинг...";
|
||||
break;
|
||||
@ -158,15 +176,15 @@ namespace Hcs.WebApp.Components.Shared
|
||||
|
||||
private void OnCampaignCreated(Campaign campaign)
|
||||
{
|
||||
if (campaign.Type == CampaignType)
|
||||
if (campaignTypes.Contains(campaign.Type))
|
||||
{
|
||||
InvokeAsync(() => ChangeState(SyncedPageState.SyncWaiting));
|
||||
InvokeAsync(() => ChangeState(DataPageState.DataWaiting));
|
||||
}
|
||||
}
|
||||
|
||||
private void OnCampaignEnded(int campaignId, Campaign.CampaignType type, DateTime endedAt, string failureReason)
|
||||
{
|
||||
if (type == CampaignType)
|
||||
if (campaignTypes.Contains(type))
|
||||
{
|
||||
Task.Run(RefreshData);
|
||||
}
|
||||
@ -174,7 +192,7 @@ namespace Hcs.WebApp.Components.Shared
|
||||
|
||||
private async Task RefreshData()
|
||||
{
|
||||
await InvokeAsync(() => ChangeState(SyncedPageState.Loading));
|
||||
await InvokeAsync(() => ChangeState(DataPageState.Loading));
|
||||
|
||||
var refreshedData = await GetDataAsync();
|
||||
|
||||
@ -182,7 +200,7 @@ namespace Hcs.WebApp.Components.Shared
|
||||
{
|
||||
data = refreshedData;
|
||||
|
||||
ChangeState(SyncedPageState.Idle);
|
||||
ChangeState(DataPageState.Idle);
|
||||
});
|
||||
}
|
||||
}
|
||||
@ -1,10 +1,10 @@
|
||||
namespace Hcs.WebApp.Components.Shared
|
||||
{
|
||||
public enum SyncedPageState
|
||||
public enum DataPageState
|
||||
{
|
||||
Init,
|
||||
Loading,
|
||||
Idle,
|
||||
SyncWaiting
|
||||
DataWaiting
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user