SqlSugarPagedList.cs 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  1. // Admin.NET 项目的版权、商标、专利和其他相关权利均受相应法律法规的保护。使用本项目应遵守相关法律法规和许可证的要求。
  2. //
  3. // 本项目主要遵循 MIT 许可证和 Apache 许可证(版本 2.0)进行分发和使用。许可证位于源代码树根目录中的 LICENSE-MIT 和 LICENSE-APACHE 文件。
  4. //
  5. // 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动!任何基于本项目二次开发而产生的一切法律纠纷和责任,我们不承担任何责任!
  6. namespace Admin.NET.Core;
  7. /// <summary>
  8. /// 分页泛型集合
  9. /// </summary>
  10. /// <typeparam name="TEntity"></typeparam>
  11. public class SqlSugarPagedList<TEntity>
  12. {
  13. /// <summary>
  14. /// 页码
  15. /// </summary>
  16. public int Page { get; set; }
  17. /// <summary>
  18. /// 页容量
  19. /// </summary>
  20. public int PageSize { get; set; }
  21. /// <summary>
  22. /// 总条数
  23. /// </summary>
  24. public int Total { get; set; }
  25. /// <summary>
  26. /// 总页数
  27. /// </summary>
  28. public int TotalPages { get; set; }
  29. /// <summary>
  30. /// 当前页集合
  31. /// </summary>
  32. public IEnumerable<TEntity> Items { get; set; }
  33. /// <summary>
  34. /// 是否有上一页
  35. /// </summary>
  36. public bool HasPrevPage { get; set; }
  37. /// <summary>
  38. /// 是否有下一页
  39. /// </summary>
  40. public bool HasNextPage { get; set; }
  41. }
  42. /// <summary>
  43. /// 分页拓展类
  44. /// </summary>
  45. public static class SqlSugarPagedExtensions
  46. {
  47. /// <summary>
  48. /// 分页拓展
  49. /// </summary>
  50. /// <param name="query"><see cref="ISugarQueryable{TEntity}"/>对象</param>
  51. /// <param name="pageIndex">当前页码,从1开始</param>
  52. /// <param name="pageSize">页码容量</param>
  53. /// <param name="expression">查询结果 Select 表达式</param>
  54. /// <returns></returns>
  55. public static SqlSugarPagedList<TResult> ToPagedList<TEntity, TResult>(this ISugarQueryable<TEntity> query, int pageIndex, int pageSize,
  56. Expression<Func<TEntity, TResult>> expression)
  57. {
  58. var total = 0;
  59. var items = query.ToPageList(pageIndex, pageSize, ref total, expression);
  60. return CreateSqlSugarPagedList(items, total, pageIndex, pageSize);
  61. }
  62. /// <summary>
  63. /// 分页拓展
  64. /// </summary>
  65. /// <param name="query"><see cref="ISugarQueryable{TEntity}"/>对象</param>
  66. /// <param name="pageIndex">当前页码,从1开始</param>
  67. /// <param name="pageSize">页码容量</param>
  68. /// <returns></returns>
  69. public static SqlSugarPagedList<TEntity> ToPagedList<TEntity>(this ISugarQueryable<TEntity> query, int pageIndex, int pageSize)
  70. {
  71. var total = 0;
  72. var items = query.ToPageList(pageIndex, pageSize, ref total);
  73. return CreateSqlSugarPagedList(items, total, pageIndex, pageSize);
  74. }
  75. /// <summary>
  76. /// 分页拓展
  77. /// </summary>
  78. /// <param name="query"><see cref="ISugarQueryable{TEntity}"/>对象</param>
  79. /// <param name="pageIndex">当前页码,从1开始</param>
  80. /// <param name="pageSize">页码容量</param>
  81. /// <param name="expression">查询结果 Select 表达式</param>
  82. /// <returns></returns>
  83. public static async Task<SqlSugarPagedList<TResult>> ToPagedListAsync<TEntity, TResult>(this ISugarQueryable<TEntity> query, int pageIndex, int pageSize,
  84. Expression<Func<TEntity, TResult>> expression)
  85. {
  86. RefAsync<int> total = 0;
  87. var items = await query.ToPageListAsync(pageIndex, pageSize, total, expression);
  88. return CreateSqlSugarPagedList(items, total, pageIndex, pageSize);
  89. }
  90. /// <summary>
  91. /// 分页拓展
  92. /// </summary>
  93. /// <param name="query"><see cref="ISugarQueryable{TEntity}"/>对象</param>
  94. /// <param name="pageIndex">当前页码,从1开始</param>
  95. /// <param name="pageSize">页码容量</param>
  96. /// <returns></returns>
  97. public static async Task<SqlSugarPagedList<TEntity>> ToPagedListAsync<TEntity>(this ISugarQueryable<TEntity> query, int pageIndex, int pageSize)
  98. {
  99. RefAsync<int> total = 0;
  100. var items = await query.ToPageListAsync(pageIndex, pageSize, total);
  101. return CreateSqlSugarPagedList(items, total, pageIndex, pageSize);
  102. }
  103. /// <summary>
  104. /// 脱敏分页拓展
  105. /// </summary>
  106. /// <param name="query"><see cref="ISugarQueryable{TEntity}"/>对象</param>
  107. /// <param name="pageIndex">当前页码,从1开始</param>
  108. /// <param name="pageSize">页码容量</param>
  109. /// <returns></returns>
  110. public static async Task<SqlSugarPagedList<TEntity>> ToPagedListDataMaskAsync<TEntity>(this ISugarQueryable<TEntity> query, int pageIndex, int pageSize) where TEntity : class
  111. {
  112. RefAsync<int> total = 0;
  113. var items = await query.ToPageListAsync(pageIndex, pageSize, total);
  114. items.ForEach(x => x.MaskSensitiveData());
  115. return CreateSqlSugarPagedList(items, total, pageIndex, pageSize);
  116. }
  117. /// <summary>
  118. /// 脱敏分页拓展
  119. /// </summary>
  120. /// <param name="list">集合对象</param>
  121. /// <param name="pageIndex">当前页码,从1开始</param>
  122. /// <param name="pageSize">页码容量</param>
  123. /// <returns></returns>
  124. public static SqlSugarPagedList<TEntity> ToPagedListDataMask<TEntity>(this IEnumerable<TEntity> list, int pageIndex, int pageSize) where TEntity : class
  125. {
  126. var total = list.Count();
  127. var items = list.Skip((pageIndex - 1) * pageSize).Take(pageSize).ToList();
  128. items.ForEach(x => x.MaskSensitiveData());
  129. return CreateSqlSugarPagedList(items, total, pageIndex, pageSize);
  130. }
  131. /// <summary>
  132. /// 分页拓展
  133. /// </summary>
  134. /// <param name="list">集合对象</param>
  135. /// <param name="pageIndex">当前页码,从1开始</param>
  136. /// <param name="pageSize">页码容量</param>
  137. /// <returns></returns>
  138. public static SqlSugarPagedList<TEntity> ToPagedList<TEntity>(this IEnumerable<TEntity> list, int pageIndex, int pageSize)
  139. {
  140. var total = list.Count();
  141. var items = list.Skip((pageIndex - 1) * pageSize).Take(pageSize).ToList();
  142. return CreateSqlSugarPagedList(items, total, pageIndex, pageSize);
  143. }
  144. /// <summary>
  145. /// 创建 <see cref="SqlSugarPagedList{TEntity}"/> 对象
  146. /// </summary>
  147. /// <typeparam name="TEntity"></typeparam>
  148. /// <param name="items">分页内容的对象集合</param>
  149. /// <param name="total">总条数</param>
  150. /// <param name="pageIndex">当前页码,从1开始</param>
  151. /// <param name="pageSize">页码容量</param>
  152. /// <returns></returns>
  153. private static SqlSugarPagedList<TEntity> CreateSqlSugarPagedList<TEntity>(IEnumerable<TEntity> items, int total, int pageIndex, int pageSize)
  154. {
  155. var totalPages = pageSize > 0 ? (int)Math.Ceiling(total / (double)pageSize) : 0;
  156. return new SqlSugarPagedList<TEntity>
  157. {
  158. Page = pageIndex,
  159. PageSize = pageSize,
  160. Items = items,
  161. Total = total,
  162. TotalPages = totalPages,
  163. HasNextPage = pageIndex < totalPages,
  164. HasPrevPage = pageIndex - 1 > 0
  165. };
  166. }
  167. }