|
|
|
using Cis.Core.Common;
|
|
|
|
using Newtonsoft.Json.Linq;
|
|
|
|
|
|
|
|
namespace Cis.Application.Sys;
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// 系统字典值服务
|
|
|
|
/// </summary>
|
|
|
|
[ApiDescriptionSettings(SysInfo.GroupName, Order = SysInfo.SysDictDataGroupOrder)]
|
|
|
|
public class SysDictDataService : ServiceBase<SysDictData>, ITransient
|
|
|
|
{
|
|
|
|
public SysDictDataService(SqlSugarRepository<SysDictData> baseRep) : base(baseRep)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// 获取实体类
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="queryJson">equal:sysDictTypeId,id,isDelete; like:name,code; between:[startTime,endTime];</param>
|
|
|
|
/// <returns></returns>
|
|
|
|
[HttpGet]
|
|
|
|
public override async Task<SysDictData> GetByQ([Required] string queryJson)
|
|
|
|
{
|
|
|
|
JObject queryObj = queryJson.ToJObject();
|
|
|
|
|
|
|
|
var exp = Expressionable.Create<SysDictData>();
|
|
|
|
if (queryObj.TryGetValue("sysDictTypeId", StringComparison.OrdinalIgnoreCase, out JToken sysDictTypeId))
|
|
|
|
exp.And(it => it.SysDictTypeId.Equals(sysDictTypeId));
|
|
|
|
if (queryObj.TryGetValue("Id", StringComparison.OrdinalIgnoreCase, out JToken Id))
|
|
|
|
exp.And(it => it.Id.Equals(Id));
|
|
|
|
if (queryObj.TryGetValue("name", StringComparison.OrdinalIgnoreCase, out JToken name))
|
|
|
|
exp.And(it => it.Name.Contains(name.ToString()));
|
|
|
|
if (queryObj.TryGetValue("code", StringComparison.OrdinalIgnoreCase, out JToken code))
|
|
|
|
exp.And(it => it.Code.Contains(code.ToString()));
|
|
|
|
if (queryObj.TryGetValue("IsDelete", StringComparison.OrdinalIgnoreCase, out JToken isDelete))
|
|
|
|
exp.And(it => it.IsDelete.Equals(isDelete));
|
|
|
|
if (queryObj.TryGetValue("StartTime", StringComparison.OrdinalIgnoreCase, out JToken startTime)
|
|
|
|
&& queryObj.TryGetValue("EndTime", StringComparison.OrdinalIgnoreCase, out JToken endTime))
|
|
|
|
exp.And(it => it.CreateTime >= startTime.ToDateTime() && it.CreateTime <= endTime.ToDateTime());
|
|
|
|
|
|
|
|
var entity = await _baseRep.AsQueryable()
|
|
|
|
.Where(exp.ToExpression())
|
|
|
|
.OrderBy(it => new { it.SysDictTypeId, it.Order })
|
|
|
|
.FirstAsync();
|
|
|
|
return entity;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// 批量获取实体类
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="queryJson">equal:sysDictTypeId,isDelete; like:name,code; between:[startTime,endTime];</param>
|
|
|
|
/// <returns></returns>
|
|
|
|
[HttpGet]
|
|
|
|
public override async Task<List<SysDictData>> GetList(string queryJson = "")
|
|
|
|
{
|
|
|
|
JObject queryObj = queryJson.ToJObject();
|
|
|
|
|
|
|
|
var exp = Expressionable.Create<SysDictData>();
|
|
|
|
if (queryObj.TryGetValue("sysDictTypeId", StringComparison.OrdinalIgnoreCase, out JToken sysDictTypeId))
|
|
|
|
exp.And(it => it.SysDictTypeId.Equals(sysDictTypeId));
|
|
|
|
if (queryObj.TryGetValue("name", StringComparison.OrdinalIgnoreCase, out JToken name))
|
|
|
|
exp.And(it => it.Name.Contains(name.ToString()));
|
|
|
|
if (queryObj.TryGetValue("code", StringComparison.OrdinalIgnoreCase, out JToken code))
|
|
|
|
exp.And(it => it.Code.Contains(code.ToString()));
|
|
|
|
if (queryObj.TryGetValue("IsDelete", StringComparison.OrdinalIgnoreCase, out JToken isDelete))
|
|
|
|
exp.And(it => it.IsDelete.Equals(isDelete));
|
|
|
|
if (queryObj.TryGetValue("StartTime", StringComparison.OrdinalIgnoreCase, out JToken startTime)
|
|
|
|
&& queryObj.TryGetValue("EndTime", StringComparison.OrdinalIgnoreCase, out JToken endTime))
|
|
|
|
exp.And(it => it.CreateTime >= startTime.ToDateTime() && it.CreateTime <= endTime.ToDateTime());
|
|
|
|
|
|
|
|
var list = await _baseRep.AsQueryable()
|
|
|
|
.Where(exp.ToExpression())
|
|
|
|
.OrderBy(it => new { it.SysDictTypeId, it.Order })
|
|
|
|
.ToListAsync();
|
|
|
|
return list;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// 批量获取分页实体类
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="queryJson">equal:sysDictTypeId,isDelete; like:name,code; between:[startTime,endTime];</param>
|
|
|
|
/// <param name="pagination">index,size</param>
|
|
|
|
/// <returns></returns>
|
|
|
|
[HttpGet]
|
|
|
|
public override async Task<List<SysDictData>> GetPageList([Required] string pagination, string queryJson = "")
|
|
|
|
{
|
|
|
|
Pagination pageObj = pagination.ToObject<Pagination>();
|
|
|
|
JObject queryObj = queryJson.ToJObject();
|
|
|
|
|
|
|
|
var exp = Expressionable.Create<SysDictData>();
|
|
|
|
if (queryObj.TryGetValue("sysDictTypeId", StringComparison.OrdinalIgnoreCase, out JToken sysDictTypeId))
|
|
|
|
exp.And(it => it.SysDictTypeId.Equals(sysDictTypeId));
|
|
|
|
if (queryObj.TryGetValue("name", StringComparison.OrdinalIgnoreCase, out JToken name))
|
|
|
|
exp.And(it => it.Name.Contains(name.ToString()));
|
|
|
|
if (queryObj.TryGetValue("code", StringComparison.OrdinalIgnoreCase, out JToken code))
|
|
|
|
exp.And(it => it.Code.Contains(code.ToString()));
|
|
|
|
if (queryObj.TryGetValue("IsDelete", StringComparison.OrdinalIgnoreCase, out JToken isDelete))
|
|
|
|
exp.And(it => it.IsDelete.Equals(isDelete));
|
|
|
|
if (queryObj.TryGetValue("StartTime", StringComparison.OrdinalIgnoreCase, out JToken startTime)
|
|
|
|
&& queryObj.TryGetValue("EndTime", StringComparison.OrdinalIgnoreCase, out JToken endTime))
|
|
|
|
exp.And(it => it.CreateTime >= startTime.ToDateTime() && it.CreateTime <= endTime.ToDateTime());
|
|
|
|
|
|
|
|
var list = await _baseRep.AsQueryable()
|
|
|
|
.Where(exp.ToExpression())
|
|
|
|
.OrderBy(it => new { it.SysDictTypeId, it.Order })
|
|
|
|
.ToPageListAsync(pageObj.Index, pageObj.Size);
|
|
|
|
return list;
|
|
|
|
}
|
|
|
|
}
|