using CMS.Plugin.HIAWms.Domain.WmsTask; 
using CMS.Plugin.HIAWms.EntityFrameworkCore.Extensions; 
using CmsQueryExtensions.Extension; 
using Microsoft.EntityFrameworkCore; 
using System.Linq.Dynamic.Core; 
using System.Linq.Expressions; 
using Volo.Abp.Domain.Repositories.EntityFrameworkCore; 
using Volo.Abp.EntityFrameworkCore; 
 
 
namespace CMS.Plugin.HIAWms.EntityFrameworkCore.Repositories; 
 
///  
/// Wms任务管理仓储实现 
///  
public class EfCoreWmsTaskRepository : EfCoreRepository, IWmsTaskRepository 
{ 
    ///  
    /// Initializes a new instance of the  class. 
    ///  
    /// The database context provider. 
    public EfCoreWmsTaskRepository(IDbContextProvider dbContextProvider) 
        : base(dbContextProvider) 
    { 
    } 
 
    ///  
    /// 按照名称查找Wms任务管理 
    ///  
    ///  
    ///  
    ///  
    public virtual async Task FindByNameAsync(string taskNo, CancellationToken cancellationToken = default) 
    { 
        return await (await GetDbSetAsync()) 
            .IncludeDetails() 
            .Where(x => !x.IsDeleted) 
            .OrderBy(t => t.Sort) 
            .FirstOrDefaultAsync(t => t.TaskNo == taskNo, GetCancellationToken(cancellationToken)); 
    } 
 
    ///  
    /// 验证名称是否存在Wms任务管理 
    ///  
    /// 校验值 
    ///  
    ///  
    public async Task NameExistAsync(string taskNo, Guid? id = null) 
    { 
        return await (await GetDbSetAsync()).WhereIf(id.HasValue, p => p.Id != id).Where(x => !x.IsDeleted).AnyAsync(x => x.TaskNo == taskNo); 
    } 
 
    ///  
    /// 获取最大排序Wms任务管理 
    ///  
    ///  
    public async Task GetMaxSortAsync() 
    { 
        var hasAny = await (await GetQueryableAsync()) 
            .Where(x => !x.IsDeleted).AnyAsync(); 
        if (!hasAny) 
        { 
            return 1; 
        } 
 
        var sort = await (await GetQueryableAsync()) 
            .Where(x => !x.IsDeleted).MaxAsync(x => x.Sort); 
        return sort + 1; 
    } 
 
    ///  
    /// 获取分页列表Wms任务管理 
    ///  
    ///  
    ///  
    ///  
    ///  
    ///  
    ///  
    ///  
    public async Task> GetListAsync(FunReturnResultModel>> whereConditions, string sorting = null, int maxResultCount = int.MaxValue, int skipCount = 0, bool includeDetails = false, CancellationToken cancellationToken = default) 
    { 
        return await (await GetDbSetAsync()) 
            .IncludeDetails(includeDetails) 
            .WhereIf(whereConditions != null, whereConditions.data) 
            .Where(x => !x.IsDeleted) 
            .OrderBy(sorting.IsNullOrEmpty() ? nameof(WmsTask.Sort) : sorting) 
            .PageBy(skipCount, maxResultCount) 
            .ToListAsync(GetCancellationToken(cancellationToken)); 
    } 
 
    ///  
    /// 获取总数Wms任务管理 
    ///  
    ///  
    ///  
    ///  
    public async Task GetCountAsync(FunReturnResultModel>> whereConditions, CancellationToken cancellationToken = default) 
    { 
        return await (await GetQueryableAsync()) 
            .WhereIf(whereConditions != null, whereConditions.data) 
            .Where(x => !x.IsDeleted) 
            .CountAsync(cancellationToken: GetCancellationToken(cancellationToken)); 
    } 
 
 
    ///  
    public override async Task> WithDetailsAsync() 
    { 
        return (await GetQueryableAsync()) 
            .Where(x => !x.IsDeleted).IncludeDetails(); 
    } 
}