123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141 |
- using Hotline.Caching.Interfaces;
- using Hotline.FlowEngine.Workflows;
- using Hotline.Orders;
- using Hotline.Repository.SqlSugar.DataPermissions;
- using Hotline.Repository.SqlSugar.Extensions;
- using Hotline.Repository.SqlSugar.Ts;
- using Hotline.Settings;
- using Hotline.Settings.Hotspots;
- using Hotline.Settings.TimeLimits;
- using Hotline.Share.Dtos;
- using Hotline.Share.Dtos.FlowEngine.Workflow;
- using Hotline.Share.Dtos.Order;
- using Hotline.Share.Enums.Order;
- using Hotline.Tools;
- using MapsterMapper;
- using SqlSugar;
- using System.Reflection;
- using XF.Domain.Constants;
- using XF.Domain.Dependency;
- using XF.Domain.Repository;
- namespace Hotline.Repository.SqlSugar.Orders
- {
- public class OrderRepository : BaseRepositoryWorkflow<Order>, IOrderRepository, IScopeDependency
- {
- private readonly IDataPermissionFilterBuilder _dataPermissionFilterBuilder;
- public OrderRepository(ISugarUnitOfWork<HotlineDbContext> uow,
- IDataPermissionFilterBuilder dataPermissionFilterBuilder
- ) : base(uow, dataPermissionFilterBuilder)
- {
- _dataPermissionFilterBuilder = dataPermissionFilterBuilder;
- }
- public async Task<string> AddOrderNavAsync(Order order, CancellationToken cancellationToken)
- {
- //弥补AddNav方法没有自动指派到创建人
- order.AssignToCreator(_dataPermissionFilterBuilder.DataPermissionManager);
- await AddNav(order).Include(d => d.OrderExtension).ExecuteCommandAsync();
- return order.Id;
- }
- /// <summary>
- /// 工单词库批量删除
- /// </summary>
- /// <param name="ids"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- public async Task RemoveOrderWrodBatchAsync(List<string> ids, CancellationToken cancellationToken)
- {
- await Db.Deleteable<OrderWord>().In(x => x.Id, ids).ExecuteCommandAsync(cancellationToken);
- }
- /// <summary>
- /// 工单观察批量删除
- /// </summary>
- /// <param name="ids"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- public async Task RemoveOrderObserveBatchAsync(List<string> ids, CancellationToken cancellationToken)
- {
- await Db.Deleteable<OrderObserve>().In(x => x.Id, ids).ExecuteCommandAsync(cancellationToken);
- }
- /// <summary>
- /// 工单终结批量删除
- /// </summary>
- /// <param name="ids"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- public async Task RemoveOrderFinalityBatchAsync(List<string> ids, CancellationToken cancellationToken)
- {
- await Db.Deleteable<OrderFinality>().In(x => x.Id, ids).ExecuteCommandAsync(cancellationToken);
- }
- public async Task OrderScreenRevisionVisit(string VisitId, bool canHandle, CancellationToken cancellationToken)
- {
- await Db.Updateable<OrderVisit>().SetColumns(x => x.IsCanHandle == canHandle).Where(x => x.Id == VisitId).ExecuteCommandAsync(cancellationToken);
- }
- public async Task FileAsync(Order order, CancellationToken cancellationToken)
- {
- await Db.Updateable<Order>().SetColumns(x => x.FileJson == order.FileJson).Where(x => x.Id == order.Id).ExecuteCommandAsync(cancellationToken);
- }
- private static object GetPropertyValue(object obj, string property)
- {
- PropertyInfo propertyInfo = obj.GetType().GetProperty(property);
- return propertyInfo.GetValue(obj, null);
- }
- public async Task<object> HotPortJoinOrgStatistics(DateTime StartTime, DateTime EndTime)
- {
- //查询一级热点
- var hotSpotList = await Db.Queryable<Hotspot>().Where(x => string.IsNullOrEmpty(x.ParentId)).ToListAsync();
- List<dynamic>? listReturn = new List<dynamic>();
- foreach (var item in hotSpotList)
- {
- var table = await Db.Queryable<Order>()
- .LeftJoin<SystemOrganize>((it, o) => it.ActualHandleOrgCode.Substring(SqlFunc.MappingColumn<int>("0"), SqlFunc.MappingColumn<int>("6")) == o.Id)
- .Where((it, o) => it.StartTime >= StartTime && it.StartTime <= EndTime)
- .GroupBy((it, o) => new
- {
- CurrentHandleOrgCode = (it.ActualHandleOrgCode.Substring(SqlFunc.MappingColumn<int>("0"), SqlFunc.MappingColumn<int>("6"))),
- o.Name
- })
- .Select((it, o) => new
- {
- OrgCode = it.ActualHandleOrgCode.Substring(SqlFunc.MappingColumn<int>("0"), SqlFunc.MappingColumn<int>("6")),
- Count = SqlFunc.AggregateSum(SqlFunc.IIF(it.HotspotId.Substring(0, 2) == item.Id, 1, 0)),
- Key = item.Id,
- OrgName = o.Name,
- HotSorpName = item.HotSpotName
- }).ToPivotListAsync(x => x.Key, x => new { x.OrgCode, x.OrgName, x.HotSorpName }, x => x.Sum(x => x.Count));
- listReturn.AddRange(table);
- }
- return new { HotSpot = hotSpotList, Data = listReturn };
- }
- }
- public class OrderScreenRepository : BaseRepositoryWorkflow<OrderScreen>, IOrderScreenRepository, IScopeDependency
- {
- public OrderScreenRepository(ISugarUnitOfWork<HotlineDbContext> uow, IDataPermissionFilterBuilder dataPermissionFilterBuilder) : base(uow, dataPermissionFilterBuilder)
- {
- }
- }
- public class OrderDelayRepository : BaseRepositoryWorkflow<OrderDelay>, IOrderDelayRepository, IScopeDependency
- {
- public OrderDelayRepository(ISugarUnitOfWork<HotlineDbContext> uow, IDataPermissionFilterBuilder dataPermissionFilterBuilder) : base(uow, dataPermissionFilterBuilder)
- {
- }
- }
- }
|