mirror of
https://gitee.com/ThingsGateway/ThingsGateway.git
synced 2025-10-25 04:33:09 +08:00
103 lines
3.6 KiB
C#
103 lines
3.6 KiB
C#
#region copyright
|
||
//------------------------------------------------------------------------------
|
||
// 此代码版权声明为全文件覆盖,如有原作者特别声明,会在下方手动补充
|
||
// 此代码版权(除特别声明外的代码)归作者本人Diego所有
|
||
// 源代码使用协议遵循本仓库的开源协议及附加协议
|
||
// Gitee源代码仓库:https://gitee.com/diego2098/ThingsGateway
|
||
// Github源代码仓库:https://github.com/kimdiego2098/ThingsGateway
|
||
// 使用文档:https://diego2098.gitee.io/thingsgateway-docs/
|
||
// QQ群:605534569
|
||
//------------------------------------------------------------------------------
|
||
#endregion
|
||
|
||
using BlazorComponent;
|
||
|
||
using Masa.Blazor;
|
||
|
||
using Microsoft.AspNetCore.Components;
|
||
|
||
using SqlSugar;
|
||
|
||
using ThingsGateway.Admin.Blazor.Core;
|
||
using ThingsGateway.Admin.Core;
|
||
using ThingsGateway.Application;
|
||
|
||
namespace ThingsGateway.Blazor;
|
||
|
||
/// <summary>
|
||
/// 历史报警页面
|
||
/// </summary>
|
||
public partial class HistoryAlarmPage
|
||
{
|
||
private IAppDataTable _datatable;
|
||
|
||
|
||
AlarmWorker AlarmHostService { get; set; }
|
||
[Inject]
|
||
InitTimezone InitTimezone { get; set; }
|
||
|
||
HisPageInput SearchModel { get; set; } = new();
|
||
/// <summary>
|
||
/// <inheritdoc/>
|
||
/// </summary>
|
||
/// <returns></returns>
|
||
protected override async Task OnInitializedAsync()
|
||
{
|
||
AlarmHostService = ServiceHelper.GetBackgroundService<AlarmWorker>();
|
||
await base.OnInitializedAsync();
|
||
}
|
||
|
||
private async Task DatatableQuery()
|
||
{
|
||
await _datatable?.QueryClickAsync();
|
||
}
|
||
private async Task<SqlSugarPagedList<HistoryAlarm>> QueryCallAsync(HisPageInput input)
|
||
{
|
||
var result = await AlarmHostService.GetAlarmDbAsync();
|
||
if (result.IsSuccess)
|
||
{
|
||
return await Task.Run(async () =>
|
||
{
|
||
try
|
||
{
|
||
var query = result.Content.CopyNew().Queryable<HistoryAlarm>().
|
||
WhereIF(!input.DeviceName.IsNullOrEmpty(), a => a.DeviceName.Contains(input.DeviceName))
|
||
.WhereIF(!input.Name.IsNullOrEmpty(), a => a.Name.Contains(input.Name))
|
||
.WhereIF(input.StartTime != null, a => a.EventTime >= input.StartTime.Value.ToLocalTime())
|
||
.WhereIF(input.EndTime != null, a => a.EventTime <= input.EndTime.Value.ToLocalTime());
|
||
|
||
for (int i = 0; i < input.SortField.Count; i++)
|
||
{
|
||
query = query.OrderByIF(!string.IsNullOrEmpty(input.SortField[i]), $"{input.SortField[i]} {(input.SortDesc[i] ? "desc" : "asc")}");
|
||
}
|
||
var data = await query.ToPagedListAsync(input.Current, input.Size);
|
||
return data;
|
||
}
|
||
catch (Exception ex)
|
||
{
|
||
await InvokeAsync(async () => await PopupService.EnqueueSnackbarAsync("查询失败,请检查网络连接:" + ex.Message, AlertTypes.Warning));
|
||
return new()
|
||
{
|
||
Current = 1,
|
||
Size = 10,
|
||
Pages = 0,
|
||
Records = new List<HistoryAlarm>(),
|
||
Total = 0
|
||
};
|
||
}
|
||
});
|
||
}
|
||
else
|
||
{
|
||
await InvokeAsync(async () => await PopupService.EnqueueSnackbarAsync(result.Message, AlertTypes.Warning));
|
||
return new()
|
||
{
|
||
Current = 1,
|
||
Size = 10,
|
||
Pages = 0,
|
||
Records = new List<HistoryAlarm>(),
|
||
Total = 0
|
||
};
|
||
}
|
||
}
|
||
} |