OrderRepository.cs 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Threading.Tasks;
  4. using AutoMapper;
  5. using Datory;
  6. using GxPress.Common.AppOptions;
  7. using GxPress.Common.Page;
  8. using GxPress.Common.Tools;
  9. using GxPress.Repository.Interface.Order;
  10. using GxPress.Request.Order;
  11. using Microsoft.Extensions.Options;
  12. namespace GxPress.Repository.Implement.Order
  13. {
  14. public class OrderRepository : IOrderRepository
  15. {
  16. private readonly Repository<Entity.Order.Order> _repository;
  17. private readonly IMapper _mapper;
  18. public OrderRepository(IOptionsMonitor<DatabaseOptions> dbOptionsAccessor, IMapper mapper)
  19. {
  20. var databaseType = StringUtils.ToEnum<DatabaseType>(dbOptionsAccessor.CurrentValue.DatabaseType, DatabaseType.MySql);
  21. var database = new Database(databaseType, dbOptionsAccessor.CurrentValue.ConnectionString);
  22. _repository = new Repository<Entity.Order.Order>(database);
  23. _mapper = mapper;
  24. }
  25. public IDatabase Database => _repository.Database;
  26. public string TableName => _repository.TableName;
  27. public List<TableColumn> TableColumns => _repository.TableColumns;
  28. /// <summary>
  29. /// 查询订单
  30. /// </summary>
  31. /// <param name="request"></param>
  32. /// <returns></returns>
  33. public async Task<PagedList<Entity.Order.Order>> GetAllOrderAsync(OrderSearchRequest request)
  34. {
  35. var result = new PagedList<Entity.Order.Order>();
  36. var query = Q.NewQuery();
  37. if (!string.IsNullOrEmpty(request.KeyWord))
  38. query.WhereLike(nameof(Entity.Order.Order.OrderNumber), $"%{request.KeyWord}%");
  39. if (request.PayWay > 0)
  40. query.Where(nameof(Entity.Order.Order.PayWay), request.PayWay);
  41. if (!string.IsNullOrEmpty(request.BeginTime) && !string.IsNullOrEmpty(request.EndTime))
  42. {
  43. if (DateTime.TryParse(request.BeginTime, out var BeginTime) && DateTime.TryParse(request.EndTime, out var EndTime))
  44. {
  45. query.WhereTime(nameof(Entity.Order.Order.CreatedDate), ">", BeginTime);
  46. query.WhereTime(nameof(Entity.Order.Order.CreatedDate), "<", EndTime);
  47. }
  48. }
  49. result.Total = await _repository.CountAsync(query);
  50. result.Items = await _repository.GetAllAsync(query.ForPage(request.Page, request.PerPage));
  51. return result;
  52. }
  53. }
  54. }