郑州市第一人民医院

Sys_Work_ClassGroupRepository.cs 5.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. using MadRunFabric.Common;
  2. using MadRunFabric.Common.Options;
  3. using MadRunFabric.Model;
  4. using Microsoft.Extensions.Logging;
  5. using Microsoft.Extensions.Options;
  6. using MongoDB.Driver;
  7. using SignTokenApi.IRepositories;
  8. using System;
  9. using System.Collections.Generic;
  10. using System.Text;
  11. using System.Linq;
  12. namespace SignTokenApi.Repositories
  13. {
  14. public class Sys_Work_ClassGroupRepository : BaseRepository<Sys_Work_ClassGroup, string>, ISys_Work_ClassGroupRepository
  15. {
  16. protected readonly ILogger<BaseRepository<Sys_Work_ClassGroup, string>> _logger;
  17. protected readonly IMongoCollection<Pro_Project_Info> _collection_pro_project_info;
  18. protected readonly IMongoCollection<Sys_DictionaryValue> _collection_sys_dictionaryvalue;
  19. public Sys_Work_ClassGroupRepository(
  20. IOptions<MongodbOptions> settings,
  21. ILogger<BaseRepository<Sys_Work_ClassGroup, string>> logger) : base(settings, logger)
  22. {
  23. _collection_pro_project_info = _context.GetCollection<Pro_Project_Info>(); //获取集合
  24. _collection_sys_dictionaryvalue = _context.GetCollection<Sys_DictionaryValue>();
  25. _logger = logger;
  26. }
  27. /// <summary>
  28. /// 获取分页
  29. /// </summary>
  30. /// <param name="projectid"></param>
  31. /// <param name="keyword"></param>
  32. /// <param name="userinfo"></param>
  33. /// <param name="pageindex"></param>
  34. /// <param name="pagesize"></param>
  35. /// <param name="recordcount"></param>
  36. /// <returns></returns>
  37. public IEnumerable<object> GetListsByPage(string keyword, string projectid, UserInfoModel userinfo, int pageIndex, int pageSize, out int recordCount)
  38. {
  39. var query =
  40. from p in _collection.AsQueryable()
  41. join proje in _collection_pro_project_info.AsQueryable() on p.projectid equals proje.id into projeDefa
  42. join dic_protype in _collection_sys_dictionaryvalue.AsQueryable() on p.usertype equals dic_protype.id into dic_usertypeDefa
  43. where p.isdelete == 0
  44. orderby p.starttime ascending
  45. select new
  46. {
  47. p.id,
  48. p.projectid,
  49. projectname = projeDefa.Count() > 0 ? projeDefa.First().project_name : "",
  50. p.usertype,
  51. usertypename = dic_usertypeDefa.Count() > 0 ? dic_usertypeDefa.First().name : null,
  52. p.code,
  53. p.name,
  54. p.starttime,
  55. p.endtime,
  56. p.remark,
  57. p.createby,
  58. p.createtime,
  59. p.isdelete
  60. };
  61. #region 查询条件
  62. if (!string.IsNullOrEmpty(projectid))
  63. query = query.Where(it => it.projectid.Equals(projectid));
  64. if (!string.IsNullOrEmpty(keyword))
  65. query = query.Where(it => it.name.Contains(keyword) || it.code.Contains(keyword));
  66. if (userinfo.isallproject == 0)
  67. query = query.Where(it => userinfo.projectlist.Contains(it.projectid));
  68. #endregion
  69. //排班排序
  70. DateTime dtNow = DateTime.Now;
  71. string dayNow = dtNow.ToString("yyyy-MM-dd");
  72. var lists = query.ToList();
  73. var result = lists.Select(p => new
  74. {
  75. id = p.id,
  76. projectid = p.projectid,
  77. projectname = p.projectname,
  78. usertype = p.usertype,
  79. usertypename = p.usertypename,
  80. code = p.code,
  81. name = p.name,
  82. starttime = p.starttime,
  83. endtime = p.endtime,
  84. orderbytime = DateTime.Parse(dayNow + " " + p.starttime),
  85. remark = p.remark,
  86. createby = p.createby,
  87. createtime = p.createtime,
  88. isdelete = p.isdelete
  89. }).ToList();
  90. recordCount = result.Count();
  91. var list = result.OrderBy(it => it.orderbytime).Skip((pageIndex - 1) * pageSize).Take(pageSize);
  92. //recordCount = query.Count();
  93. //var list = query.OrderByDescending(it => it.createtime).Skip((pageIndex - 1) * pageSize).Take(pageSize);
  94. return list;
  95. }
  96. /// <summary>
  97. /// 获取详情
  98. /// </summary>
  99. /// <param name="id"></param>
  100. /// <returns></returns>
  101. public object GetDetails(string id)
  102. {
  103. var query =
  104. from p in _collection.AsQueryable()
  105. join proje in _collection_pro_project_info.AsQueryable() on p.projectid equals proje.id into projeDefa
  106. join dic_protype in _collection_sys_dictionaryvalue.AsQueryable() on p.usertype equals dic_protype.id into dic_usertypeDefa
  107. where p.isdelete == 0 && p.id == id
  108. select new
  109. {
  110. p.id,
  111. p.projectid,
  112. projectname = projeDefa.Count() > 0 ? projeDefa.First().project_name : "",
  113. p.usertype,
  114. usertypename = dic_usertypeDefa.Count() > 0 ? dic_usertypeDefa.First().name : null,
  115. p.code,
  116. p.name,
  117. p.starttime,
  118. p.endtime,
  119. p.remark,
  120. p.createby,
  121. p.createtime,
  122. p.isdelete
  123. };
  124. var model = query.FirstOrDefault();
  125. if (model != null)
  126. {
  127. return model;
  128. }
  129. return null;
  130. }
  131. }
  132. }