郑州市第一人民医院

Sys_Work_UserGroupRepository.cs 8.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  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_UserGroupRepository : BaseRepository<Sys_Work_UserGroup, string>, ISys_Work_UserGroupRepository
  15. {
  16. protected readonly ILogger<BaseRepository<Sys_Work_UserGroup, string>> _logger;
  17. protected readonly IMongoCollection<Sys_Work_Group> _collection_sys_work_group;
  18. protected readonly IMongoCollection<Sys_User_Account> _collection_sys_user_account;
  19. protected readonly IMongoCollection<Sys_Role_Info> _collection_role_info;
  20. public Sys_Work_UserGroupRepository(IOptions<MongodbOptions> settings, ILogger<BaseRepository<Sys_Work_UserGroup, string>> logger) : base(settings, logger)
  21. {
  22. _logger = logger;
  23. _collection_sys_user_account = _context.GetCollection<Sys_User_Account>();
  24. _collection_role_info = _context.GetCollection<Sys_Role_Info>();
  25. _collection_sys_work_group= _context.GetCollection<Sys_Work_Group>();
  26. }
  27. /// <summary>
  28. /// 获取排班人员
  29. /// </summary>
  30. /// <param name="keyword"></param>
  31. /// <returns></returns>
  32. public IEnumerable<object> GetUserList(string projectid, string keyword)
  33. {
  34. var userlist = from p in _collection_sys_user_account.AsQueryable()
  35. join r in _collection_role_info.AsQueryable() on p.role_id equals r.id into roleinfo
  36. where p.delete_flag == false
  37. select new
  38. {
  39. p.head_img,
  40. p.usercode,
  41. p.username,
  42. projectid = p.projectlist != null && p.projectlist.Count() > 0 ? p.projectlist.First() : null,
  43. roleid = p.role_id,
  44. rolecode = roleinfo != null && roleinfo.Count() > 0 ? roleinfo.First().role_code : null,
  45. p.idcardno,
  46. p.remark
  47. };
  48. var wxlist = userlist.Where(p => p.rolecode == "YWYG" || p.rolecode == "YWZG");
  49. if (!string.IsNullOrEmpty(keyword))
  50. wxlist.Where(p => p.usercode.Contains(keyword) || p.username.Contains(keyword));
  51. if (!string.IsNullOrEmpty(projectid))
  52. wxlist = wxlist.Where(p => p.projectid == projectid);
  53. return wxlist;
  54. }
  55. /// <summary>
  56. /// 获取排班详情
  57. /// </summary>
  58. /// <param name="projectid"></param>
  59. /// <param name="startdate"></param>
  60. /// <param name="enddate"></param>
  61. /// <param name="usercode"></param>
  62. /// <param name="groupcode"></param>
  63. /// <returns></returns>
  64. public IEnumerable<object> GetUserGroupList(string projectid, string startdate, string enddate, string usercode, string groupcode)
  65. {
  66. var userlist = from p in _collection_sys_user_account.AsQueryable()
  67. join r in _collection_role_info.AsQueryable() on p.role_id equals r.id into roleinfo
  68. where p.delete_flag == false
  69. select new
  70. {
  71. p.projectlist,
  72. p.head_img,
  73. p.usercode,
  74. p.username,
  75. rolecode = roleinfo != null && roleinfo.Count() > 0 ? roleinfo.First().role_code : null
  76. };
  77. var wxlist = userlist.Where(p => p.rolecode == "YWYG" || p.rolecode == "YWZG");
  78. if (!string.IsNullOrEmpty(projectid))
  79. wxlist = wxlist.Where(p => p.projectlist.Contains(projectid));
  80. if (!string.IsNullOrEmpty(usercode))
  81. wxlist = wxlist.Where(p => p.usercode == usercode);
  82. var datenow = DateTime.Now;
  83. var startdatetime = datenow;
  84. var enddatetime = datenow;
  85. if (!string.IsNullOrEmpty(startdate) && !string.IsNullOrEmpty(enddate))
  86. {
  87. startdatetime = DateTime.Parse(startdate);
  88. enddatetime = DateTime.Parse(enddate);
  89. }
  90. else
  91. {
  92. startdatetime = datenow.AddDays(1 - datenow.Day); //本月月初
  93. enddatetime = startdatetime.AddMonths(1).AddDays(-1); //本月月末
  94. }
  95. var listApp = new List<FilterDefinition<Sys_Work_UserGroup>>();
  96. listApp.Add(Builders<Sys_Work_UserGroup>.Filter.Eq("isdelete", 0));
  97. listApp.Add(Builders<Sys_Work_UserGroup>.Filter.Gte("date", startdatetime.ToString("yyyy-MM-dd")));
  98. listApp.Add(Builders<Sys_Work_UserGroup>.Filter.Lte("date", enddatetime.ToString("yyyy-MM-dd")));
  99. if (!string.IsNullOrEmpty(usercode))
  100. listApp.Add(Builders<Sys_Work_UserGroup>.Filter.Eq("usercode", usercode));
  101. if (!string.IsNullOrEmpty(groupcode))
  102. listApp.Add(Builders<Sys_Work_UserGroup>.Filter.Eq("groupcode", groupcode));
  103. var filter = Builders<Sys_Work_UserGroup>.Filter.And(listApp);
  104. var grouplist = _collection_sys_work_group.AsQueryable().ToList();
  105. var lists = _collection.Find(filter).ToList();
  106. var days = enddatetime.Subtract(startdatetime).Days + 1;
  107. var list = wxlist.ToList().Select(p =>
  108. {
  109. string[] dates = new string[days];
  110. string[] groups = new string[days];
  111. for (int i = 0; i < days; i++)
  112. {
  113. dates[i] = startdatetime.AddDays(i).ToString("yyyy-MM-dd");
  114. groupcode = lists.Where(q => q.usercode == p.usercode && q.date == dates[i]).FirstOrDefault()?.groupcode ?? "";
  115. //if (p.projectlist != null && p.projectlist.Count > 0)
  116. //{
  117. // groups[i] = grouplist.Where(q => q.projectid == p.projectlist[0] && q.code == groupcode).FirstOrDefault()?.name ?? "";
  118. //}
  119. //else
  120. //{
  121. // groups[i] = "";
  122. //}
  123. groups[i] = grouplist.Where(q => q.code == groupcode).FirstOrDefault()?.name ?? "";
  124. }
  125. return new
  126. {
  127. p.head_img,
  128. p.usercode,
  129. p.username,
  130. dates,
  131. groups
  132. };
  133. }).ToList();
  134. return list;
  135. }
  136. /// <summary>
  137. /// 获取用户排班详情
  138. /// </summary>
  139. /// <param name="usercode"></param>
  140. /// <param name="date"></param>
  141. /// <returns></returns>
  142. public object GetUserGroupInfo(string usercode, string date)
  143. {
  144. var query = from p in _collection.AsQueryable()
  145. join r in _collection_sys_work_group.AsQueryable() on p.groupcode equals r.code into groupinfo
  146. join u in _collection_sys_user_account.AsQueryable() on p.usercode equals u.usercode into userinfo
  147. where p.isdelete == 0 && p.usercode == usercode && p.date == date
  148. select new
  149. {
  150. p.usercode,
  151. p.groupcode,
  152. p.date,
  153. username = userinfo != null && userinfo.Count() > 0 ? userinfo.First().username : null,
  154. headimg = userinfo != null && userinfo.Count() > 0 ? userinfo.First().head_img : null,
  155. groupname = groupinfo != null && groupinfo.Count() > 0 ? groupinfo.First().name : null,
  156. starttime = groupinfo != null && groupinfo.Count() > 0 ? groupinfo.First().starttime : null,
  157. endtime = groupinfo != null && groupinfo.Count() > 0 ? groupinfo.First().endtime : null
  158. };
  159. var model = query.FirstOrDefault();
  160. if (model != null)
  161. {
  162. return model;
  163. }
  164. return null;
  165. }
  166. }
  167. }