NewManagerModelService.cs 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data.Common;
  4. using System.Linq;
  5. using System.Linq.Expressions;
  6. using System.Text;
  7. using System.Threading.Tasks;
  8. using YiSha.Data;
  9. using YiSha.Data.Repository;
  10. using YiSha.Entity.ZX;
  11. using YiSha.Enum.ZX;
  12. using YiSha.IService.ZX;
  13. using YiSha.Model.Param.ZX;
  14. using YiSha.Model.Result.ZX;
  15. using YiSha.Util;
  16. using YiSha.Util.Extension;
  17. using YiSha.Util.Model;
  18. using YiSha.Web.Code;
  19. namespace YiSha.Service.ZX
  20. {
  21. /// <summary>
  22. /// 创 建:cmzx
  23. /// 日 期:2021-04-16 15:00
  24. /// 描 述:资讯文章服务实现类(部分类)
  25. /// </summary>
  26. public partial class NewManagerModelService
  27. {
  28. private IRepositoryFactory _baseRepository;
  29. private IMenuManagerModelsService _managerModelsService;
  30. public NewManagerModelService(IRepositoryFactory baseRepository, IMenuManagerModelsService managerModelsService)
  31. {
  32. _baseRepository = baseRepository;
  33. _managerModelsService = managerModelsService;
  34. }
  35. /// <summary>
  36. /// 获取分页数据
  37. /// </summary>
  38. /// <param name="param">请求参数</param>
  39. /// <param name="pagination">分页条件</param>
  40. /// <returns></returns>
  41. public async Task<List<NewManagerModelPageJoinModel>> GetPageListPartial(NewManagerModelListParam param, Pagination pagination)
  42. {
  43. var parameters = new List<DbParameter>();
  44. var sql = SqlPageList(param, pagination, out parameters);
  45. var list = await _baseRepository.BaseRepository(dbConnectType).FindList<NewManagerModelPageJoinModel>(sql, parameters.ToArray());
  46. return list.ToList();
  47. }
  48. /// <summary>
  49. /// 获取分页数据
  50. /// </summary>
  51. /// <param name="param">请求参数</param>
  52. /// <param name="pagination">分页条件</param>
  53. /// <returns></returns>
  54. public async Task<List<NewContentPublishNumberPageJoinModel>> GetPublishNumberPageListJson(NewContentPublishNumberListParam param, Pagination pagination)
  55. {
  56. var parameters = new List<DbParameter>();
  57. var sql = SqlPublishNumberPageList(param, pagination, out parameters);
  58. var list = await _baseRepository.BaseRepository(dbConnectType).FindList<NewContentPublishNumberPageJoinModel>(sql, parameters.ToArray());
  59. return list.ToList();
  60. }
  61. /// <summary>
  62. /// 保存数据(由于之前数据库设计不规范,无法实现在新增、修改时保存正确的操作用户信息,每张表的创建时间和创建人id、创建人姓名都不一样,且这些字段是必填项)
  63. /// </summary>
  64. /// <param name="entity">实体参数</param>
  65. /// <returns></returns>
  66. public async Task<int> SaveFormPartial(NewManagerModelEntity entity)
  67. {
  68. OperatorInfo user = await Operator.Instance.Current(entity.Token);
  69. if (entity.Id.IsNullOrZero())
  70. {
  71. entity.createTime = DateTime.Now;
  72. entity.createUserId = user?.UserId;
  73. entity.createUserName = user?.UserName;
  74. var zxId = await _baseRepository.BaseRepository(dbConnectType).Insert(entity);
  75. if (zxId > 0 && int.TryParse(entity.menuId?.ToString(), out var menuId))
  76. {
  77. var zxMenu = await _managerModelsService.GetEntity(menuId);
  78. if (int.TryParse(zxMenu?.parentId?.ToString(), out var parentId))
  79. {
  80. var type = ZxCzTemplateTypeHelper.dict[parentId];
  81. //描述信息
  82. string[] arrtributeText = type.GetEnumText();
  83. entity.IsGenerated = true;
  84. entity.SourceUrl = string.Format("/{0}/{1}.htm", arrtributeText[1] + "/" + zxMenu.Shorthand, entity.Id);
  85. await _baseRepository.BaseRepository(dbConnectType).Update(entity);
  86. }
  87. }
  88. return zxId;
  89. }
  90. else
  91. {
  92. if (int.TryParse(entity.menuId?.ToString(), out var menuId))
  93. {
  94. var zxMenu = await _managerModelsService.GetEntity(menuId);
  95. if (int.TryParse(zxMenu?.parentId?.ToString(), out var parentId))
  96. {
  97. var type = ZxCzTemplateTypeHelper.dict[parentId];
  98. //描述信息
  99. string[] arrtributeText = type.GetEnumText();
  100. entity.IsGenerated = true;
  101. entity.SourceUrl = string.Format("/{0}/{1}.htm", arrtributeText[1] + "/" + zxMenu.Shorthand, entity.Id);
  102. }
  103. }
  104. return await _baseRepository.BaseRepository(dbConnectType).Update(entity);
  105. }
  106. }
  107. #region 私有方法
  108. /// <summary>
  109. /// 列表条件过滤
  110. /// 建议该方法放在Partial部分类中,因为代码生成时当前类会被覆盖(该方法在生成时将会被注释)
  111. /// </summary>
  112. /// <param name="param"></param>
  113. /// <returns></returns>
  114. private Expression<Func<NewManagerModelEntity, bool>> ListFilterPartial(NewManagerModelListParam param)
  115. {
  116. var expression = LinqExtensions.True<NewManagerModelEntity>();
  117. if (param != null)
  118. {
  119. }
  120. return expression;
  121. }
  122. /// <summary>
  123. /// 获取分页Sql语句
  124. /// </summary>
  125. /// <param name="param"></param>
  126. /// <returns></returns>
  127. private string SqlPageList(NewManagerModelListParam param, Pagination pagination, out List<DbParameter> parameters)
  128. {
  129. parameters = new List<DbParameter>();
  130. var where = new StringBuilder();
  131. where.Append(" 1 = 1 ");
  132. if (param != null)
  133. {
  134. if (!string.IsNullOrEmpty(param.Title))
  135. {
  136. where.Append(" and nmm.title like @Title ");
  137. parameters.Add(DbParameterExtension.CreateDbParameter("@Title", $"%{param.Title}%", dbConnectType));
  138. }
  139. if (!string.IsNullOrEmpty(param.Qi))
  140. {
  141. where.Append(" and nmm.periodsNumber like @Qi ");
  142. parameters.Add(DbParameterExtension.CreateDbParameter("@Qi", $"%{param.Qi}%", dbConnectType));
  143. }
  144. if (param.MenuId != null && param.MenuId > 0)
  145. {
  146. where.Append(" and nmm.menuId = @MenuId ");
  147. parameters.Add(DbParameterExtension.CreateDbParameter("@MenuId", param.MenuId, dbConnectType));
  148. }
  149. var noticeMenuIds = new List<int>() { 108, 110, 111 };
  150. if (param.NoticeOrArticleType == MenuNoticeOrArticleTypeEnum.公告类型)
  151. {
  152. //公告类型只需要menuId为108、110、111的数据
  153. where.Append(" and (nmm.menuId = 108 or nmm.menuId = 110 or nmm.menuId = 111) ");
  154. }
  155. //if (!string.IsNullOrEmpty(param.MenuName))
  156. //{
  157. // where.Append(" and mmm.menuName like @MenuName ");
  158. // parameters.Add(DbParameterExtension.CreateDbParameter("@MenuName", $"%{param.MenuName}%", dbConnectType));
  159. //}
  160. }
  161. //获取分页数据Sql
  162. var pageSql = $@"select nmm.*,mmm.menuName,ls.labelName
  163. from newManagerModels nmm
  164. left join menuManagerModels mmm on nmm.menuId = mmm.id
  165. left join LabelModels ls on nmm.labelId = ls.id
  166. where {where.ToString()}";
  167. //统计总数据Sql
  168. var totalSql = $@"select count(1)
  169. from newManagerModels nmm
  170. left join menuManagerModels mmm on nmm.menuId = mmm.id
  171. left join LabelModels ls on nmm.labelId = ls.id
  172. where {where.ToString()}";
  173. pageSql = SqlserverHelper.GetInstance.SqlPageList(pageSql, totalSql, pagination);
  174. return pageSql;
  175. }
  176. /// <summary>
  177. /// 获取分页Sql语句
  178. /// </summary>
  179. /// <param name="param"></param>
  180. /// <returns></returns>
  181. private string SqlPublishNumberPageList(NewContentPublishNumberListParam param, Pagination pagination, out List<DbParameter> parameters)
  182. {
  183. parameters = new List<DbParameter>();
  184. var where = new StringBuilder();
  185. where.Append(" 1 = 1 ");
  186. if (param != null)
  187. {
  188. if (param.StartTime != null)
  189. {
  190. where.Append(" and nmm.createTime >= @StartTime ");
  191. parameters.Add(DbParameterExtension.CreateDbParameter("@StartTime", param.StartTime, dbConnectType));
  192. }
  193. if (param.EndTime != null)
  194. {
  195. where.Append(" and nmm.createTime <= @EndTime ");
  196. parameters.Add(DbParameterExtension.CreateDbParameter("@EndTime", param.EndTime, dbConnectType));
  197. }
  198. }
  199. //获取分页数据Sql
  200. var pageSql = string.Empty;
  201. //统计总数据Sql
  202. var totalSql = string.Empty;
  203. if (param.Type == PublishStatisticsType.内容发布量)
  204. {
  205. pageSql = $@"select
  206. 0 Id,
  207. nmm.menuId,
  208. mmm.menuName,
  209. nmm.createUserName userName,
  210. count(nmm.ID) publishNumber
  211. from newManagerModels nmm
  212. inner join menuManagerModels mmm on mmm.id = nmm.menuId
  213. where {where.ToString()}
  214. group by nmm.menuId,mmm.menuName,nmm.createUserName";
  215. totalSql = $@"select count(1) from
  216. (
  217. select
  218. count(1) as c
  219. from newManagerModels nmm
  220. inner join menuManagerModels mmm on mmm.id = nmm.menuId
  221. where {where.ToString()}
  222. group by nmm.menuId,mmm.menuName,nmm.createUserName
  223. ) TotalTable";
  224. pagination.Sort = "publishNumber";
  225. }
  226. else
  227. {
  228. pageSql = $@"select
  229. 0 Id,
  230. nmm.menuId,
  231. mmm.menuName,
  232. count(nmm.menuId) publishNumber
  233. from newManagerModels nmm
  234. inner join menuManagerModels mmm on mmm.id = nmm.menuId
  235. where {where.ToString()}
  236. group by nmm.menuId,mmm.menuName";
  237. totalSql = $@"select count(1) from
  238. (
  239. select
  240. count(1) as c
  241. from newManagerModels nmm
  242. inner join menuManagerModels mmm on mmm.id = nmm.menuId
  243. where {where.ToString()}
  244. group by nmm.menuId,mmm.menuName
  245. ) TotalTable";
  246. pagination.Sort = "publishNumber";
  247. }
  248. pageSql = SqlserverHelper.GetInstance.SqlPageList(pageSql, totalSql, pagination);
  249. return pageSql;
  250. }
  251. #endregion
  252. }
  253. }