2
schangxiang@126.com
2024-08-26 9a6009b6841523cad86325706e1e4c802a205322
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
using Furion.FriendlyException;
using Mapster;
using MapsterMapper;
 
namespace iWare.Wms.Core
{
    /// <summary>
    /// 列表通用排序
    /// </summary>
    public static class PageInputOrder
    {
        /// <summary>
        /// 排序方式(默认降序)
        /// </summary>
        /// <param name="pageInput"> </param>
        /// <param name="defualtSortField"> 默认排序字段 </param>
        /// <param name="descSort"> 是否降序 </param>
        /// <returns> </returns>
        public static string OrderBuilder<T>(T pageInput, string defualtSortField = "Id", bool descSort = true)
        {
            string orderStr;
            // 约定默认每张表都有Id排序
            if (!string.IsNullOrWhiteSpace(defualtSortField))
                orderStr = descSort ? defualtSortField + " Desc" : defualtSortField + " Asc";
            else
                throw Oops.Oh("排序字段不能为空!");
 
            TypeAdapterConfig config = new();
            config.ForType<T, PageInputBase>().IgnoreNullValues(true);
            Mapper mapper = new(config); // 务必将mapper设为单实例
            PageInputBase nowPagerInput = mapper.Map<PageInputBase>(pageInput);
            // 排序是否可用-排序字段为非空才启用排序
            if (!string.IsNullOrEmpty(nowPagerInput.SortField))
            {
                orderStr = $"{nowPagerInput.SortField} {(nowPagerInput.SortOrder == nowPagerInput.DescStr ? "Desc" : "Asc")}";
            }
            return orderStr;
        }
    }
}