Как вызвать универсальный класс из универсального репозитория
Я хочу использовать универсальный класс для запроса списка нумерации страниц. Я нашел решение по этому URL: https://dotnetcultist.com/paging-in-entity-framework-core/?unapproved=181&moderation-hash=c64d661435dc84a39f046cc786888855
Как я могу назвать этот статический класс "CreateAsync" из PaginationList
public class PaginatedList<T>
{
public int CurrentPage { get; private set; }
public int From { get; private set; }
public List<T> Items { get; private set; }
public int PageSize { get; private set; }
public int To { get; private set; }
public int TotalCount { get; private set; }
public int TotalPages { get; private set; }
public PaginatedList(List<T> items, int count, int currentPage, int pageSize)
{
CurrentPage = currentPage;
TotalPages = (int)Math.Ceiling(count / (double)pageSize);
TotalCount = count;
PageSize = pageSize;
From = ((currentPage - 1) * pageSize) + 1;
To = (From + pageSize) - 1;
Items = items;
}
public bool HasPreviousPage
{
get
{
return (CurrentPage > 1);
}
}
public bool HasNextPage
{
get
{
return (CurrentPage < TotalPages);
}
}
public static async Task<PaginatedList<T>> CreateAsync(
IQueryable<T> source, int currentPage, int pageSize, string sortOn, string sortDirection)
{
var count = await source.CountAsync();
if (!string.IsNullOrEmpty(sortOn))
{
if (sortDirection.ToUpper() == "ASC")
source = source.OrderBy(sortOn);
else
source = source.OrderByDescending(sortOn);
}
source = source.Skip(
(currentPage - 1) * pageSize)
.Take(pageSize);
var items = await source.ToListAsync();
return new PaginatedList<T>(items, count, currentPage, pageSize);
}
}
И как я могу добавить этот класс в общий класс репозитория.
public abstract class RepositoryBase<T> : PaginatedList<T>, IRepositoryBase<T> where T : class
{
protected EasyDoctorContext RepositoryContext { get; set; }
protected PaginatedList<T> PaginatedList { get; set; }
public RepositoryBase(EasyDoctorContext repositoryContext)
{
this.RepositoryContext = repositoryContext;
}
public IQueryable<T> FindAll()
{
return this.RepositoryContext.Set<T>();
}
public IQueryable<T> FindByCondition(Expression<Func<T, bool>> expression)
{
return this.RepositoryContext.Set<T>()
.Where(expression);
}
public void Create(T entity)
{
this.RepositoryContext.Set<T>().Add(entity);
}
public void Update(T entity)
{
this.RepositoryContext.Set<T>().Update(entity);
}
public void Delete(T entity)
{
this.RepositoryContext.Set<T>().Remove(entity);
}
public async Task<Boolean> SaveAsync()
{
try
{
await this.RepositoryContext.SaveChangesAsync();
return true;
}
catch(DbUpdateException e)
{
string model = typeof(T).ToString();
DBExeptionLogger.SetDbErrorLog(model, e.InnerException.Message);
return false;
}
}
}
1 ответ
Решение
Попробуйте, соответствует ли приведенный ниже код вашему требованию:
public class RepositoryBase<T> : IRepositoryBase<T> where T : class
{
protected ApplicationDbContext RepositoryContext { get; set; }
public RepositoryBase(ApplicationDbContext repositoryContext)
{
this.RepositoryContext = repositoryContext;
}
public async Task<PaginatedList<T>> FindAll()
{
return await PaginatedList<T>.CreateAsync(this.RepositoryContext.Set<T>(),1,2,null, null);
}
}