12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 |
- using Azure;
- using Microsoft.AspNetCore.Mvc.RazorPages;
- using Microsoft.EntityFrameworkCore;
- using MTWorkHR.Core.Entities.Base;
- using MTWorkHR.Core.IDto;
- using MTWorkHR.Core.IRepositories.Base;
- using MTWorkHR.Infrastructure.Data;
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- namespace MTWorkHR.Infrastructure.Repositories
- {
- public class Repository<T> : IRepository<T> where T : Entity
- {
- protected readonly HRDataContext _context;
- private readonly DbSet<T> dbSet;
- public Repository(HRDataContext context)
- {
- _context = context;
- dbSet = context.Set<T>();
- }
- public async Task<T> AddAsync(T entity)
- {
- await _context.AddAsync(entity);
- await _context.SaveChangesAsync();
- return entity;
- }
- public async Task<IList<T>> AddRangeAsync(IList<T> entities)
- {
- await dbSet.AddRangeAsync(entities);
- return entities;
- }
- public async Task DeleteAsync(T entity)
- {
- dbSet.Remove(entity);
- }
- public async Task DeleteRangeAsync(IEnumerable<T> entities)
- {
- dbSet.RemoveRange(entities);
- }
- public async Task<Tuple<ICollection<T>, int>> GetAllAsync()
- {
- var query = dbSet.AsQueryable();
- var total = await query.CountAsync();
- return new Tuple<ICollection<T>, int>(await query.ToListAsync(), total);
- }
- //public virtual async Task<Tuple<ICollection<T>, int>> GetAllAsync(IPagingInputDto pagingInputDto)
- //{
- // //var query = dbSet.AsQueryable();
- // //if (pagingInputDto.HiddenFilter != null)
- // //{
- // // query = query.Where(pagingInputDto.HiddenFilter);
- // //}
- // //if (pagingInputDto.Filter != null)
- // //{
- // // var props = typeof(T).GetProperties().Where(prop => Attribute.IsDefined(prop, typeof(FilterAttribute)));
- // // var condition = "";
- // // foreach (var p in props)
- // // {
- // // condition = (condition == "" ? condition : condition + " || ") + p.Name + ".Contains(@0)";
- // // }
- // // query = query.Where(condition, pagingInputDto.Filter);
- // //}
- // //var order = query.OrderBy(pagingInputDto.OrderByField + " " + pagingInputDto.OrderType);
- // //var page = order.Skip((pagingInputDto.PageNumber * pagingInputDto.PageSize) - pagingInputDto.PageSize).Take(pagingInputDto.PageSize);
- // //var total = await query.CountAsync();
- // //return new Tuple<ICollection<T>, int>(await page.ToListAsync(), total);
- // throw new NotImplementedException();
- //}
- public async Task<T> GetByIdAsync(long id)
- {
- return await _context.Set<T>().FindAsync(id);
- }
- }
- }
|