ModuleService.cs 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173
  1. using Lottomat.Application.Entity.AuthorizeManage;
  2. using Lottomat.Application.IService.AuthorizeManage;
  3. using Lottomat.Data.Repository;
  4. using Lottomat.Util.Extension;
  5. using System;
  6. using System.Collections.Generic;
  7. using System.Linq;
  8. using System.Text;
  9. using Lottomat.Util;
  10. using Lottomat.Utils;
  11. namespace Lottomat.Application.Service.BaseManage
  12. {
  13. /// <summary>
  14. /// 版 本 1.0
  15. /// Copyright (c) 2016-2017
  16. /// 创建人:赵轶
  17. /// 日 期:2015.10.27 09:16
  18. /// 描 述:系统功能
  19. /// </summary>
  20. public class ModuleService : RepositoryFactory<ModuleEntity>, IModuleService
  21. {
  22. #region 获取数据
  23. /// <summary>
  24. /// 获取最大编号
  25. /// </summary>
  26. /// <returns></returns>
  27. public int GetSortCode()
  28. {
  29. int sortCode = this.BaseRepository().IQueryable().Max(t => t.SortCode).ToInt();
  30. if (!string.IsNullOrEmpty(sortCode.ToString()))
  31. {
  32. return sortCode + 1;
  33. }
  34. return 100001;
  35. }
  36. /// <summary>
  37. /// 功能列表
  38. /// </summary>
  39. /// <param name="parentId">父级ID</param>
  40. /// <returns></returns>
  41. public IEnumerable<ModuleEntity> GetList(string parentId = "")
  42. {
  43. StringBuilder strSql = new StringBuilder();
  44. if (!string.IsNullOrEmpty(parentId))
  45. {
  46. parentId = parentId.SqlFilters();
  47. strSql.Append("SELECT * FROM BASE_Module Where ParentId ='" + parentId + "' Order By SortCode");
  48. }
  49. else
  50. {
  51. strSql.Append("SELECT * FROM BASE_Module Order By SortCode");
  52. }
  53. return this.BaseRepository().FindList(strSql.ToString());
  54. }
  55. /// <summary>
  56. /// 功能实体
  57. /// </summary>
  58. /// <param name="keyValue">主键值</param>
  59. /// <returns></returns>
  60. public ModuleEntity GetEntity(string keyValue)
  61. {
  62. return this.BaseRepository().FindEntity(keyValue);
  63. }
  64. #endregion
  65. #region 验证数据
  66. /// <summary>
  67. /// 功能编号不能重复
  68. /// </summary>
  69. /// <param name="enCode">编号</param>
  70. /// <param name="keyValue">主键</param>
  71. /// <returns></returns>
  72. public bool ExistEnCode(string enCode, string keyValue)
  73. {
  74. var expression = LinqExtensions.True<ModuleEntity>();
  75. expression = expression.And(t => t.EnCode == enCode);
  76. if (!string.IsNullOrEmpty(keyValue))
  77. {
  78. expression = expression.And(t => t.ModuleId != keyValue);
  79. }
  80. return this.BaseRepository().IQueryable(expression).Count() == 0 ? true : false;
  81. }
  82. /// <summary>
  83. /// 功能名称不能重复
  84. /// </summary>
  85. /// <param name="fullName">名称</param>
  86. /// <param name="keyValue">主键</param>
  87. /// <returns></returns>
  88. public bool ExistFullName(string fullName, string keyValue)
  89. {
  90. var expression = LinqExtensions.True<ModuleEntity>();
  91. expression = expression.And(t => t.FullName == fullName);
  92. if (!string.IsNullOrEmpty(keyValue))
  93. {
  94. expression = expression.And(t => t.ModuleId != keyValue);
  95. }
  96. return this.BaseRepository().IQueryable(expression).Count() == 0 ? true : false;
  97. }
  98. #endregion
  99. #region 提交数据
  100. /// <summary>
  101. /// 删除功能
  102. /// </summary>
  103. /// <param name="keyValue">主键</param>
  104. public void RemoveForm(string keyValue)
  105. {
  106. IRepository db = new RepositoryFactory().BaseRepository().BeginTrans();
  107. try
  108. {
  109. int count = db.IQueryable<ModuleEntity>(t => t.ParentId == keyValue).Count();
  110. if (count > 0)
  111. {
  112. throw new Exception("当前所选数据有子节点数据!");
  113. }
  114. db.Delete<ModuleEntity>(keyValue);
  115. db.Delete<ModuleButtonEntity>(t => t.ModuleId.Equals(keyValue));
  116. db.Delete<ModuleColumnEntity>(t => t.ModuleId.Equals(keyValue));
  117. db.Commit();
  118. }
  119. catch (Exception)
  120. {
  121. db.Rollback();
  122. throw;
  123. }
  124. }
  125. /// <summary>
  126. /// 保存表单(新增、修改)
  127. /// </summary>
  128. /// <param name="keyValue">主键值</param>
  129. /// <param name="moduleEntity">功能实体</param>
  130. /// <param name="moduleButtonList">按钮实体列表</param>
  131. /// <param name="moduleColumnList">视图实体列表</param>
  132. /// <returns></returns>
  133. public void SaveForm(string keyValue, ModuleEntity moduleEntity, List<ModuleButtonEntity> moduleButtonList, List<ModuleColumnEntity> moduleColumnList)
  134. {
  135. IRepository db = new RepositoryFactory().BaseRepository().BeginTrans();
  136. try
  137. {
  138. if (!string.IsNullOrEmpty(keyValue))
  139. {
  140. moduleEntity.Modify(keyValue);
  141. db.Update(moduleEntity);
  142. }
  143. else
  144. {
  145. moduleEntity.Create();
  146. db.Insert(moduleEntity);
  147. }
  148. db.Delete<ModuleButtonEntity>(t => t.ModuleId.Equals(keyValue));
  149. if (moduleButtonList != null)
  150. {
  151. db.Insert(moduleButtonList);
  152. }
  153. db.Delete<ModuleColumnEntity>(t => t.ModuleId.Equals(keyValue));
  154. if (moduleColumnList != null)
  155. {
  156. db.Insert(moduleColumnList);
  157. }
  158. db.Commit();
  159. }
  160. catch (Exception)
  161. {
  162. db.Rollback();
  163. throw;
  164. }
  165. }
  166. #endregion
  167. }
  168. }