HotelPriceRepository.cs 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619
  1. using AutoMapper;
  2. using MathNet.Numerics.Statistics.Mcmc;
  3. using MySqlX.XDevAPI.Common;
  4. using NPOI.SS.Formula.Functions;
  5. using OASystem.Domain;
  6. using OASystem.Domain.Dtos.Financial;
  7. using OASystem.Domain.Dtos.Groups;
  8. using OASystem.Domain.Dtos.Resource;
  9. using OASystem.Domain.Entities.Financial;
  10. using OASystem.Domain.Entities.Groups;
  11. using OASystem.Domain.ViewModels.Financial;
  12. using OASystem.Domain.ViewModels.Groups;
  13. using OASystem.Infrastructure.Repositories.Resource;
  14. using OASystem.Infrastructure.Tools;
  15. using Org.BouncyCastle.Asn1.Ocsp;
  16. using SqlSugar;
  17. using StackExchange.Redis;
  18. using System;
  19. using System.Collections.Generic;
  20. using System.Linq;
  21. using System.Text;
  22. using System.Threading.Tasks;
  23. using static NPOI.HSSF.Util.HSSFColor;
  24. using Result = OASystem.Domain.Result;
  25. namespace OASystem.Infrastructure.Repositories.Groups
  26. {
  27. public class HotelPriceRepository : BaseRepository<Grp_HotelReservations, Grp_HotelReservations>
  28. {
  29. private readonly IMapper _mapper;
  30. private readonly Result _result;
  31. private readonly JsonView _view;
  32. private readonly TeamRateRepository _teamRateRep;
  33. private readonly TourClientListRepository _tourClientListRep;
  34. private readonly HotelDataRepository _hotelDataRep;
  35. public HotelPriceRepository(SqlSugarClient sqlSugar, IMapper mapper, TeamRateRepository teamRateRep, TourClientListRepository tourClientListRep, HotelDataRepository hotelDataRep)
  36. :base(sqlSugar)
  37. {
  38. this._mapper = mapper;
  39. _result = new Result() { Code = -1, Msg = MsgTips.Fail };
  40. _view = new JsonView() { Code = 400, Msg = MsgTips.Fail };
  41. _teamRateRep = teamRateRep;
  42. _tourClientListRep = tourClientListRep;
  43. _hotelDataRep = hotelDataRep;
  44. }
  45. /// <summary>
  46. /// 酒店预定
  47. /// Items By DiId
  48. /// </summary>
  49. /// <param name="dto"></param>
  50. /// <returns></returns>
  51. public async Task<JsonView> _ItemsByDiId(int portType,int diId)
  52. {
  53. string sql = string.Format(@"Select row_number() over(order by hr.CheckInDate asc) as Row_Number,
  54. hr.Id,hr.DiId,sd1.Name As GuestType,hr.ReservationsNo,hr.HotelName,hr.CheckInDate,hr.CheckOutDate,
  55. ccp.PayMoney, ccp.PaymentCurrency,sd2.Name PayCurrency,hr.CreateUserId,u.CnName As CreateUserName,
  56. hr.CreateTime,ccp.IsAuditGM,ccp.IsPay
  57. From Grp_HotelReservations hr
  58. Inner Join Grp_CreditCardPayment ccp On hr.DiId = ccp.DIId And hr.Id = ccp.CId
  59. And ccp.CTable = 76
  60. Left Join Sys_SetData sd1 On hr.GTId = sd1.Id
  61. Left Join Sys_SetData sd2 On ccp.PaymentCurrency = sd2.Id
  62. Left Join Sys_Users u On hr.CreateUserId = u.Id
  63. Where hr.IsDel = 0 And ccp.IsDel = 0 And hr.DiId = {0} ", diId);
  64. if (portType == 1 || portType == 2 || portType == 3)
  65. {
  66. var hotelFeeData = await _sqlSugar.SqlQueryable<HotelReservationsItemsView>(sql).ToListAsync();
  67. _view.Code = 200;
  68. _view.Data = hotelFeeData;
  69. _view.Msg = MsgTips.Succeed;
  70. }
  71. else
  72. {
  73. _view.Msg = MsgTips.Port;
  74. }
  75. return _view;
  76. }
  77. /// <summary>
  78. /// 酒店预定
  79. /// basicsData Init
  80. /// </summary>
  81. /// <param name="dto"></param>
  82. /// <returns></returns>
  83. public async Task<JsonView> _BasicsDataInit(int portType, int diId)
  84. {
  85. List<Sys_SetData> _dataSouruce = await _sqlSugar.Queryable<Sys_SetData>().Where(a => a.IsDel == 0).ToListAsync();
  86. if (portType == 1 || portType == 2 || portType == 3)
  87. {
  88. //客人类型
  89. List<Sys_SetData> GuestType = _dataSouruce.Where(a => a.STid == 11).ToList();
  90. List<SetDataInfoView> _GuestType = _mapper.Map<List<SetDataInfoView>>(GuestType);
  91. //预订网站
  92. List<Sys_SetData> BookingWebsite = _dataSouruce.Where(a => a.STid == 12).ToList();
  93. List<SetDataInfoView> _BookingWebsite = _mapper.Map<List<SetDataInfoView>>(BookingWebsite);
  94. //支付方式
  95. List<Sys_SetData> Payment = _dataSouruce.Where(a => a.STid == 14).ToList();
  96. List<SetDataInfoView> _Payment = _mapper.Map<List<SetDataInfoView>>(Payment);
  97. //卡类型
  98. List<Sys_SetData> BankCard = _dataSouruce.Where(a => a.STid == 15).ToList();
  99. List<SetDataCurrencyInfoView> _BankCard = _mapper.Map<List<SetDataCurrencyInfoView>>(BankCard);
  100. //房间入住人类型
  101. List<Sys_SetData> CheckPerson = _dataSouruce.Where(a => a.STid == 71).ToList();
  102. List<SetDataInfoView> _CheckPerson = _mapper.Map<List<SetDataInfoView>>(CheckPerson);
  103. var _teamRateView = await _teamRateRep.PostGroupTeamRateItemByDiIdAndCTableId(portType, diId, 76);
  104. string _CheckVolumeNo = string.Empty;
  105. var checkVoumeNoData = _CreateCheckVolumeNo(diId);
  106. if (checkVoumeNoData.Result.Code == 0)
  107. {
  108. _CheckVolumeNo = checkVoumeNoData.Result.Data;
  109. }
  110. //客户名单
  111. var guestNames = await _tourClientListRep._GuestNameItemByDiId(portType, diId);
  112. var data = new
  113. {
  114. GuestType = _GuestType, //客人分类
  115. Payment = _Payment,
  116. CurrencyList = _teamRateView,
  117. BankCard = _BankCard,
  118. BookingWebsite = _BookingWebsite,
  119. CheckPerson = _CheckPerson,
  120. CheckVolumeNo = _CheckVolumeNo,
  121. GuestName = guestNames
  122. };
  123. _view.Code = 200;
  124. _view.Data = data;
  125. _view.Msg = MsgTips.Succeed;
  126. }
  127. else _view.Msg = MsgTips.Port;
  128. return _view;
  129. }
  130. /// <summary>
  131. /// 酒店预定
  132. /// 创建 入住卷号码
  133. /// </summary>
  134. /// <param name="DiId"></param>
  135. /// <returns></returns>
  136. public async Task<Result> _CreateCheckVolumeNo(int DiId)
  137. {
  138. var groupInfo = await _sqlSugar.Queryable<Grp_DelegationInfo>().Where(it => it.Id == DiId && it.IsDel == 0).FirstAsync();
  139. if (groupInfo != null)
  140. {
  141. if (!string.IsNullOrEmpty(groupInfo.VisitCountry))
  142. {
  143. string no = string.Empty;
  144. string[] countrys = new string[] { };
  145. countrys = groupInfo.VisitCountry.Split('|');
  146. foreach (string country in countrys)
  147. {
  148. //国家城市三字码 未挪数据 暂时用随机数代替
  149. }
  150. no = CommonFun.GetRandomLetter(countrys.Length).ToUpper();
  151. no += CommonFun.GetRandomNumber(2);
  152. _result.Code = 0;
  153. _result.Data = no;
  154. _result.Msg = "入住卷号码 获取成功!";
  155. }
  156. }
  157. return _result;
  158. }
  159. /// <summary>
  160. /// 酒店预定-
  161. /// details
  162. /// </summary>
  163. /// <param name="dto"></param>
  164. /// <returns></returns>
  165. public async Task<JsonView> _Details(int portType, int id)
  166. {
  167. if (id < 0 )
  168. {
  169. _view.Msg = string.Format(@"请输入正确的Id!");
  170. return _view;
  171. }
  172. string sql = string.Format(@"Select hr.Id,hr.DiId,hr.GTId,hr.CheckNumber,hr.ReservationsWebsite,hr.ReservationsNo,
  173. hr.DetermineNo,hr.City,hr.HotelName,hr.HotelTel,hr.HotelAddress,hr.GuestName,hr.CheckInDate,hr.CheckOutDate,
  174. hr.CheckType,hr.RoomExplanation,hr.Remark As HotelRemark,hr.SingleRoomPrice,hr.SingleRoomCount,hr.DoubleRoomPrice,
  175. hr.DoubleRoomCount,hr.SuiteRoomPrice,hr.SuiteRoomCount,hr.OtherRoomPrice,hr.OtherRoomCount,hr.CardPrice,hr.CardPriceCurrency,
  176. hr.Isoppay,hr.BreakfastPrice,hr.BreakfastCurrency,hr.GovernmentRent,hr.GovernmentRentCurrency,hr.CityTax,
  177. hr.CityTaxCurrency,ccp.PayDId,ccp.ConsumptionPatterns,ccp.ConsumptionDate,ccp.PayMoney,ccp.PaymentCurrency,
  178. ccp.BankNo,ccp.CardholderName,ccp.CompanyBankNo,ccp.OtherBankName,ccp.OtherSideNo,ccp.OtherSideName,ccp.Payee,
  179. ccp.OrbitalPrivateTransfer,ccp.Remark As CcpRemark
  180. From Grp_HotelReservations hr
  181. Inner Join Grp_CreditCardPayment ccp On hr.DiId = ccp.DIId And hr.Id = ccp.CId
  182. And ccp.CTable = 76
  183. Where hr.IsDel = 0 And ccp.IsDel = 0 And hr.Id = {0}", id);
  184. if (portType == 1 || portType == 2 || portType == 3)
  185. {
  186. var info = await _sqlSugar.SqlQueryable<HotelReservationsDetailsView>(sql).FirstAsync();
  187. string contentSql = string.Format($@"Select
  188. Id,
  189. DiId,
  190. HrId,
  191. PriceType,
  192. Price,
  193. Currency,
  194. Rate,
  195. IsOppay,
  196. PayDId,
  197. ConsumptionPatterns,
  198. ConsumptionDate,
  199. CTDId,
  200. BankNo,
  201. CardholderName,
  202. CompanyBankNo,
  203. OtherBankName,
  204. OtherSideNo,
  205. OtherSideName,
  206. IsPay,
  207. Payee,
  208. OrbitalPrivateTransfer
  209. From Grp_HotelReservationsContent With(NoLock)
  210. Where IsDel = 0 And HrId = {info.Id}");
  211. info.Contents = await _sqlSugar.SqlQueryable<HotelReservationsContnetDetailsView>(contentSql).ToListAsync();
  212. _view.Code = 200;
  213. _view.Data = info;
  214. _view.Msg = MsgTips.Succeed;
  215. }
  216. else _view.Msg = MsgTips.Port;
  217. return _view;
  218. }
  219. /// <summary>
  220. /// 酒店预定
  221. /// Add Or Edit
  222. /// </summary>
  223. /// <returns></returns>
  224. public async Task<JsonView> _AddOrEdit(HotelReservationsAddOrEditDto _dto)
  225. {
  226. var _view = new JsonView() { Code = 400, Msg = MsgTips.Fail };
  227. int portType = _dto.PortType;
  228. if (portType == 1 || portType == 2 || portType == 3)
  229. {
  230. Grp_HotelReservations _HotelReservations = new Grp_HotelReservations();
  231. List<Grp_HotelReservationsContent> _HotelReservationsContents = new List<Grp_HotelReservationsContent>();
  232. Grp_CreditCardPayment _CreditCardPayment = new Grp_CreditCardPayment();
  233. #region 参数处理
  234. _HotelReservations = _mapper.Map<Grp_HotelReservations>(_dto);
  235. _HotelReservationsContents = _mapper.Map<List<Grp_HotelReservationsContent>>(_dto.Contents);
  236. _CreditCardPayment = _mapper.Map<Grp_CreditCardPayment>(_dto);
  237. _HotelReservations.DiId = _dto.DiId;
  238. _HotelReservations.CreateUserId = _dto.UserId;
  239. _HotelReservations.Remark = _dto.HotelRemark;
  240. #region 子表币种汇率处理
  241. //List<Sys_SetData> currData = await _sqlSugar.Queryable<Sys_SetData>().Where(a => a.IsDel == 0 && a.STid == 66).ToListAsync();
  242. //List<TeamRateModelView> teamRateModelViews = new List<TeamRateModelView>();
  243. //teamRateModelViews = await _teamRateRep.PostGroupRateInfoByDiId(_dto.DiId);
  244. //if (teamRateModelViews.Count < 0)
  245. //{
  246. // _view.Msg = "该团未设置酒店预订模块相关币种汇率!";
  247. // return _view;
  248. //}
  249. //TeamRateModelView teamRateModels_hotel = new TeamRateModelView();
  250. //teamRateModels_hotel = teamRateModelViews.Where(it => it.CTableId == 76).FirstOrDefault();
  251. //if (teamRateModels_hotel == null)
  252. //{
  253. // _view.Msg = "该团未设置酒店预订模块相关币种汇率!";
  254. // return _view;
  255. //}
  256. //List<TeamRateDescView> teamRateDescViews = new List<TeamRateDescView>();
  257. //teamRateDescViews = teamRateModels_hotel.TeamRates;
  258. //if (teamRateDescViews.Count < 0)
  259. //{
  260. // _view.Msg = "该团未设置酒店预订模块相关币种汇率!";
  261. // return _view;
  262. //}
  263. #endregion
  264. _HotelReservationsContents.ForEach(it => {
  265. it.CreateUserId = _dto.UserId;
  266. it.DiId = _dto.DiId;
  267. it.HrId = _HotelReservations.Id;
  268. if (it.PayDId == 72) it.IsPay = 1;
  269. else it.IsPay = 0;
  270. if (!string.IsNullOrEmpty(it.ConsumptionDate))
  271. {
  272. if (DateTime.TryParse(it.ConsumptionDate, out DateTime dt))
  273. {
  274. it.ConsumptionDate = dt.ToString("yyyy-MM-dd");
  275. }
  276. }
  277. //var currCode = currData.Find(x => x.Id == it.Currency)?.Name;
  278. //decimal? currRate = teamRateDescViews.Find(x => x.CurrencyCode == currCode)?.Rate;
  279. //it.Rate = currRate ?? 0.00M;
  280. });
  281. _HotelReservationsContents = _HotelReservationsContents.OrderBy(x => x.PriceType).ToList();
  282. if (portType == 2 || portType == 3)
  283. {
  284. string checkNo = string.Empty;
  285. Result checkNoRes = await _CreateCheckVolumeNo(_dto.DiId);
  286. if (checkNoRes.Code == 0)
  287. {
  288. checkNo = checkNoRes.Data;
  289. _HotelReservations.CheckNumber = checkNo;
  290. }
  291. }
  292. #region CCP 表参数
  293. _CreditCardPayment.CreateUserId = _dto.UserId;
  294. _CreditCardPayment.DIId = _dto.DiId;
  295. _CreditCardPayment.CTable = 76;
  296. _CreditCardPayment.PayMoney = _dto.CardPrice;
  297. _CreditCardPayment.PaymentCurrency = _dto.CardPriceCurrency;
  298. decimal ccpRate = 1.0000M;
  299. if (_dto.CardPriceCurrency != 836) ccpRate = _dto.Contents.Find(x => x.Currency == _dto.CardPriceCurrency)?.Rate ?? 1.0000M;
  300. _CreditCardPayment.DayRate = ccpRate;
  301. _CreditCardPayment.PayPercentage = 100.00M;
  302. _CreditCardPayment.PayThenMoney = _CreditCardPayment.PayMoney;
  303. _CreditCardPayment.RMBPrice = (_CreditCardPayment.DayRate * _CreditCardPayment.PayMoney).DecimalsKeepTwo();
  304. //if (_CreditCardPayment.PayDId == 72) //刷卡
  305. //{
  306. // _CreditCardPayment.BankNo = "6222 **** **** 7990";
  307. // _CreditCardPayment.CardholderName = "Zhang Hailin";
  308. //}
  309. _CreditCardPayment.Remark = _dto.CcpRemark;
  310. #endregion
  311. #endregion
  312. if (_dto.Id == 0) // Add
  313. {
  314. _sqlSugar.BeginTran();
  315. int hotelId = await _sqlSugar.Insertable<Grp_HotelReservations>(_HotelReservations).ExecuteReturnIdentityAsync();
  316. if (hotelId < 0)
  317. {
  318. _sqlSugar.RollbackTran(); //回滚
  319. _view.Msg = $"酒店预定信息添加失败!";
  320. return _view;
  321. }
  322. _HotelReservationsContents.ForEach(it => {
  323. it.HrId = hotelId;
  324. });
  325. int hotelSubId = await _sqlSugar.Insertable<Grp_HotelReservationsContent>(_HotelReservationsContents).ExecuteReturnIdentityAsync();
  326. if (hotelSubId < 0)
  327. {
  328. _sqlSugar.RollbackTran(); //回滚
  329. _view.Msg = "酒店预定详细信息添加失败";
  330. return _view;
  331. }
  332. _CreditCardPayment.CId = hotelId;
  333. _CreditCardPayment.CTable = 76; //酒店预定模块
  334. int ccpId = await _sqlSugar.Insertable<Grp_CreditCardPayment>(_CreditCardPayment).ExecuteReturnIdentityAsync();
  335. if (ccpId < 0)
  336. {
  337. _view.Msg = "付款信息添加失败!";
  338. _sqlSugar.RollbackTran(); //回滚
  339. return _view;
  340. }
  341. #region 酒店基础数据 添加
  342. var hotelDataReq = new OperationHotelDto()
  343. {
  344. Status = 1,
  345. City = _dto.City,
  346. Name = _dto.HotelName,
  347. Tel = _dto.HotelTel,
  348. Address = _dto.HotelAddress
  349. };
  350. await _hotelDataRep.OperationHotelData(hotelDataReq);
  351. #endregion
  352. _view.Msg = "操作成功!";
  353. _view.Code = 200;
  354. _view.Data = new { ccpId = ccpId, sign = 1, hotelId = hotelId };
  355. _sqlSugar.CommitTran(); // 提交
  356. return _view;
  357. }
  358. else if (_dto.Id > 0) //Edit
  359. {
  360. _sqlSugar.BeginTran();
  361. int hotelStatus = await _sqlSugar.Updateable<Grp_HotelReservations>(_HotelReservations)
  362. .UpdateColumns(it => new
  363. {
  364. it.GTId,
  365. it.CheckNumber,
  366. it.ReservationsWebsite,
  367. it.ReservationsNo,
  368. it.DetermineNo,
  369. it.City,
  370. it.HotelName,
  371. it.HotelTel,
  372. it.HotelAddress,
  373. it.GuestName,
  374. it.CheckInDate,
  375. it.CheckOutDate,
  376. it.CheckType,
  377. it.RoomExplanation,
  378. it.SingleRoomPrice,
  379. it.SingleRoomCount,
  380. it.DoubleRoomPrice,
  381. it.DoubleRoomCount,
  382. it.SuiteRoomPrice,
  383. it.SuiteRoomCount,
  384. it.OtherRoomPrice,
  385. it.OtherRoomCount,
  386. it.CardPrice,
  387. it.CardPriceCurrency,
  388. it.Remark,
  389. })
  390. .WhereColumns(it => it.Id)
  391. .ExecuteCommandAsync();
  392. if (hotelStatus < 0)
  393. {
  394. _view.Msg = "酒店预定信息修改失败!";
  395. _sqlSugar.RollbackTran(); //回滚
  396. return _view;
  397. }
  398. var hotelSubStatus = false;
  399. var addHotelSubData = _HotelReservationsContents.Where(it => it.Id == 0).ToList();
  400. var updateHotelSubData = _HotelReservationsContents.Where(it => it.Id != 0).ToList();
  401. if (addHotelSubData.Count > 0)
  402. {
  403. int hotelSubAdd = await _sqlSugar.Insertable<Grp_HotelReservationsContent>(addHotelSubData).ExecuteCommandAsync();
  404. if (hotelSubAdd > 0) hotelSubStatus = true;
  405. }
  406. if (updateHotelSubData.Count > 0)
  407. {
  408. int hotelSubUpdate = await _sqlSugar.Updateable<Grp_HotelReservationsContent>(updateHotelSubData)
  409. .IgnoreColumns(it => new {
  410. it.DiId,
  411. it.HrId,
  412. it.CreateUserId,
  413. it.CreateTime,
  414. it.DeleteUserId,
  415. it.DeleteTime
  416. })
  417. .WhereColumns(it => it.Id)
  418. .ExecuteCommandAsync();
  419. if (hotelSubUpdate > 0) hotelSubStatus = true;
  420. }
  421. if (!hotelSubStatus)
  422. {
  423. _view.Msg = "酒店预定子表信息修改失败!";
  424. _sqlSugar.RollbackTran(); //回滚
  425. return _view;
  426. }
  427. var hotelInfo = await _sqlSugar.Queryable<Grp_CreditCardPayment>()
  428. .Where(it => it.DIId == _dto.DiId &&
  429. it.CId == _dto.Id &&
  430. it.CTable == 76 &&
  431. it.IsDel == 0
  432. )
  433. .FirstAsync();
  434. if (hotelInfo == null) //ccp表 Add
  435. {
  436. }
  437. else //ccp表 Edit
  438. {
  439. _CreditCardPayment.Id = hotelInfo.Id;
  440. int creditCardStatus = await _sqlSugar.Updateable(_CreditCardPayment)
  441. .UpdateColumns(it => new
  442. {
  443. it.CTDId,
  444. it.PayDId,
  445. it.IsPay,
  446. it.ConsumptionPatterns,
  447. it.ConsumptionDate,
  448. it.PayMoney,
  449. it.PaymentCurrency,
  450. it.PayThenMoney,
  451. it.DayRate,
  452. it.RMBPrice,
  453. it.BankNo,
  454. it.CardholderName,
  455. it.CompanyBankNo,
  456. it.OtherBankName,
  457. it.OtherSideNo,
  458. it.OtherSideName,
  459. it.Payee,
  460. it.OrbitalPrivateTransfer,
  461. it.Remark,
  462. })
  463. .WhereColumns(it => it.Id)
  464. .ExecuteCommandAsync();
  465. if (creditCardStatus < 0)
  466. {
  467. _view.Msg = "付款信息表修改失败!";
  468. _sqlSugar.RollbackTran(); //回滚
  469. return _view;
  470. }
  471. }
  472. _view.Msg = "操作成功!";
  473. _view.Code = 200;
  474. _view.Data = new { ccpId = _CreditCardPayment.Id, sign = 2 ,hotelId = _HotelReservations.Id };
  475. _sqlSugar.CommitTran(); // 提交
  476. return _view;
  477. }
  478. else if (_dto.Id < 0) _view.Msg = MsgTips.Id;
  479. }
  480. else _view.Msg = MsgTips.Port;
  481. return _view;
  482. }
  483. /// <summary>
  484. /// 酒店预定
  485. /// Del
  486. /// </summary>
  487. /// <returns></returns>
  488. public async Task<JsonView> _Del(int id,int userId)
  489. {
  490. _sqlSugar.BeginTran();
  491. Grp_HotelReservations _HotelReservations = new Grp_HotelReservations()
  492. {
  493. Id = id,
  494. IsDel = 1,
  495. DeleteUserId = userId,
  496. DeleteTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")
  497. };
  498. int hrStatus = await _sqlSugar.Updateable<Grp_HotelReservations>(_HotelReservations)
  499. .UpdateColumns(it => new
  500. {
  501. it.IsDel,
  502. it.DeleteUserId,
  503. it.DeleteTime,
  504. })
  505. .WhereColumns(it => it.Id)
  506. .ExecuteCommandAsync();
  507. if (hrStatus < 0)
  508. {
  509. _sqlSugar.RollbackTran();
  510. return new JsonView() { Code = 400,Msg = MsgTips.Fail };
  511. }
  512. int hrSubStatus = await _sqlSugar.Updateable<Grp_HotelReservationsContent>()
  513. .SetColumns(it => it.IsDel == 1)
  514. .SetColumns(it => it.DeleteUserId == userId)
  515. .SetColumns(it => it.DeleteTime == DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"))
  516. .Where(it => it.HrId == id).ExecuteCommandAsync();
  517. var ccpInfp = new Grp_CreditCardPayment() {
  518. CId = id,
  519. CTable = 76,
  520. IsDel = 1,
  521. DeleteUserId = userId,
  522. DeleteTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")
  523. };
  524. int hrCCPStatus = await _sqlSugar.Updateable<Grp_CreditCardPayment>(ccpInfp)
  525. .UpdateColumns(it => new
  526. {
  527. it.IsDel,
  528. it.DeleteUserId,
  529. it.DeleteTime,
  530. })
  531. .WhereColumns(it => new { it.CTable, it.CId })
  532. .ExecuteCommandAsync();
  533. _sqlSugar.CommitTran();
  534. return new JsonView() { Code = 200, Msg = MsgTips.Succeed };
  535. }
  536. }
  537. }