payne
2024-04-25 3fa9d2b0420f4d39849f72e6a04b5cb40823fa0d
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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
using Furion.FriendlyException;
using Mapster;
using MapsterMapper;
 
namespace Admin.NET.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;
        }
 
 
        /// <summary>
        /// 不分页排序方式(默认降序)
        /// </summary>
        /// <param name="pageInput"> </param>
        /// <param name="defualtSortField"> 默认排序字段 </param>
        /// <param name="descSort"> 是否降序 </param>
        /// <returns> </returns>
        public static string OrderNonPageBuilder<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设为单实例
            PageInputNonPageBase nowPagerInput = mapper.Map<PageInputNonPageBase>(pageInput);
            // 排序是否可用-排序字段为非空才启用排序
            if (!string.IsNullOrEmpty(nowPagerInput.SortField))
            {
                orderStr = $"{nowPagerInput.SortField} {(nowPagerInput.SortOrder == nowPagerInput.DescStr ? "Desc" : "Asc")}";
            }
            return orderStr;
        }
    }
}