BootstrapAdmin/Bootstrap.Admin/Query/QueryMenuOption.cs

111 lines
3.7 KiB
C#
Raw Normal View History

using Bootstrap.DataAccess;
2018-06-07 00:45:47 +08:00
using Longbow.Web.Mvc;
using System;
2018-06-07 00:45:47 +08:00
using System.Linq;
namespace Bootstrap.Admin.Query
{
/// <summary>
///
/// </summary>
2018-06-07 00:45:47 +08:00
public class QueryMenuOption : PaginationOption
{
/// <summary>
///
/// </summary>
public string Name { get; set; }
2018-06-07 00:45:47 +08:00
/// <summary>
///
/// </summary>
public string ParentName { get; set; }
2018-06-07 00:45:47 +08:00
/// <summary>
///
/// </summary>
public string Category { get; set; }
2018-06-07 00:45:47 +08:00
/// <summary>
///
/// </summary>
public string IsResource { get; set; }
/// <summary>
///
/// </summary>
public string AppCode { get; set; }
/// <summary>
///
/// </summary>
/// <param name="userName"></param>
/// <returns></returns>
public QueryData<object> RetrieveData(string userName)
2018-06-07 00:45:47 +08:00
{
2018-10-19 23:09:52 +08:00
var data = MenuHelper.RetrieveMenusByUserName(userName);
2018-06-07 00:45:47 +08:00
if (!string.IsNullOrEmpty(ParentName))
{
data = data.Where(t => t.Name.Contains(ParentName) || (t.ParentName != null && t.ParentName.Contains(ParentName)));
2018-06-07 00:45:47 +08:00
}
if (!string.IsNullOrEmpty(Name))
{
data = data.Where(t => t.Name.Contains(Name));
}
if (!string.IsNullOrEmpty(Category))
{
data = data.Where(t => t.Category.Contains(Category));
}
if (!string.IsNullOrEmpty(IsResource))
{
data = data.Where(t => t.IsResource.ToString() == IsResource);
}
if (!string.IsNullOrEmpty(AppCode))
{
data = data.Where(t => t.Application.Equals(AppCode, StringComparison.OrdinalIgnoreCase));
}
var ret = new QueryData<object>();
2018-06-07 00:45:47 +08:00
ret.total = data.Count();
switch (Sort)
{
case "Name":
data = Order == "asc" ? data.OrderBy(t => t.Name) : data.OrderByDescending(t => t.Name);
break;
case "ParentName":
data = Order == "asc" ? data.OrderBy(t => t.ParentName) : data.OrderByDescending(t => t.ParentName);
break;
case "Order":
data = Order == "asc" ? data.OrderBy(t => t.Application).ThenBy(t => t.ParentId).ThenBy(t => t.Order) : data.OrderBy(t => t.Application).ThenBy(t => t.ParentId).ThenByDescending(t => t.Order);
2018-06-07 00:45:47 +08:00
break;
case "CategoryName":
data = Order == "asc" ? data.OrderBy(t => t.CategoryName) : data.OrderByDescending(t => t.CategoryName);
break;
case "Target":
data = Order == "asc" ? data.OrderBy(t => t.Target) : data.OrderByDescending(t => t.Target);
break;
case "IsResource":
data = Order == "asc" ? data.OrderBy(t => t.IsResource) : data.OrderByDescending(t => t.IsResource);
break;
case "Application":
data = Order == "asc" ? data.OrderBy(t => t.Application) : data.OrderByDescending(t => t.Application);
2018-06-07 00:45:47 +08:00
break;
}
ret.rows = data.Skip(Offset).Take(Limit).Select(p => new
{
p.Id,
p.ParentId,
p.ParentName,
p.Name,
p.Order,
p.Icon,
p.Url,
p.Category,
p.CategoryName,
p.Target,
p.IsResource,
p.Application
});
2018-06-07 00:45:47 +08:00
return ret;
}
}
}