mirror of
				https://gitee.com/ThingsGateway/ThingsGateway.git
				synced 2025-10-31 07:33:58 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			101 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			101 lines
		
	
	
		
			3.4 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 SqlSugar;
 | ||
| 
 | ||
| using ThingsGateway.Admin.Blazor.Core;
 | ||
| using ThingsGateway.Admin.Core;
 | ||
| using ThingsGateway.Application;
 | ||
| 
 | ||
| 
 | ||
| namespace ThingsGateway.Blazor;
 | ||
| /// <summary>
 | ||
| /// 时序库页面
 | ||
| /// </summary>
 | ||
| public partial class HistoryValuePage
 | ||
| {
 | ||
| 
 | ||
|     HisPageInput SearchModel { get; set; } = new();
 | ||
| 
 | ||
|     private IAppDataTable _datatable;
 | ||
|     HistoryValueWorker HistoryValueHostService { get; set; }
 | ||
|     /// <summary>
 | ||
|     /// <inheritdoc/>
 | ||
|     /// </summary>
 | ||
|     /// <returns></returns>
 | ||
|     protected override async Task OnInitializedAsync()
 | ||
|     {
 | ||
|         HistoryValueHostService = ServiceHelper.GetBackgroundService<HistoryValueWorker>();
 | ||
|         await base.OnInitializedAsync();
 | ||
|     }
 | ||
| 
 | ||
|     private async Task DatatableQuery()
 | ||
|     {
 | ||
|         await _datatable?.QueryClickAsync();
 | ||
|     }
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
|     private async Task<SqlSugarPagedList<HistoryValue>> QueryCallAsync(HisPageInput input)
 | ||
|     {
 | ||
|         var result = await HistoryValueHostService.GetHisDbAsync();
 | ||
|         if (result.IsSuccess)
 | ||
|         {
 | ||
|             try
 | ||
|             {
 | ||
|                 return await Task.Run(async () =>
 | ||
|                 {
 | ||
|                     var query = result.Content.CopyNew().Queryable<HistoryValue>()
 | ||
|                     .WhereIF(!input.Name.IsNullOrEmpty(), a => a.Name.Contains(input.Name))
 | ||
|                     .WhereIF(input.StartTime != null, a => a.CollectTime >= input.StartTime.Value)
 | ||
|                     .WhereIF(input.EndTime != null, a => a.CollectTime <= input.EndTime.Value);
 | ||
| 
 | ||
|                     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<HistoryValue>(),
 | ||
|                     Total = 0
 | ||
|                 };
 | ||
|             }
 | ||
|         }
 | ||
|         else
 | ||
|         {
 | ||
|             await InvokeAsync(async () => await PopupService.EnqueueSnackbarAsync(result.Message, AlertTypes.Warning));
 | ||
|             return new()
 | ||
|             {
 | ||
|                 Current = 1,
 | ||
|                 Size = 10,
 | ||
|                 Pages = 0,
 | ||
|                 Records = new List<HistoryValue>(),
 | ||
|                 Total = 0
 | ||
|             };
 | ||
|         }
 | ||
|     }
 | ||
| } | 
