BuildingService.cs 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  1. using Bowin.Common.Linq.Entity;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6. using YLShipBuildLandMap.Entity;
  7. using YLShipBuildLandMap.Entity.ViewModel.Build;
  8. using System.Linq;
  9. using System.Linq.Expressions;
  10. using System.Text;
  11. using System.Threading.Tasks;
  12. using Z.EntityFramework.Plus;
  13. using YLShipBuildLandMap.Entity.ViewModel;
  14. using YLShipBuildLandMap.Entity.Extensions;
  15. namespace YLShipBuildLandMap.Services.Build
  16. {
  17. public class BuildingService : IBuildingService
  18. {
  19. private YLShipBuildLandMapContext DbContext { get; set; }
  20. public BuildingService(YLShipBuildLandMapContext dbContext)
  21. {
  22. DbContext = dbContext;
  23. }
  24. private IQueryable<BuildingView> GetBuildingQuery(Expression<Func<BdBuilding, bool>> exp)
  25. {
  26. var query = from b in DbContext.BdBuilding.Where(exp)
  27. /*join f in DbContext.BdBuildingFloor on b.BuildingId equals f.BuildingId into dbFloor
  28. from f in dbFloor.DefaultIfEmpty()
  29. group new { floorName = f.Name } by new { b } into g
  30. select new BuildingView
  31. {
  32. BuildingId = g.Key.b.BuildingId,
  33. Name = g.Key.b.Name,
  34. RecordStatus = g.Key.b.RecordStatus,
  35. CreateUserId = g.Key.b.CreateUserId,
  36. CreateTime = g.Key.b.CreateTime,
  37. ModifyTime = g.Key.b.ModifyTime,
  38. ModifyUserId = g.Key.b.ModifyUserId,
  39. FloorList = string.Join(",", g.Select(s => s.floorName)),
  40. };*/
  41. select new BuildingView
  42. {
  43. BuildingId = b.BuildingId,
  44. Name = b.Name,
  45. RecordStatus = b.RecordStatus,
  46. CreateUserId = b.CreateUserId,
  47. CreateTime = b.CreateTime,
  48. ModifyTime = b.ModifyTime,
  49. ModifyUserId = b.ModifyUserId,
  50. FloorList = string.Join("、", b.BdBuildingFloor.OrderBy(f => f.Sort).Select(s => s.Name))
  51. };
  52. return query;
  53. }
  54. public Task<List<BuildingView>> GetBuildingList()
  55. {
  56. return Task.FromResult(GetBuildingQuery(e => true).OrderBy(e => e.Name).ToList());
  57. }
  58. public Task<List<FloorView>> GetFloorList(Guid buildingId)
  59. {
  60. var query = from f in DbContext.BdBuildingFloor
  61. join b in DbContext.BdBuilding on f.BuildingId equals b.BuildingId
  62. where f.BuildingId == buildingId
  63. select new FloorView
  64. {
  65. BuildingFloorId = f.BuildingFloorId,
  66. Name = f.Name,
  67. BuildingName = b.Name,
  68. Sort = f.Sort,
  69. RecordStatus = f.RecordStatus
  70. };
  71. return Task.FromResult(query.OrderBy(e => e.Sort).ToList());
  72. }
  73. public Task<BuildingView> GetBuildingById(Guid? buildingId)
  74. {
  75. if (!buildingId.HasValue)
  76. return Task.FromResult(new BuildingView { BuildingId = Guid.NewGuid() });
  77. return Task.FromResult(GetBuildingQuery(e => e.BuildingId == buildingId).FirstOrDefault());
  78. }
  79. public async Task<int> DeleteBuilding(List<Guid> buildingIdList)
  80. {
  81. var floorIdList = DbContext.BdBuildingFloor.Where(e => buildingIdList.Contains((Guid)e.BuildingId)).Select(s => s.BuildingFloorId).ToList();
  82. var roomIdList = DbContext.BdBuildingFloorRoom.Where(e => floorIdList.Contains(e.BuildingFloorRoomId)).Select(s => s.BuildingFloorRoomId).ToList();
  83. await DbContext.BdDepartmentOrServicePointBmBuildingFloorRoom.Where(e => roomIdList.Contains(e.BuildingFloorRoomId)).DeleteAsync();
  84. await DbContext.BdBuildingFloorRoom.Where(e => roomIdList.Contains(e.BuildingFloorRoomId)).DeleteAsync();
  85. await DbContext.BdBuildingFloor.Where(e => floorIdList.Contains(e.BuildingFloorId)).DeleteAsync();
  86. await DbContext.BdBuilding.Where(e => buildingIdList.Contains(e.BuildingId)).DeleteAsync();
  87. await DbContext.BdBuildingXyAxis.Where(e => buildingIdList.Contains((Guid)e.BuildingId)).DeleteAsync();
  88. return await this.DbContext.SaveChangesAsync();
  89. }
  90. public async Task<int> DeleteFloor(Guid buildingFloorId)
  91. {
  92. var roomIdList = DbContext.BdBuildingFloorRoom.Where(e => e.BuildingFloorId == buildingFloorId).Select(s => s.BuildingFloorRoomId).ToList();
  93. await DbContext.BdDepartmentOrServicePointBmBuildingFloorRoom.Where(e => roomIdList.Contains(e.BuildingFloorRoomId)).DeleteAsync();
  94. await DbContext.BdBuildingFloorRoom.Where(e => roomIdList.Contains(e.BuildingFloorRoomId)).DeleteAsync();
  95. await DbContext.BdBuildingFloor.Where(e => e.BuildingFloorId == buildingFloorId).DeleteAsync();
  96. return await this.DbContext.SaveChangesAsync();
  97. }
  98. public async Task<int> SaveBuilding(BuildingView data, List<FloorView> floorList, Guid? userId)
  99. {
  100. BdBuilding dbData = DbContext.BdBuilding.FirstOrDefault(e => e.BuildingId == data.BuildingId);
  101. if (dbData != null)
  102. {
  103. dbData.Name = data.Name;
  104. dbData.ModifyTime = DateTime.Now;
  105. dbData.ModifyUserId = userId;
  106. DbContext.BdBuilding.Update(dbData);
  107. }
  108. else
  109. {
  110. dbData = new BdBuilding
  111. {
  112. BuildingId = data.BuildingId,
  113. Name = data.Name,
  114. CreateTime = DateTime.Now,
  115. CreateUserId = userId
  116. };
  117. this.DbContext.Add(dbData);
  118. }
  119. floorList.ForEach(floor =>
  120. {
  121. var dbFloor = this.DbContext.BdBuildingFloor.Where(e => e.BuildingFloorId == floor.BuildingFloorId).FirstOrDefault();
  122. if (dbFloor == null)
  123. {
  124. dbFloor = new BdBuildingFloor
  125. {
  126. BuildingFloorId = Guid.NewGuid(),
  127. BuildingId = dbData.BuildingId,
  128. Name = floor.Name,
  129. Sort = floor.Sort,
  130. CreateTime = DateTime.Now,
  131. CreateUserId = userId
  132. };
  133. this.DbContext.BdBuildingFloor.Add(dbFloor);
  134. }
  135. else
  136. {
  137. dbFloor.Sort = floor.Sort;
  138. dbFloor.Name = floor.Name;
  139. dbFloor.ModifyTime = DateTime.Now;
  140. dbFloor.ModifyUserId = userId;
  141. DbContext.BdBuildingFloor.Update(dbFloor);
  142. }
  143. });
  144. return await this.DbContext.SaveChangesAsync();
  145. }
  146. public Task<List<BuildingXyAxisView>> GetBuildingXYAxisList(Guid? buildingId)
  147. {
  148. Expression<Func<BdBuilding, bool>> exp = e => true;
  149. exp = exp.AndIf(buildingId.HasValue, e => e.BuildingId == buildingId);
  150. var query = from b in DbContext.BdBuilding.Where(exp)
  151. join xy in DbContext.BdBuildingXyAxis on b.BuildingId equals xy.BuildingId
  152. select new BuildingXyAxisView
  153. {
  154. BuildingId = b.BuildingId,
  155. XyaxisId = xy.XyaxisId,
  156. BuildingName = b.Name,
  157. Xaxis = xy.Xaxis,
  158. Yaxis = xy.Yaxis
  159. };
  160. return Task.FromResult(query.OrderBy(e => e.BuildingName).ThenBy(e => e.Xaxis).ThenBy(e => e.Yaxis).ToList());
  161. }
  162. public Task<List<BuildingXyAxisGroupView>> GetBuildingXyAxisGroupList(Guid? buildingId)
  163. {
  164. Expression<Func<BdBuilding, bool>> exp = e => true;
  165. exp = exp.AndIf(buildingId.HasValue, e => e.BuildingId == buildingId);
  166. var query = from b in DbContext.BdBuilding.Where(exp)
  167. join xy in DbContext.BdBuildingXyAxis on b.BuildingId equals xy.BuildingId
  168. group new { xy } by new { b.BuildingId, b.Name } into g
  169. select new BuildingXyAxisGroupView
  170. {
  171. BuildingId = g.Key.BuildingId,
  172. BuildingName = g.Key.Name,
  173. MinXAxis = g.Min(e => e.xy.Xaxis),
  174. MaxXAxis = g.Max(e => e.xy.Xaxis),
  175. MinYAxis = g.Min(e => e.xy.Yaxis),
  176. MaxYAxis = g.Max(e => e.xy.Yaxis),
  177. };
  178. return Task.FromResult(query.OrderBy(e => e.BuildingName).ThenBy(e => e.MinXAxis).ThenBy(e => e.MinYAxis).ToList());
  179. }
  180. }
  181. }