using Cis.Core.Common; using Newtonsoft.Json.Linq; namespace Cis.Application.Sys; /// /// 系统字典值服务 /// [ApiDescriptionSettings(SysInfo.GroupName, Order = SysInfo.SysDictDataGroupOrder)] public class SysDictDataService : ServiceBase, ITransient { public SysDictDataService(SqlSugarRepository baseRep) : base(baseRep) { } /// /// 获取实体类 /// /// equal:sysDictTypeId,id,isDelete; like:name,code; between:[startTime,endTime]; /// [HttpGet] public override async Task GetByQ([Required] string queryJson) { JObject queryObj = queryJson.ToJObject(); var exp = Expressionable.Create(); 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; } /// /// 批量获取实体类 /// /// equal:sysDictTypeId,isDelete; like:name,code; between:[startTime,endTime]; /// [HttpGet] public override async Task> GetList(string queryJson = "") { JObject queryObj = queryJson.ToJObject(); var exp = Expressionable.Create(); 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; } /// /// 批量获取分页实体类 /// /// equal:sysDictTypeId,isDelete; like:name,code; between:[startTime,endTime]; /// index,size /// [HttpGet] public override async Task> GetPageList([Required] string pagination, string queryJson = "") { Pagination pageObj = pagination.ToObject(); JObject queryObj = queryJson.ToJObject(); var exp = Expressionable.Create(); 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; } }