MenuManagerModelsService.cs 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. using System;
  2. using System.Collections.Generic;
  3. using System.ComponentModel.DataAnnotations.Schema;
  4. using System.Data.Common;
  5. using System.Linq;
  6. using System.Linq.Expressions;
  7. using System.Threading.Tasks;
  8. using YiSha.Data;
  9. using YiSha.Data.Repository;
  10. using YiSha.Entity.ZxOrTkMenuManagerModels;
  11. using YiSha.Enum.ZX;
  12. using YiSha.Model.Param.TK;
  13. using YiSha.Model.Result.TK;
  14. using YiSha.Util.Extension;
  15. using YiSha.Web.Code;
  16. namespace YiSha.Service.TK
  17. {
  18. /// <summary>
  19. /// 创 建:cmzx
  20. /// 日 期:2021-04-21 09:30
  21. /// 描 述:图库菜单管理服务实现类(部分类)
  22. /// </summary>
  23. public partial class MenuManagerModelsService
  24. {
  25. private IRepositoryFactory _baseRepository;
  26. public MenuManagerModelsService(IRepositoryFactory baseRepository)
  27. {
  28. _baseRepository = baseRepository;
  29. }
  30. /// <summary>
  31. /// 获取资讯彩种类型菜单树
  32. /// </summary>
  33. /// <returns></returns>
  34. public async Task<List<MenuManagerModelsTreeListModel>> GetZxMenuManagerTreeList(MenuManagerModelsListParam param)
  35. {
  36. var expression = ListFilterPartial(param);
  37. //var s = await _baseRepository.BaseRepository(dbConnectType).FindList<MenuManagerModelsCommonEntity>(expression);
  38. try
  39. {
  40. var zxMenuManagerList = await _baseRepository.BaseRepository(dbConnectType).FindList<MenuManagerModelsCommonEntity>(expression);
  41. var result = zxMenuManagerList.ToList().ConvertAll<MenuManagerModelsTreeListModel>(item =>
  42. {
  43. return new MenuManagerModelsTreeListModel
  44. {
  45. Id = item.Id,
  46. ParentId = item.parentId,
  47. MenuName = item.menuName,
  48. ParentName = item.parentName,
  49. SortNo = item.sortNo,
  50. Type = item.type
  51. };
  52. });
  53. return result;
  54. }
  55. catch (Exception ex)
  56. {
  57. throw;
  58. }
  59. }
  60. /// <summary>
  61. /// 保存数据(由于之前数据库设计不规范,无法实现在新增、修改时保存正确的操作用户信息,每张表的创建时间和创建人id、创建人姓名都不一样,且这些字段是必填项)
  62. /// </summary>
  63. /// <param name="entity">实体参数</param>
  64. /// <returns></returns>
  65. public async Task<int> SaveFormPartial(MenuManagerModelsCommonEntity entity)
  66. {
  67. OperatorInfo user = await Operator.Instance.Current(entity.Token);
  68. if (entity.Id.IsNullOrZero())
  69. {
  70. entity.createTime = DateTime.Now;
  71. entity.createUserId = user?.UserId;
  72. entity.createUserName = user?.UserName;
  73. return await _baseRepository.BaseRepository(dbConnectType).Insert(entity);
  74. }
  75. else
  76. {
  77. return await _baseRepository.BaseRepository(dbConnectType).Update(entity);
  78. }
  79. }
  80. /// <summary>
  81. /// 删除数据(由于之前数据库设计不规范,无法实现统一的删除功能,这里需要手动更改)
  82. /// </summary>
  83. /// <param name="ids">主键集合</param>
  84. /// <returns></returns>
  85. public async Task<int> DeleteFormByIdPartial(string ids)
  86. {
  87. ids = $"{string.Join(",", ids.Split(","))}";
  88. var where = $" id in ({ids}) ";
  89. var setField = " isdelete = @IsDelete ";
  90. var parameters = new List<DbParameter>();
  91. parameters.Add(DbParameterExtension.CreateDbParameter("@IsDelete", TkIsDeleteEnum.已删除.ParseToInt(), dbConnectType));
  92. string tableName = typeof(MenuManagerModelsCommonEntity).GetAttributeValue((TableAttribute ta) => ta.Name);
  93. string updateSql = $"update {tableName} set {setField} where {where}";
  94. return await _baseRepository.BaseRepository(dbConnectType).ExecuteBySql(updateSql, DbParameterExtension.ToDbParameter(parameters.ToArray()));
  95. }
  96. #region 私有方法
  97. /// <summary>
  98. /// 列表条件过滤
  99. /// 建议该方法放在Partial部分类中,因为代码生成时当前类会被覆盖(该方法在生成时将会被注释)
  100. /// </summary>
  101. /// <param name="param"></param>
  102. /// <returns></returns>
  103. private Expression<Func<MenuManagerModelsCommonEntity, bool>> ListFilterPartial(MenuManagerModelsListParam param)
  104. {
  105. var expression = LinqExtensions.True<MenuManagerModelsCommonEntity>();
  106. expression = expression.And(d => d.isDelete == false);
  107. if (param != null)
  108. {
  109. if (param.Type != null)
  110. expression = expression.And(d => d.type == param.Type.ParseToInt());
  111. if (!string.IsNullOrEmpty(param.MenuName))
  112. expression = expression.And(d => d.menuName.Contains(param.MenuName));
  113. }
  114. return expression;
  115. }
  116. #endregion
  117. }
  118. }