AirTicketResRepository.cs 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227
  1. using AutoMapper;
  2. using OASystem.Domain;
  3. using OASystem.Domain.Dtos.Groups;
  4. using OASystem.Domain.Entities.Groups;
  5. using OASystem.Domain.Entities.Resource;
  6. using OASystem.Domain.ViewModels.Groups;
  7. using System;
  8. using System.Collections.Generic;
  9. using System.Linq;
  10. using System.Text;
  11. using System.Threading.Tasks;
  12. using System.Xml.Linq;
  13. namespace OASystem.Infrastructure.Repositories.Resource
  14. {
  15. public class AirTicketResRepository : BaseRepository<Grp_AirTicketReservations, Grp_AirTicketReservations>
  16. {
  17. private readonly IMapper _mapper;
  18. public AirTicketResRepository(SqlSugarClient sqlSugar, IMapper mapper) : base(sqlSugar)
  19. {
  20. _mapper = mapper;
  21. }
  22. public async Task<Result> AirTicketResList(AirTicketResListDto dto)
  23. {
  24. Result result = new Result() { Code = -2, Msg = "未知错误" };
  25. Grp_DelegationInfo _DelegationInfo = _sqlSugar.Queryable<Grp_DelegationInfo>().First(it => it.Id == dto.DiId);
  26. if (_DelegationInfo != null)
  27. {
  28. string sql = string.Format(@"select a.*,c.IsAuditGM,(select Name from Sys_SetData where Id=a.cType) as 'CTypeName',(select Name from
  29. Sys_SetData where Id=a.PreCurrency) as 'PreCurrencyStr',(select Name from Sys_SetData where Id=a.Currency)
  30. as 'CurrencyStr' from Grp_AirTicketReservations a,Grp_CreditCardPayment c where a.id=c.CId and a.isdel={1}
  31. and a.DIId={0} Order By a.CreateTime desc", dto.DiId, 0);
  32. List<AirTicketReservationsView> _AirTicketReservations = _sqlSugar.SqlQueryable<AirTicketReservationsView>(sql).ToList();
  33. foreach (var item in _AirTicketReservations)
  34. {
  35. if (item.FlightsDescription.Contains("\r\n"))
  36. {
  37. var spilitArr = Regex.Split(item.FlightsDescription, "\r\n");
  38. int rowindex = 1;
  39. foreach (var spilitItem in spilitArr)
  40. {
  41. try
  42. {
  43. var spDotandEmpty = spilitItem.Split('.')[1].Split(' ').Where(x => !string.IsNullOrEmpty(x)).ToList();
  44. var depCode = spDotandEmpty[3].Substring(0, 3);
  45. var arrCode = spDotandEmpty[3].Substring(3, 3);
  46. Res_ThreeCode depData = _sqlSugar.Queryable<Res_ThreeCode>().First(it => it.IsDel == 0 && it.Three == depCode);
  47. Res_ThreeCode arrData = _sqlSugar.Queryable<Res_ThreeCode>().First(it => it.IsDel == 0 && it.Three == arrCode);
  48. string day = spDotandEmpty[2].Substring(2, 2);//日
  49. string monthAbbreviations = spDotandEmpty[1].Substring(4, 3).ToUpper();//月份
  50. switch (monthAbbreviations)
  51. {
  52. case "JAN":
  53. monthAbbreviations = "1";
  54. break;
  55. case "FEB":
  56. monthAbbreviations = "2";
  57. break;
  58. case "MAR":
  59. monthAbbreviations = "3";
  60. break;
  61. case "APR":
  62. monthAbbreviations = "4";
  63. break;
  64. case "MAY":
  65. monthAbbreviations = "5";
  66. break;
  67. case "JUN":
  68. monthAbbreviations = "6";
  69. break;
  70. case "JUL":
  71. monthAbbreviations = "7";
  72. break;
  73. case "AUG":
  74. monthAbbreviations = "8";
  75. break;
  76. case "SEP":
  77. monthAbbreviations = "9";
  78. break;
  79. case "OCT":
  80. monthAbbreviations = "10";
  81. break;
  82. case "NOV":
  83. monthAbbreviations = "11";
  84. break;
  85. case "DEC":
  86. monthAbbreviations = "12";
  87. break;
  88. }
  89. string tate = $"{monthAbbreviations}月{day}日";
  90. item.FlightDescription += rowindex + ". " + depData.AirPort + " " + arrData.AirPort + " (" + tate + ")\r\n";
  91. }
  92. catch (Exception)
  93. {
  94. item.FlightDescription = "录入数据不规范!请检查";
  95. break;
  96. }
  97. rowindex++;
  98. }
  99. }
  100. else
  101. {
  102. try
  103. {
  104. var spDotandEmpty = item.FlightsDescription.Split('.')[1].Split(' ').Where(x => !string.IsNullOrEmpty(x)).ToList();
  105. var depCode = spDotandEmpty[3].Substring(0, 3);
  106. var arrCode = spDotandEmpty[3].Substring(3, 3);
  107. Res_ThreeCode depData = _sqlSugar.Queryable<Res_ThreeCode>().First(it => it.IsDel == 0 && it.Three == depCode);
  108. Res_ThreeCode arrData = _sqlSugar.Queryable<Res_ThreeCode>().First(it => it.IsDel == 0 && it.Three == arrCode);
  109. string day = spDotandEmpty[2].Substring(2, 2);//日
  110. string monthAbbreviations = spDotandEmpty[2].Substring(4, 3).ToUpper();//月份
  111. switch (monthAbbreviations)
  112. {
  113. case "JAN":
  114. monthAbbreviations = "1";
  115. break;
  116. case "FEB":
  117. monthAbbreviations = "2";
  118. break;
  119. case "MAR":
  120. monthAbbreviations = "3";
  121. break;
  122. case "APR":
  123. monthAbbreviations = "4";
  124. break;
  125. case "MAY":
  126. monthAbbreviations = "5";
  127. break;
  128. case "JUN":
  129. monthAbbreviations = "6";
  130. break;
  131. case "JUL":
  132. monthAbbreviations = "7";
  133. break;
  134. case "AUG":
  135. monthAbbreviations = "8";
  136. break;
  137. case "SEP":
  138. monthAbbreviations = "9";
  139. break;
  140. case "OCT":
  141. monthAbbreviations = "10";
  142. break;
  143. case "NOV":
  144. monthAbbreviations = "11";
  145. break;
  146. case "DEC":
  147. monthAbbreviations = "12";
  148. break;
  149. }
  150. string tate = $"{monthAbbreviations}月{day}日";
  151. item.FlightDescription +=depData.AirPort + " " + arrData.AirPort + " (" + tate + ")\r\n";
  152. }
  153. catch (Exception)
  154. {
  155. item.FlightDescription = "录入数据不规范!请检查";
  156. }
  157. }
  158. }
  159. //团组成本预算表查询
  160. Grp_GroupCostParameter _GroupCostParameter = _sqlSugar.Queryable<Grp_GroupCostParameter>().First(a=>a.DiId==dto.DiId);
  161. AirGroupCostParameterView _AirgroupCostParameter = _mapper.Map<AirGroupCostParameterView>(_GroupCostParameter);
  162. var data = new
  163. {
  164. DelegationInfo = _DelegationInfo,
  165. AirTicketReservations = _AirTicketReservations,
  166. AirGroupCostParameter= _AirgroupCostParameter
  167. };
  168. return result = new Result() { Code = 0, Msg = "查询成功!", Data = data };
  169. }
  170. else
  171. {
  172. return result = new Result() { Code = -1, Msg = "暂无团组数据!" };
  173. }
  174. }
  175. public async Task<Result> AirTicketResSelect(AirTicketResDto dto)
  176. {
  177. Result result = new Result() { Code = -2, Msg = "未知错误" };
  178. try
  179. {
  180. List<Grp_GroupsTaskAssignment> grp_GroupsTaskAssignment = Query<Grp_GroupsTaskAssignment>(a => a.IsDel == 0 && a.UId == dto.UserId && a.CTId == 85).ToList();
  181. if (grp_GroupsTaskAssignment.Count != 0)
  182. {
  183. string DiId = "";
  184. foreach (var item in grp_GroupsTaskAssignment)
  185. {
  186. DiId += item.DIId + ",";
  187. }
  188. DiId = DiId.Substring(0, DiId.Length - 1);
  189. string sql = string.Format(@"select * from Grp_DelegationInfo where Id in({0}) and IsDel={1}", DiId, 0);
  190. List<Grp_DelegationInfo> grp_Delegations = _sqlSugar.SqlQueryable<Grp_DelegationInfo>(sql).ToList();
  191. if (grp_Delegations.Count == 0)
  192. {
  193. return result = new Result() { Code = -1, Msg = "查询失败!" };
  194. }
  195. List<GroupNameView> grp_NameView = new List<GroupNameView>();
  196. foreach (var item in grp_Delegations)
  197. {
  198. GroupNameView groupNameView = new GroupNameView();
  199. groupNameView.Id = item.Id;
  200. groupNameView.GroupName = item.TeamName;
  201. grp_NameView.Add(groupNameView);
  202. }
  203. return result = new Result() { Code = 0, Msg = "查询成功!", Data = grp_NameView };
  204. }
  205. else
  206. {
  207. return result = new Result() { Code = -1, Msg = "暂无可操作团组" };
  208. }
  209. }
  210. catch (Exception ex)
  211. {
  212. return result = new Result() { Code = -2, Msg = "程序错误" };
  213. throw;
  214. }
  215. }
  216. }
  217. }