OrderRepository.cs 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. using Hotline.Caching.Interfaces;
  2. using Hotline.FlowEngine.Workflows;
  3. using Hotline.Orders;
  4. using Hotline.Repository.SqlSugar.DataPermissions;
  5. using Hotline.Repository.SqlSugar.Extensions;
  6. using Hotline.Repository.SqlSugar.Ts;
  7. using Hotline.Settings;
  8. using Hotline.Settings.Hotspots;
  9. using Hotline.Settings.TimeLimits;
  10. using Hotline.Share.Dtos;
  11. using Hotline.Share.Dtos.FlowEngine.Workflow;
  12. using Hotline.Share.Dtos.Order;
  13. using Hotline.Share.Enums.Order;
  14. using Hotline.Tools;
  15. using MapsterMapper;
  16. using SqlSugar;
  17. using System.Reflection;
  18. using XF.Domain.Constants;
  19. using XF.Domain.Dependency;
  20. using XF.Domain.Repository;
  21. namespace Hotline.Repository.SqlSugar.Orders
  22. {
  23. public class OrderRepository : BaseRepositoryWorkflow<Order>, IOrderRepository, IScopeDependency
  24. {
  25. private readonly IDataPermissionFilterBuilder _dataPermissionFilterBuilder;
  26. public OrderRepository(ISugarUnitOfWork<HotlineDbContext> uow,
  27. IDataPermissionFilterBuilder dataPermissionFilterBuilder
  28. ) : base(uow, dataPermissionFilterBuilder)
  29. {
  30. _dataPermissionFilterBuilder = dataPermissionFilterBuilder;
  31. }
  32. public async Task<string> AddOrderNavAsync(Order order, CancellationToken cancellationToken)
  33. {
  34. //弥补AddNav方法没有自动指派到创建人
  35. order.AssignToCreator(_dataPermissionFilterBuilder.DataPermissionManager);
  36. await AddNav(order).Include(d => d.OrderExtension).ExecuteCommandAsync();
  37. return order.Id;
  38. }
  39. /// <summary>
  40. /// 工单词库批量删除
  41. /// </summary>
  42. /// <param name="ids"></param>
  43. /// <param name="cancellationToken"></param>
  44. /// <returns></returns>
  45. public async Task RemoveOrderWrodBatchAsync(List<string> ids, CancellationToken cancellationToken)
  46. {
  47. await Db.Deleteable<OrderWord>().In(x => x.Id, ids).ExecuteCommandAsync(cancellationToken);
  48. }
  49. /// <summary>
  50. /// 工单观察批量删除
  51. /// </summary>
  52. /// <param name="ids"></param>
  53. /// <param name="cancellationToken"></param>
  54. /// <returns></returns>
  55. public async Task RemoveOrderObserveBatchAsync(List<string> ids, CancellationToken cancellationToken)
  56. {
  57. await Db.Deleteable<OrderObserve>().In(x => x.Id, ids).ExecuteCommandAsync(cancellationToken);
  58. }
  59. /// <summary>
  60. /// 工单终结批量删除
  61. /// </summary>
  62. /// <param name="ids"></param>
  63. /// <param name="cancellationToken"></param>
  64. /// <returns></returns>
  65. public async Task RemoveOrderFinalityBatchAsync(List<string> ids, CancellationToken cancellationToken)
  66. {
  67. await Db.Deleteable<OrderFinality>().In(x => x.Id, ids).ExecuteCommandAsync(cancellationToken);
  68. }
  69. public async Task OrderScreenRevisionVisit(string VisitId, bool canHandle, CancellationToken cancellationToken)
  70. {
  71. await Db.Updateable<OrderVisit>().SetColumns(x => x.IsCanHandle == canHandle).Where(x => x.Id == VisitId).ExecuteCommandAsync(cancellationToken);
  72. }
  73. public async Task FileAsync(Order order, CancellationToken cancellationToken)
  74. {
  75. await Db.Updateable<Order>().SetColumns(x => x.FileJson == order.FileJson).Where(x => x.Id == order.Id).ExecuteCommandAsync(cancellationToken);
  76. }
  77. private static object GetPropertyValue(object obj, string property)
  78. {
  79. PropertyInfo propertyInfo = obj.GetType().GetProperty(property);
  80. return propertyInfo.GetValue(obj, null);
  81. }
  82. public async Task<object> HotPortJoinOrgStatistics(DateTime StartTime, DateTime EndTime)
  83. {
  84. //查询一级热点
  85. var hotSpotList = await Db.Queryable<Hotspot>().Where(x => string.IsNullOrEmpty(x.ParentId)).ToListAsync();
  86. List<dynamic>? listReturn = new List<dynamic>();
  87. foreach (var item in hotSpotList)
  88. {
  89. var table = await Db.Queryable<Order>()
  90. .LeftJoin<SystemOrganize>((it, o) => it.ActualHandleOrgCode.Substring(SqlFunc.MappingColumn<int>("0"), SqlFunc.MappingColumn<int>("6")) == o.Id)
  91. .Where((it, o) => it.StartTime >= StartTime && it.StartTime <= EndTime)
  92. .GroupBy((it, o) => new
  93. {
  94. CurrentHandleOrgCode = (it.ActualHandleOrgCode.Substring(SqlFunc.MappingColumn<int>("0"), SqlFunc.MappingColumn<int>("6"))),
  95. o.Name
  96. })
  97. .Select((it, o) => new
  98. {
  99. OrgCode = it.ActualHandleOrgCode.Substring(SqlFunc.MappingColumn<int>("0"), SqlFunc.MappingColumn<int>("6")),
  100. Count = SqlFunc.AggregateSum(SqlFunc.IIF(it.HotspotId.Substring(0, 2) == item.Id, 1, 0)),
  101. Key = item.Id,
  102. OrgName = o.Name,
  103. HotSorpName = item.HotSpotName
  104. }).ToPivotListAsync(x => x.Key, x => new { x.OrgCode, x.OrgName, x.HotSorpName }, x => x.Sum(x => x.Count));
  105. listReturn.AddRange(table);
  106. }
  107. return new { HotSpot = hotSpotList, Data = listReturn };
  108. }
  109. }
  110. public class OrderScreenRepository : BaseRepositoryWorkflow<OrderScreen>, IOrderScreenRepository, IScopeDependency
  111. {
  112. public OrderScreenRepository(ISugarUnitOfWork<HotlineDbContext> uow, IDataPermissionFilterBuilder dataPermissionFilterBuilder) : base(uow, dataPermissionFilterBuilder)
  113. {
  114. }
  115. }
  116. public class OrderDelayRepository : BaseRepositoryWorkflow<OrderDelay>, IOrderDelayRepository, IScopeDependency
  117. {
  118. public OrderDelayRepository(ISugarUnitOfWork<HotlineDbContext> uow, IDataPermissionFilterBuilder dataPermissionFilterBuilder) : base(uow, dataPermissionFilterBuilder)
  119. {
  120. }
  121. }
  122. }