71 lines
2.4 KiB
C#
71 lines
2.4 KiB
C#
using Bootstrap.DataAccess;
|
|
using Longbow.Web.Mvc;
|
|
using System.Linq;
|
|
|
|
namespace Bootstrap.Admin.Query
|
|
{
|
|
/// <summary>
|
|
///
|
|
/// </summary>
|
|
public class QueryUserOption : PaginationOption
|
|
{
|
|
/// <summary>
|
|
///
|
|
/// </summary>
|
|
public string Name { get; set; }
|
|
/// <summary>
|
|
///
|
|
/// </summary>
|
|
public string DisplayName { get; set; }
|
|
/// <summary>
|
|
///
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
public QueryData<object> RetrieveData()
|
|
{
|
|
// int limit, int offset, string name, string price, string sort, string order
|
|
var data = UserHelper.Retrieves();
|
|
if (!string.IsNullOrEmpty(Name))
|
|
{
|
|
data = data.Where(t => t.UserName.Contains(Name));
|
|
}
|
|
if (!string.IsNullOrEmpty(DisplayName))
|
|
{
|
|
data = data.Where(t => t.DisplayName.Contains(DisplayName));
|
|
}
|
|
var ret = new QueryData<object>();
|
|
ret.total = data.Count();
|
|
switch (Sort)
|
|
{
|
|
case "UserName":
|
|
data = Order == "asc" ? data.OrderBy(t => t.UserName) : data.OrderByDescending(t => t.UserName);
|
|
break;
|
|
case "DisplayName":
|
|
data = Order == "asc" ? data.OrderBy(t => t.DisplayName) : data.OrderByDescending(t => t.DisplayName);
|
|
break;
|
|
case "RegisterTime":
|
|
data = Order == "asc" ? data.OrderBy(t => t.RegisterTime) : data.OrderByDescending(t => t.RegisterTime);
|
|
break;
|
|
case "ApprovedTime":
|
|
data = Order == "asc" ? data.OrderBy(t => t.ApprovedTime) : data.OrderByDescending(t => t.ApprovedTime);
|
|
break;
|
|
case "ApprovedBy":
|
|
data = Order == "asc" ? data.OrderBy(t => t.ApprovedBy) : data.OrderByDescending(t => t.ApprovedBy);
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
ret.rows = data.Skip(Offset).Take(Limit).Select(u => new
|
|
{
|
|
u.Id,
|
|
u.UserName,
|
|
u.DisplayName,
|
|
u.RegisterTime,
|
|
u.ApprovedTime,
|
|
u.ApprovedBy,
|
|
u.Description
|
|
});
|
|
return ret;
|
|
}
|
|
}
|
|
} |