TourClientListRepository.cs 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. using AutoMapper;
  2. using OASystem.Domain;
  3. using OASystem.Domain.Entities.Groups;
  4. using OASystem.Domain.ViewModels.Groups;
  5. using System;
  6. using System.Collections.Generic;
  7. using System.Linq;
  8. using System.Text;
  9. using System.Threading.Tasks;
  10. namespace OASystem.Infrastructure.Repositories.Groups
  11. {
  12. /// <summary>
  13. /// 接团客户名单
  14. /// 仓库
  15. /// </summary>
  16. public class TourClientListRepository :BaseRepository<Grp_TourClientList,TourClientListView>
  17. {
  18. private readonly Result _result;
  19. private readonly IMapper _mapper;
  20. public TourClientListRepository(SqlSugarClient sqlSugar, IMapper mapper)
  21. : base(sqlSugar)
  22. {
  23. _result = new Result() { Code = -1, Msg = "操作失败!" };
  24. _mapper = mapper;
  25. }
  26. /// <summary>
  27. /// 根据团组Id查询List
  28. /// </summary>
  29. /// <param name="portId"></param>
  30. /// <param name="diId"></param>
  31. /// <returns></returns>
  32. public async Task<Result> _ItemByDiId(int portId, int diId)
  33. {
  34. if (portId == 1 || portId == 2 || portId == 3 ) // 1 web 2 Android 3 ios
  35. {
  36. string sql = string.Format(@"Select tcl.Id,tcl.DiId,temp.* From Grp_TourClientList tcl
  37. Left Join
  38. (Select dc.Id As DcId,dc.LastName,dc.FirstName,ccom.CompanyFullName,dc.Job,cc.CertNo As IDCardNo,dc.Sex
  39. From Crm_DeleClient dc
  40. Left Join Crm_CustomerCompany ccom On dc.CrmCompanyId = ccom.Id And ccom.IsDel = 0
  41. Left Join Crm_CustomerCert cc On dc.Id = cc.DcId And cc.SdId = 773 And cc.IsDel = 0
  42. Where dc.IsDel = 0) temp
  43. On temp.DcId =tcl.ClientId
  44. Where tcl.IsDel = 0 And tcl.DiId = {0}", diId);
  45. var data = await _sqlSugar.SqlQueryable<TourClientListByDiIdView>(sql).ToListAsync();
  46. _result.Code = 0;
  47. _result.Data = data;
  48. }
  49. else
  50. {
  51. _result.Msg = "请传入有效的PortType参数,1 Web 2 Android 3 IOS!";
  52. }
  53. return _result;
  54. }
  55. /// <summary>
  56. /// 根据Id查询Details
  57. /// </summary>
  58. /// <param name="portId"></param>
  59. /// <param name="id"></param>
  60. /// <returns></returns>
  61. public async Task<Result> _Details(int portId, int id)
  62. {
  63. if (portId == 1 || portId == 2 || portId == 3) // 1 web 2 Android 3 ios
  64. {
  65. string sql = string.Format(@"Select tcl.Id,tcl.DiId,temp.*,tcl.ShippingSpaceTypeId,tcl.ShippingSpaceSpecialNeeds,
  66. tcl.HotelSpecialNeeds,tcl.MealSpecialNeeds,tcl.Remark
  67. From Grp_TourClientList tcl
  68. Left Join
  69. (Select dc.Id As DcId,dc.LastName,dc.FirstName,dc.Pinyin,dc.Sex,ccom.CompanyFullName,dc.Job,
  70. cc1.CertNo As IDCardNo,dc.Phone,dc.BirthDay,cc2.PassportType,cc2.CertNo As PassportNo,cc2.Country,
  71. cc2.Area,cc2.IssueDt,cc2.ExpiryDt
  72. From Crm_DeleClient dc
  73. Left Join Crm_CustomerCompany ccom On dc.CrmCompanyId = ccom.Id And ccom.IsDel = 0
  74. Left Join Crm_CustomerCert cc1 On dc.Id = cc1.DcId And cc1.SdId = 773 And cc1.IsDel = 0
  75. Left Join Crm_CustomerCert cc2 On dc.Id = cc2.DcId And cc2.SdId = 774 And cc2.IsDel = 0
  76. Where dc.IsDel = 0) temp
  77. On temp.DcId =tcl.ClientId
  78. Where tcl.IsDel = 0 And tcl.Id = {0}", id);
  79. var data = await _sqlSugar.SqlQueryable<TourClientListDetailsView>(sql).FirstAsync();
  80. _result.Code = 0;
  81. _result.Data = data;
  82. }
  83. else
  84. {
  85. _result.Msg = "请传入有效的PortType参数,1 Web 2 Android 3 IOS!";
  86. }
  87. return _result;
  88. }
  89. }
  90. }