DataDictDetailService.cs 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. using System;
  2. using System.Linq;
  3. using System.Collections.Generic;
  4. using System.Threading.Tasks;
  5. using YiSha.Util;
  6. using YiSha.Util.Extension;
  7. using YiSha.Util.Model;
  8. using YiSha.Data.Repository;
  9. using YiSha.Entity.SystemManage;
  10. using YiSha.Model.Param.SystemManage;
  11. using System.Linq.Expressions;
  12. using YiSha.Enum;
  13. namespace YiSha.Service.SystemManage
  14. {
  15. public partial class DataDictDetailService
  16. {
  17. private IRepositoryFactory _baseRepository;
  18. public DataDictDetailService(IRepositoryFactory baseRepository)
  19. {
  20. _baseRepository = baseRepository;
  21. }
  22. #region 获取数据
  23. public async Task<List<DataDictDetailEntity>> GetListPartial(DataDictDetailListParam param)
  24. {
  25. var expression = ListFilterPartial(param);
  26. var list = await _baseRepository.BaseRepository(dbConnectType).FindList(expression);
  27. return list.OrderBy(p => p.DictSort).ToList();
  28. }
  29. public async Task<List<DataDictDetailEntity>> GetPageListPartial(DataDictDetailListParam param, Pagination pagination)
  30. {
  31. var expression = ListFilterPartial(param);
  32. var list = await _baseRepository.BaseRepository(dbConnectType).FindList(expression, pagination);
  33. return list.ToList();
  34. }
  35. public async Task<DataDictDetailEntity> GetEntityPartial(int id)
  36. {
  37. return await _baseRepository.BaseRepository(dbConnectType).FindEntity<DataDictDetailEntity>(id);
  38. }
  39. public async Task<int> GetMaxSortPartial()
  40. {
  41. object result = await _baseRepository.BaseRepository(dbConnectType).FindObject("SELECT MAX(DictSort) FROM SysDataDictDetail");
  42. int sort = result.ParseToInt();
  43. sort++;
  44. return sort;
  45. }
  46. public bool ExistDictKeyValuePartial(DataDictDetailEntity entity)
  47. {
  48. var expression = LinqExtensions.True<DataDictDetailEntity>();
  49. expression = expression.And(t => t.BaseIsDelete == (int)IsDeleteEnum.No);
  50. if (entity.Id.IsNullOrZero())
  51. {
  52. expression = expression.And(t => t.DictType == entity.DictType && (t.DictKey == entity.DictKey || t.DictValue == entity.DictValue));
  53. }
  54. else
  55. {
  56. expression = expression.And(t => t.DictType == entity.DictType && (t.DictKey == entity.DictKey || t.DictValue == entity.DictValue) && t.Id != entity.Id);
  57. }
  58. return _baseRepository.BaseRepository(dbConnectType).IQueryable(expression).Count() > 0 ? true : false;
  59. }
  60. #endregion
  61. #region 提交数据
  62. public async Task SaveFormPartial(DataDictDetailEntity entity)
  63. {
  64. if (entity.Id.IsNullOrZero())
  65. {
  66. await entity.Create();
  67. await _baseRepository.BaseRepository(dbConnectType).Insert<DataDictDetailEntity>(entity);
  68. }
  69. else
  70. {
  71. await entity.Modify();
  72. await _baseRepository.BaseRepository(dbConnectType).Update<DataDictDetailEntity>(entity);
  73. }
  74. }
  75. #endregion
  76. #region 私有方法
  77. private Expression<Func<DataDictDetailEntity, bool>> ListFilterPartial(DataDictDetailListParam param)
  78. {
  79. var expression = LinqExtensions.True<DataDictDetailEntity>();
  80. expression = expression.And(t => t.BaseIsDelete == (int)IsDeleteEnum.No);
  81. if (param != null)
  82. {
  83. if (param.DictKey.ParseToInt() > 0)
  84. {
  85. expression = expression.And(t => t.DictKey == param.DictKey);
  86. }
  87. if (!string.IsNullOrEmpty(param.DictValue))
  88. {
  89. expression = expression.And(t => t.DictValue.Contains(param.DictValue));
  90. }
  91. if (!string.IsNullOrEmpty(param.DictType))
  92. {
  93. expression = expression.And(t => t.DictType.Contains(param.DictType));
  94. }
  95. }
  96. return expression;
  97. }
  98. #endregion
  99. }
  100. }