mh_sms/APT.MicroApi/APT.PF.WebApi/Controllers/Api/Table/PageTreeController.cs
2024-01-22 09:17:01 +08:00

216 lines
8.8 KiB
C#

using APT.BaseData.Domain.ApiModel;
using APT.BaseData.Domain.Entities;
using APT.BaseData.Domain.Enums;
using APT.BaseData.Domain.IServices;
using APT.Infrastructure.Core;
using APT.Utility;
using Microsoft.AspNetCore.Mvc;
using System;
using System.Collections.Generic;
using System.Linq;
using APT.Infrastructure.Api;
using APT.Utility;
using APT.BaseData.Domain.ApiModel.Platform;
using APT.Infrastructure.Api.Redis;
namespace APT.PF.WebApiControllers.Api.PF
{
[Route("api/PF/PageTree")]
[APT.Infrastructure.Api.RootOrg]
public class PageTreeController : AuthorizeApiController<T_PF_PAGE_TREE>
{
/// <summary>
/// 查询
/// </summary>
/// <param name="pageFilter"></param>
/// <returns></returns>
[HttpPost, Route("Entities")]
public JsonActionResult<IEnumerable<T_PF_PAGE_TREE>> Entities([FromBody] KeywordFilter filter)
{
return WitEntities(null, filter);
}
/// <summary>
/// 查询
/// </summary>
/// <param name="pageFilter"></param>
/// <returns></returns>
[HttpPost, Route("OrderEntities")]
public JsonActionResult<IEnumerable<T_PF_PAGE_TREE>> OrderEntities([FromBody] KeywordFilter filter)
{
//return WitOrderEntities(null, filter);
return SafeExecute<IEnumerable<T_PF_PAGE_TREE>>(() =>
{
var data = this.GetOrderEntities<T_PF_PAGE_TREE>(null, filter); ;
data.ForEach(x =>
{
if (x.Nav_Columns != null) x.Nav_Columns.Where(i => !string.IsNullOrEmpty(i.ENUM))
.ForEach(i => i.ENUM = DataHelper.EnumToString(i.ENUM));
});
return data;
});
}
/// <summary>
/// 查询
/// </summary>
/// <param name="pageFilter"></param>
/// <returns></returns>
[HttpPost, Route("Paged")]
public PagedActionResult<T_PF_PAGE_TREE> Paged([FromBody] KeywordPageFilter pageFilter)
{
return WitPaged(null, pageFilter);
}
/// <summary>
/// 查询
/// </summary>
/// <param name="pageFilter"></param>
/// <returns></returns>
[HttpPost, Route("OrderPaged")]
public PagedActionResult<T_PF_PAGE_TREE> OrderPaged([FromBody] KeywordPageFilter pageFilter)
{
return WitOrderPaged(null, pageFilter);
}
[HttpPost, Route("Update")]
public JsonActionResult<bool> Update([FromBody] T_PF_PAGE_TREE entity)
{
return SafeExecute<bool>(() =>
{
this.UpdateEntity(entity);
var formService = APT.Infrastructure.Api.ServiceLocator.Instance.GetService<IPFFormService>();
formService.CreateFormConfigVersion(PFFormConfigVersionEnum.PageTree, entity.ID.ToString());
return true;
});
}
/// <summary>
/// 删除
/// </summary>
/// <param name="id"></param>
/// <returns></returns>
[HttpGet, Route("Delete")]
public JsonActionResult<bool> Delete(string id)
{
return SafeExecute<bool>(() =>
{
var formService = APT.Infrastructure.Api.ServiceLocator.Instance.GetService<IPFFormService>();
formService.CreateFormConfigVersion(PFFormConfigVersionEnum.PageTree, id);
List<Guid> ids = new List<Guid>();
ids.Add(new Guid(id));
this.DoDelete(ids);
return true;
});
}
private void DoDelete(List<Guid> ids)
{
this.DeleteEntity<T_PF_TREE_COLUMN>(t => ids.Contains(t.PAGE_TREE_ID));
this.DeleteEntity<T_PF_PAGE_TREE>(t => ids.Contains(t.ID));
}
/// <summary>
/// 批量删除
/// </summary>
/// <param name="ids"></param>
/// <returns></returns>
[HttpGet, Route("BatchDelete")]
public JsonActionResult<bool> BatchDelete(string ids)
{
return SafeExecute<bool>(() =>
{
var formService = APT.Infrastructure.Api.ServiceLocator.Instance.GetService<IPFFormService>();
formService.CreateFormConfigVersion(PFFormConfigVersionEnum.PageTree, ids);
var arrays = string.IsNullOrEmpty(ids) ? null : ids.Split(new char[] { ',' }, StringSplitOptions.RemoveEmptyEntries)
.Select(t => new Guid(t)).ToList();
if (arrays != null && arrays.Count > 0)
this.DoDelete(arrays);
return true;
});
}
/// <summary>
/// 根据ID获得实体数据
/// </summary>
/// <param name="id"></param>
/// <returns></returns>
[HttpPost, Route("Get")]
public JsonActionResult<T_PF_PAGE_TREE> Get([FromBody] KeywordFilter filter)
{
//return WitEntity(null, filter);
return SafeExecute<T_PF_PAGE_TREE>(() =>
{
var data = this.GetEntity<T_PF_PAGE_TREE>(null, filter);
if (data == null)
throw new Exception("不存在此表单");
if (data.Nav_Columns != null && data.Nav_Columns.Any(i => !string.IsNullOrEmpty(i.ENUM)))
{
data.Nav_Columns.Where(i => !string.IsNullOrEmpty(i.ENUM))
.ForEach(i => i.ENUM = DataHelper.EnumToString(i.ENUM));
}
return data;
});
}
/// <summary>
/// 获取树配置信息
/// </summary>
/// <param name="filter"></param>
/// <returns></returns>
[HttpPost, Route("GetTreePageConfigInfo")]
public JsonActionResult<TreePageModel> GetTreePageConfigInfo([FromBody] KeywordFilter filter)
{
//return WitEntity(null, filter);
return SafeExecute<TreePageModel>(() =>
{
string formCode = filter.Keyword;
if (string.IsNullOrEmpty(formCode))
throw new Exception("表单CODE不允许为空");
filter.OrgType = FilterOrgTypeEnum.;
var redisCode = string.Format(RedisCacheKey.PageTreeRedisKey, filter.Keyword, filter.OrgId);
bool isRedisConfig = true;
var redisConfig = APT.Infrastructure.Api.ConfigurationManager.AppSettings["RedisFormConfig"];
if (!string.IsNullOrEmpty(redisConfig))
isRedisConfig = bool.Parse(redisConfig);
if (isRedisConfig)
{
if (CsRedisManager.KeyExists(redisCode))
return CsRedisManager.StringGet<TreePageModel>(redisCode);
}
var form = this.GetEntityByRedis<T_PF_FORM>(formCode, filter.GetOrgId());
if (form == null)
return null;
var redisFilter = new BaseFilter(filter.GetOrgId());
redisFilter.Sort = "NUM";
//var pageTree= this.GetEntity<T_PF_PAGE_TREE>(t => t.PAGE_FORM_ID == form.ID);
var pageTree = this.GetEntity<T_PF_PAGE_TREE>(t => t.PAGE_FORM_ID == form.ID);
if (pageTree == null)
return null;
TreePageModel result = new TreePageModel();
result.Nav_Form = form;
result.Nav_PageTree = pageTree;
var columns = this.GetEntitiesByRedis<T_PF_TREE_COLUMN>(null, redisFilter, pageTree.ID.ToString());
result.Nav_Columns = columns;//
//result.Nav_Columns = this.GetOrderEntities<T_PF_TREE_COLUMN>(t => t.PAGE_TREE_ID == pageTree.ID, tmpFilter).ToList();
//重置枚举
if (result.Nav_Columns != null)
{
result.Nav_Columns.Where(i => !string.IsNullOrEmpty(i.ENUM))
.ForEach(i => i.ENUM = DataHelper.EnumToString(i.ENUM));
}
result.Nav_Btns = this.GetEntitiesByRedis<T_PF_BTN>(null, redisFilter, pageTree.ID.ToString());
BaseFilter tmpFilter = new BaseFilter();
tmpFilter.Sort = "NUM";
tmpFilter.Order = DbOrder.ASC;
tmpFilter.OrgType = FilterOrgTypeEnum.;
tmpFilter.SelectField = new string[] { "Nav_Picture.CODE", "NUM", "Nav_PicFilterDetail.NAME", "Nav_PicFilterDetail.FIELD_TYPE", "Nav_PicFilterDetail.OPERATE", "Nav_PicFilterDetail.VALUE" };
result.Nav_PicFilter = this.GetEntities<T_PF_PIC_FILTER>(i => i.PAGE_FORM_ID == form.ID, tmpFilter).ToList();
CsRedisManager.StringSet(redisCode, result);
return result;
});
}
}
}