DelegationInfoRepository.cs 52 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225
  1. using AutoMapper;
  2. using Newtonsoft.Json;
  3. using NPOI.OpenXmlFormats.Wordprocessing;
  4. using NPOI.SS.Formula.Functions;
  5. using OASystem.Domain;
  6. using OASystem.Domain.AesEncryption;
  7. using OASystem.Domain.Dtos;
  8. using OASystem.Domain.Dtos.Financial;
  9. using OASystem.Domain.Dtos.Groups;
  10. using OASystem.Domain.Dtos.UserDto;
  11. using OASystem.Domain.Entities.Customer;
  12. using OASystem.Domain.Entities.Groups;
  13. using OASystem.Domain.ViewModels.CRM;
  14. using OASystem.Domain.ViewModels.Financial;
  15. using OASystem.Domain.ViewModels.Groups;
  16. using OASystem.Infrastructure.Repositories.System;
  17. using Org.BouncyCastle.Asn1.Cms;
  18. using Org.BouncyCastle.Utilities.Collections;
  19. using Serilog;
  20. using SqlSugar;
  21. using System;
  22. using System.Collections.Generic;
  23. using System.Linq;
  24. using System.Text;
  25. using System.Threading.Tasks;
  26. namespace OASystem.Infrastructure.Repositories.Groups
  27. {
  28. /// <summary>
  29. /// 接团信息
  30. /// </summary>
  31. public class DelegationInfoRepository : BaseRepository<Grp_DelegationInfo, DelegationInfoView>
  32. {
  33. private readonly SetDataRepository _setDataRepository;
  34. private readonly UsersRepository _usersRepository;
  35. private readonly TaskAssignmentRepository _taskAssignmentRep;
  36. private readonly IMapper _mapper;
  37. //private readonly TeamRateRepository _teamRateRep;
  38. //public readonly Logs _logs;
  39. public DelegationInfoRepository(SqlSugarClient sqlSugar, SetDataRepository setDataRepository, UsersRepository usersRepository,
  40. TaskAssignmentRepository taskAssignmentRep, IMapper mapper)
  41. : base(sqlSugar)
  42. {
  43. _setDataRepository = setDataRepository;
  44. _usersRepository = usersRepository;
  45. _taskAssignmentRep = taskAssignmentRep;
  46. _mapper = mapper;
  47. //_teamRateRep = teamRateRep;
  48. }
  49. #region 团组信息 团组详情共享Api
  50. /// <summary>
  51. /// 查询团组简略详情列表
  52. /// Page 根据Ctable And User 返回可操作的团
  53. /// </summary>
  54. /// <param name="dto"></param>
  55. /// <returns></returns>
  56. public async Task<JsonView> ListByCTableAndUserId(GroupListByCTableAndUserIdDto dto)
  57. {
  58. var view = new JsonView() { Code = StatusCodes.Status400BadRequest,Msg="操作失败!" };
  59. if (dto.CTable < 1)
  60. {
  61. view.Msg = MsgTips.UserId;
  62. return view;
  63. }
  64. if (dto.CTable < 1)
  65. {
  66. view.Msg = "请输入正确的CTable Id !76 酒店预订<br/>77 行程<br/>79 车/导游地接<br/>80 签证<br/>81 邀请/公务活动<br/>82 团组客户保险<br/>85 机票预订<br/>98 其他款项<br/>751 酒店早餐";
  67. return view;
  68. }
  69. if (dto.PortType == 1 || dto.PortType == 2 || dto.PortType == 3)
  70. {
  71. //2025-02-17 更改团组列表排序功能 按照团出访时间排序(降序)
  72. string sql = string.Format(@"Select row_number() over(order by di.VisitStartDate Desc) as Row_Number,
  73. di.Id,di.TeamName,di.TourCode,di.ClientName,di.VisitCountry,di.VisitStartDate,
  74. di.VisitEndDate,di.VisitDays,di.VisitPNumber,di.CreateTime
  75. From Grp_GroupsTaskAssignment gta
  76. Inner Join Grp_DelegationInfo di On gta.DIId = di.Id
  77. Where gta.IsDel = 0 And di.IsDel = 0 And gta.IsEnable = 1
  78. And gta.CTId = {0} And gta.UId = {1}", dto.CTable, dto.UserId);
  79. if (!string.IsNullOrEmpty(dto.TeamName))
  80. {
  81. sql = string.Format($"{sql} And di.TeamName Like '%{dto.TeamName}%'");
  82. }
  83. //去重
  84. sql = $"{sql} GROUP BY di.Id,di.TeamName,di.TourCode,di.ClientName,di.VisitCountry,di.VisitStartDate,di.VisitEndDate,di.VisitDays,di.VisitPNumber,di.CreateTime";
  85. RefAsync<int> total = 0;//REF和OUT不支持异步,想要真的异步这是最优解
  86. var data = await _sqlSugar.SqlQueryable<GroupListByCTableAndUserIdView>(sql).ToPageListAsync(dto.PageIndex, dto.PageSize, total); //ToPageAsync
  87. foreach (var item in data)
  88. {
  89. item.VisitStartDate = item.VisitStartDate == "" ? "" : Convert.ToDateTime(item.VisitStartDate).ToString("yyyy-MM-dd");
  90. item.VisitEndDate = item.VisitEndDate == "" ? "" : Convert.ToDateTime(item.VisitEndDate).ToString("yyyy-MM-dd");
  91. }
  92. view.Msg = "操作成功!";
  93. view.Data = data;
  94. view.Count = total;
  95. return view;
  96. }
  97. else
  98. {
  99. view.Msg = "请输入正确的PortType 1 Web 2 Android 3 IOS ";
  100. return view;
  101. }
  102. }
  103. /// <summary>
  104. /// 团组信息 团组预览详情共享Api
  105. /// </summary>
  106. /// <param name="dto"></param>
  107. /// <returns></returns>
  108. public async Task<JsonView> PostShareGroupInfo(ShareGroupInfoDto dto)
  109. {
  110. var view = new JsonView() { Code = StatusCodes.Status400BadRequest, Msg = "操作失败!" };
  111. string sql = string.Format(@"Select Id,TeamName,TourCode,ClientName,VisitCountry,VisitStartDate,VisitEndDate,VisitDays,VisitPNumber
  112. From Grp_DelegationInfo Where Id = {0} And IsDel = 0", dto.Id);
  113. if (dto.PortType == 1) //Web
  114. {
  115. var _DelegationInfo = await _sqlSugar.SqlQueryable<Web_ShareGroupInfoView>(sql).FirstAsync();
  116. if (_DelegationInfo != null)
  117. {
  118. _DelegationInfo.VisitCountry = FormartTeamName(_DelegationInfo.VisitCountry);
  119. }
  120. else
  121. {
  122. view.Msg = "暂无该团组信息";
  123. return view;
  124. }
  125. view.Data = _DelegationInfo;
  126. }
  127. else if (dto.PortType == 2 || dto.PortType == 3) //IOS Or Android
  128. {
  129. var _DelegationInfo = await _sqlSugar.SqlQueryable<IOSOrAndroid_ShareGroupInfoView>(sql).FirstAsync();
  130. if (_DelegationInfo != null)
  131. {
  132. _DelegationInfo.VisitCountry = FormartTeamName(_DelegationInfo.VisitCountry);
  133. view.Data = _DelegationInfo;
  134. }
  135. else
  136. {
  137. view.Msg = "暂无该团组信息";
  138. return view;
  139. }
  140. view.Data = _DelegationInfo;
  141. }
  142. else
  143. {
  144. view.Msg = "请输入正确的端口号。1 Web 2 Android 3 IOS";
  145. return view;
  146. }
  147. view.Code = StatusCodes.Status200OK;
  148. view.Msg = "成功!";
  149. return view;
  150. }
  151. /// <summary>
  152. /// 团组信息List 团组预览详情共享Api
  153. /// </summary>
  154. /// <param name="dto"></param>
  155. /// <returns></returns>
  156. public async Task<Result> PostShareGroupInfos(int portType)
  157. {
  158. Result result = new Result() { Code = -2, Msg = "未知错误", Data = new List<object>() { } };
  159. string sql = string.Format(@"Select Id,TeamName,TourCode,ClientName,VisitCountry,VisitStartDate,VisitEndDate,VisitDays,VisitPNumber
  160. From Grp_DelegationInfo With(NoLock) Where IsDel = 0 Order By VisitStartDate Desc");
  161. var _DelegationInfo = await _sqlSugar.SqlQueryable<Web_ShareGroupInfoView>(sql).ToListAsync();
  162. if (_DelegationInfo.Count > 0)
  163. {
  164. foreach (var item in _DelegationInfo)
  165. {
  166. item.VisitCountry = FormartTeamName(item.VisitCountry);
  167. }
  168. }
  169. else { result.Msg = "暂无该团组信息"; return result; }
  170. if (portType == 1) //Web
  171. {
  172. result.Data = _DelegationInfo;
  173. }
  174. else if (portType == 2 || portType == 3) //IOS Or Android
  175. {
  176. result.Data = _DelegationInfo;
  177. }
  178. else { result.Msg = "请输入正确的端口号。1 Web 2 Android 3 IOS"; return result; }
  179. result.Code = 0;
  180. result.Msg = "成功!";
  181. return result;
  182. }
  183. #endregion
  184. /// <summary>
  185. /// 获取接团信息Info
  186. /// </summary>
  187. /// <param name="dto"></param>
  188. /// <returns></returns>
  189. public async Task<Result> PostGroupInfo(GroupInfoDto dto)
  190. {
  191. Result result = new Result() { Code = -2, Msg = "未知错误" };
  192. if (dto.PortType == 1 || dto.PortType == 2 || dto.PortType == 3) //Web Or Android
  193. {
  194. string sql = string.Format(@"Select Id,SalesQuoteNo,TourCode,JietuanOperator,TeamLevSId,TeamDid,TeamName,ClientName,
  195. ClientUnit,VisitCountry,VisitDate,VisitDays,VisitPNumber,TontractTime,
  196. PayDay,PaymentMoney,VisitPurpose,SpecialNeeds,OtherNeeds,CGRWSPBMMC,CGRWSPWH,
  197. ZZSCBMMC,ZZSCSPWH,Remark,TellPhone,Officialneeds
  198. From Grp_DelegationInfo Where Id = {0} And IsDel = 0", dto.Id);
  199. var _DelegationInfo = await _sqlSugar.SqlQueryable<DelegationInfoWebView>(sql).FirstAsync();
  200. if (_DelegationInfo != null)
  201. {
  202. _DelegationInfo.TeamName = FormartTeamName(_DelegationInfo.TeamName);
  203. result.Code = 0;
  204. result.Msg = "成功!";
  205. result.Data = _DelegationInfo;
  206. }
  207. else result.Msg = "暂无该团组信息";
  208. }
  209. return result;
  210. }
  211. #region 团组
  212. /// <summary>
  213. /// 统一团组国家分割字符
  214. /// </summary>
  215. /// <param name="teamName"></param>
  216. /// <returns></returns>
  217. public string FormartTeamName(string? teamName)
  218. {
  219. string str = "";
  220. if (!string.IsNullOrEmpty(teamName))
  221. {
  222. str = teamName;
  223. List<string> searchreplaces = new List<string>() { "|", " ", "/", ",", "," };
  224. foreach (var item in searchreplaces)
  225. {
  226. if (str.Contains(item))
  227. {
  228. str = str.Replace(item, "、");
  229. break;
  230. }
  231. }
  232. }
  233. return str.Trim();
  234. }
  235. /// <summary>
  236. /// 团组国家分割字符
  237. /// 返回 国家数组
  238. /// </summary>
  239. /// <param name="teamName"></param>
  240. /// <returns></returns>
  241. public List<string> GroupSplitCountry (string visitCountry)
  242. {
  243. List<string> countrys = new List<string>();
  244. if (!string.IsNullOrEmpty(visitCountry))
  245. {
  246. if (visitCountry.Contains("、")) countrys = visitCountry.Split("、").ToList();
  247. else if (visitCountry.Contains("|")) countrys = visitCountry.Split("|").ToList();
  248. else countrys.Add(visitCountry);
  249. }
  250. return countrys;
  251. }
  252. /// <summary>
  253. /// 获取接团信息 Page List
  254. /// </summary>
  255. /// <param name="dto"></param>
  256. /// <returns></returns>
  257. public async Task<Result> GetGroupPageList(GroupCommissionDto dto)
  258. {
  259. Result result = new Result() { Code = -2, Msg = "未知错误" };
  260. ListViewBase<DelegationPageListView> groupsInfoPageList = new ListViewBase<DelegationPageListView>()
  261. {
  262. ReceiveDt = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")
  263. };
  264. if (dto.PortType == 1 || dto.PortType == 2 || dto.PortType == 3) //web
  265. {
  266. int startIndex = (dto.PageIndex - 1) * dto.PageSize + 1;
  267. int endIndex = startIndex + dto.PageSize - 1;
  268. //int taskUserId = -1;
  269. string taskGroupIds = string.Empty;
  270. #region 处理用户团组操作权限
  271. if (dto.UserId != -1)
  272. {
  273. }
  274. #endregion
  275. string sql = string.Format(@"Select * From(Select row_number() over (order by gdi.Id Desc) as RowNumber,
  276. gdi.Id,SalesQuoteNo,TourCode,ssd.Id TeamTypeId, ssd.Name TeamType,ssd1.Id TeamLevId,
  277. ssd1.Name TeamLev,TeamName,ClientName,ClientUnit,VisitDate,VisitDays,VisitPNumber,
  278. su.CnName JietuanOperator,IsSure
  279. From Grp_DelegationInfo gdi
  280. Inner Join Sys_SetData ssd On gdi.TeamDid = ssd.Id
  281. Inner Join Sys_SetData ssd1 On gdi.TeamLevSId = ssd1.Id
  282. Left Join Sys_Users su On gdi.CreateUserId = su.Id
  283. Where gdi.IsDel = 0
  284. )temp Where RowNumber Between {0} and {1}", startIndex, endIndex);
  285. string sqlCount = string.Format(@"Select Count(1) as Count From Grp_DelegationInfo gdi
  286. Inner Join Sys_SetData ssd On gdi.TeamDid = ssd.Id
  287. Inner Join Sys_SetData ssd1 On gdi.TeamLevSId = ssd1.Id
  288. Left Join Sys_Users su On gdi.CreateUserId = su.Id
  289. Where gdi.IsDel = 0 ");
  290. List<DelegationPageListView> _DeleInfoList = await _sqlSugar.SqlQueryable<DelegationPageListView>(sql).ToListAsync();
  291. DelegationPageCountView _DeleCount = await _sqlSugar.SqlQueryable<DelegationPageCountView>(sqlCount).FirstAsync();
  292. int count = _DeleCount.Count;
  293. groupsInfoPageList = new ListViewBase<DelegationPageListView>
  294. {
  295. CurrPageIndex = dto.PageIndex,
  296. CurrPageSize = dto.PageSize,
  297. DataCount = count,
  298. DataList = _DeleInfoList
  299. };
  300. result.Code = 0;
  301. result.Msg = "成功!";
  302. result.Data = groupsInfoPageList;
  303. }
  304. return result;
  305. }
  306. /// <summary>
  307. /// 获取接团信息List
  308. /// </summary>
  309. /// <param name="dto"></param>
  310. /// <returns></returns>
  311. public async Task<Result> GetGroupList(GroupListDto dto)
  312. {
  313. Result result = new Result() { Code = -2, Msg = "未知错误" };
  314. if (dto.PortType == 1) {
  315. string sql = string.Format(@"Select gdi.Id,SalesQuoteNo,TourCode,ssd.Id TeamTypeId, ssd.Name TeamType,ssd1.Id TeamLevId,ssd1.Name TeamLev,TeamName,ClientName,ClientUnit,VisitDate,VisitDays,VisitPNumber,su.CnName JietuanOperator,IsSure
  316. ,gs.Id as GrpScheduleId
  317. From Grp_DelegationInfo gdi
  318. Inner Join Sys_SetData ssd On gdi.TeamDid = ssd.Id
  319. Inner Join Sys_SetData ssd1 On gdi.TeamLevSId = ssd1.Id
  320. Left Join Sys_Users su On gdi.CreateUserId = su.Id
  321. left Join Grp_Schedule gs On gdi.Id = gs.DiId
  322. Where gdi.IsDel = 0
  323. Order By gdi.CreateTime Desc");
  324. var _DelegationList = await _sqlSugar.SqlQueryable<DelegationListView>(sql).ToListAsync();
  325. if (_DelegationList.Count > 0)
  326. {
  327. result.Code = 0;
  328. result.Msg = "成功!";
  329. result.Data = _DelegationList;
  330. }
  331. else
  332. {
  333. result.Msg = "暂无该团组信息";
  334. }
  335. }
  336. else if (dto.PortType == 2 || dto.PortType == 3) //web
  337. {
  338. string sql = string.Format(@"Select gdi.Id,SalesQuoteNo,TourCode,ssd.Id TeamTypeId, ssd.Name TeamType,ssd1.Id TeamLevId,ssd1.Name TeamLev,TeamName,ClientName,ClientUnit,VisitDate,VisitDays,VisitPNumber,su.CnName JietuanOperator,IsSure
  339. From Grp_DelegationInfo gdi
  340. Inner Join Sys_SetData ssd On gdi.TeamDid = ssd.Id
  341. Inner Join Sys_SetData ssd1 On gdi.TeamLevSId = ssd1.Id
  342. Left Join Sys_Users su On gdi.CreateUserId = su.Id
  343. Where gdi.IsDel = 0
  344. Order By gdi.CreateTime Desc");
  345. var _DelegationList = await _sqlSugar.SqlQueryable<DelegationListView>(sql).ToListAsync();
  346. if (_DelegationList.Count > 0)
  347. {
  348. result.Code = 0;
  349. result.Msg = "成功!";
  350. result.Data = _DelegationList;
  351. }
  352. else
  353. {
  354. result.Msg = "暂无该团组信息";
  355. }
  356. }
  357. return result;
  358. }
  359. /// <summary>
  360. /// 获取接团信息Info
  361. /// </summary>
  362. /// <param name="dto"></param>
  363. /// <returns></returns>
  364. public async Task<Result> GetGroupInfo(GroupInfoDto dto)
  365. {
  366. Result result = new Result() { Code = -2, Msg = "未知错误" };
  367. if (dto.PortType == 1 || dto.PortType == 2 || dto.PortType == 3) //Web Or Android
  368. {
  369. string sql = string.Format(@"Select Id,SalesQuoteNo,TourCode,JietuanOperator,TeamLevSId,TeamDid,TeamName,ClientName,
  370. ClientUnit,VisitCountry,VisitDate,VisitDays,VisitPNumber,TontractTime,IsBid,
  371. PayDay,PaymentMoney,VisitPurpose,SpecialNeeds,OtherNeeds,CGRWSPBMMC,CGRWSPWH,
  372. ZZSCBMMC,ZZSCSPWH,Remark,TellPhone,WeChatNo,OpRoyaltyLv,OpRoyaltyRemark,Officialneeds
  373. From Grp_DelegationInfo Where Id = {0} And IsDel = 0", dto.Id);
  374. var _DelegationInfo = await _sqlSugar.SqlQueryable<DelegationInfoWebView>(sql).FirstAsync();
  375. if (_DelegationInfo != null)
  376. {
  377. _DelegationInfo.TeamName = FormartTeamName(_DelegationInfo.TeamName);
  378. _DelegationInfo.VisitCountry = FormartTeamName(_DelegationInfo.VisitCountry);
  379. //if (_DelegationInfo.TontractTime)
  380. //{
  381. //}
  382. result.Code = 0;
  383. result.Msg = "成功!";
  384. result.Data = _DelegationInfo;
  385. if (dto.PortType == 2)
  386. {
  387. var GroupProcessOperationDtoParam = new GroupProcessOperationDto();
  388. GroupProcessOperationDtoParam = _mapper.Map<DelegationInfoWebView, GroupProcessOperationDto>(_DelegationInfo);
  389. List<Crm_DeleClient> DeleClientArr = await _sqlSugar.Queryable<Crm_DeleClient>().Where(it => it.IsDel == 0).ToListAsync(); //客户信息
  390. List<Grp_TourClientList> _DeleClients = await _sqlSugar.Queryable<Grp_TourClientList>().Where(it => it.IsDel == 0 && it.DiId == dto.Id).ToListAsync(); // 接团客户名单
  391. List<Crm_CustomerCert> _CustomerCerts = await _sqlSugar.Queryable<Crm_CustomerCert>().Where(it => it.IsDel == 0 && it.SdId == 773).ToListAsync(); // 身份证类型证件信息
  392. List<Crm_CustomerCompany> CompanyArr = await _sqlSugar.Queryable<Crm_CustomerCompany>().Where(it => it.IsDel == 0).ToListAsync();
  393. var TourClientListInfoArr = new List<TourClientListProcessInfo>();
  394. var timeParam = new DateTime();
  395. foreach (var item in _DeleClients)
  396. {
  397. var param = new TourClientListProcessInfo();
  398. var clientInfo = DeleClientArr.FirstOrDefault(x => x.Id == item.ClientId);
  399. if (clientInfo == null) clientInfo = new Crm_DeleClient();
  400. var clientIDInfo = _CustomerCerts.FirstOrDefault(x=>x.DcId == item.ClientId); //身份证信息
  401. if (clientIDInfo == null) clientIDInfo = new Crm_CustomerCert();
  402. var Company = CompanyArr.FirstOrDefault(x => x.Id == clientInfo.CrmCompanyId);
  403. if(Company == null) Company = new Crm_CustomerCompany();
  404. param.IDCardNo = clientIDInfo.CertNo;
  405. param.Remark = item.Remark;
  406. param.BirthDay = clientInfo.BirthDay == null ? "" : DateTime.TryParse(Convert.ToDateTime( clientInfo.BirthDay).ToString("yyyy-MM-dd"), out timeParam) ? timeParam.ToString("yyyy-MM-dd") : "";
  407. param.FirstName = clientInfo.FirstName;
  408. param.LastName = clientInfo.LastName;
  409. param.CompanyFullName = Company.CompanyFullName;
  410. param.Job = clientInfo.Job;
  411. param.Sex = clientInfo.Sex;
  412. param.Phone = clientInfo.Phone;
  413. param.Pinyin = clientInfo.Pinyin;
  414. param.HotelSpecialNeeds = item.HotelSpecialNeeds;
  415. param.MealSpecialNeeds = item.MealSpecialNeeds;
  416. param.ShippingSpaceSpecialNeeds = item.ShippingSpaceSpecialNeeds;
  417. param.ShippingSpaceTypeId = item.ShippingSpaceTypeId;
  418. param.Id = clientInfo.Id;
  419. EncryptionProcessor.DecryptProperties(param);
  420. TourClientListInfoArr.Add(param);
  421. }
  422. GroupProcessOperationDtoParam.PortType = dto.PortType;
  423. GroupProcessOperationDtoParam.TourClientListInfos = TourClientListInfoArr;
  424. GroupProcessOperationDtoParam.VisitDate = DateTime.TryParse(GroupProcessOperationDtoParam.VisitDate, out timeParam) ? timeParam.ToString("yyyy-MM-dd") : "";
  425. GroupProcessOperationDtoParam.VisitDate = DateTime.TryParse(GroupProcessOperationDtoParam.VisitDate, out timeParam) ? timeParam.ToString("yyyy-MM-dd") : "";
  426. GroupProcessOperationDtoParam.TontractTime = DateTime.TryParse(GroupProcessOperationDtoParam.TontractTime, out timeParam) ? timeParam.ToString("yyyy-MM-dd") : "";
  427. result.Data = GroupProcessOperationDtoParam;
  428. }
  429. else if (dto.PortType == 3)
  430. {
  431. var GroupProcessOperationDtoParam = new GroupProcessOperationDto();
  432. GroupProcessOperationDtoParam = _mapper.Map<DelegationInfoWebView, GroupProcessOperationDto>(_DelegationInfo);
  433. List<Crm_DeleClient> DeleClientArr = await _sqlSugar.Queryable<Crm_DeleClient>().Where(it => it.IsDel == 0).ToListAsync(); //客户信息
  434. List<Grp_TourClientList> _DeleClients = await _sqlSugar.Queryable<Grp_TourClientList>().Where(it => it.IsDel == 0 && it.DiId == dto.Id).ToListAsync(); // 接团客户名单
  435. List<Crm_CustomerCert> _CustomerCerts = await _sqlSugar.Queryable<Crm_CustomerCert>().Where(it => it.IsDel == 0 && it.SdId == 773).ToListAsync(); // 身份证类型证件信息
  436. List<Crm_CustomerCompany> CompanyArr = await _sqlSugar.Queryable<Crm_CustomerCompany>().Where(it => it.IsDel == 0).ToListAsync();
  437. var TourClientListInfoArr = new List<TourClientListProcessInfo>();
  438. var timeParam = new DateTime();
  439. foreach (var item in _DeleClients)
  440. {
  441. var param = new TourClientListProcessInfo();
  442. var clientInfo = DeleClientArr.FirstOrDefault(x => x.Id == item.ClientId);
  443. if (clientInfo == null) clientInfo = new Crm_DeleClient();
  444. var clientIDInfo = _CustomerCerts.FirstOrDefault(x => x.DcId == item.ClientId); //身份证信息
  445. if (clientIDInfo == null) clientIDInfo = new Crm_CustomerCert();
  446. var Company = CompanyArr.FirstOrDefault(x => x.Id == clientInfo.CrmCompanyId);
  447. if (Company == null) Company = new Crm_CustomerCompany();
  448. param.IDCardNo = clientIDInfo.CertNo;
  449. param.Remark = item.Remark;
  450. param.BirthDay = clientInfo.BirthDay == null ? "" : DateTime.TryParse(Convert.ToDateTime(clientInfo.BirthDay).ToString("yyyy-MM-dd"), out timeParam) ? timeParam.ToString("yyyy-MM-dd") : "";
  451. param.FirstName = clientInfo.FirstName;
  452. param.LastName = clientInfo.LastName;
  453. param.CompanyFullName = Company.CompanyFullName;
  454. param.Job = clientInfo.Job;
  455. param.Sex = clientInfo.Sex;
  456. param.Phone = clientInfo.Phone;
  457. param.Pinyin = clientInfo.Pinyin;
  458. param.HotelSpecialNeeds = item.HotelSpecialNeeds;
  459. param.MealSpecialNeeds = item.MealSpecialNeeds;
  460. param.ShippingSpaceSpecialNeeds = item.ShippingSpaceSpecialNeeds;
  461. param.ShippingSpaceTypeId = item.ShippingSpaceTypeId;
  462. param.Id = item.Id;
  463. EncryptionProcessor.DecryptProperties(param);
  464. TourClientListInfoArr.Add(param);
  465. }
  466. GroupProcessOperationDtoParam.PortType = dto.PortType;
  467. GroupProcessOperationDtoParam.TourClientListInfos = TourClientListInfoArr;
  468. GroupProcessOperationDtoParam.VisitDate = DateTime.TryParse(GroupProcessOperationDtoParam.VisitDate, out timeParam) ? timeParam.ToString("yyyy-MM-dd") : "";
  469. GroupProcessOperationDtoParam.TontractTime = DateTime.TryParse(GroupProcessOperationDtoParam.TontractTime, out timeParam) ? timeParam.ToString("yyyy-MM-dd") : "";
  470. result.Data = GroupProcessOperationDtoParam;
  471. }
  472. }
  473. else result.Msg = "暂无该团组信息";
  474. }
  475. return result;
  476. }
  477. /// <summary>
  478. /// 获取接团信息 编辑
  479. /// 基础 数据源
  480. /// </summary>
  481. /// <param name="dto"></param>
  482. /// <returns></returns>
  483. public async Task<Result> GroupEditBasicSource(GroupListDto dto)
  484. {
  485. Result result = new Result() { Code = -2, Msg = "未知错误" };
  486. if (dto.PortType == 1 || dto.PortType == 2 || dto.PortType == 3) //web
  487. {
  488. dynamic? teamTypeData1 = null;
  489. string teamTypeSql = string.Format(@"Select Id,Name From Sys_SetData Where STid = {0} And IsDel = {1}", 10, 0);
  490. var teamTypeData = await _sqlSugar.SqlQueryable<SetDataInfoView>(teamTypeSql).ToListAsync(); ; //团组分类 10
  491. if (teamTypeData.Any())
  492. {
  493. teamTypeData1 = teamTypeData;
  494. if (teamTypeData.Any(x => x.Name.Equals("前期沟通")))
  495. {
  496. var info = teamTypeData.Find(x => x.Name.Equals("前期沟通"));
  497. if (info != null)
  498. {
  499. teamTypeData.Remove(info);
  500. teamTypeData.Insert(2, info);
  501. }
  502. }
  503. }
  504. dynamic? teamLevData1 = null;
  505. string teamLevSql = string.Format(@"Select Id,Name From Sys_SetData Where STid = {0} And IsDel = {1}", 56, 0);
  506. var teamLevData = await _sqlSugar.SqlQueryable<SetDataInfoView>(teamLevSql).ToListAsync(); ; //团组等级 56
  507. if (teamLevData.Any())
  508. {
  509. teamLevData1 = teamLevData;
  510. }
  511. dynamic? userData1 = null;
  512. string userSql = string.Format(@"Select Id,CnName From Sys_Users Where IsDel = {0}", 0);
  513. var userData = await _sqlSugar.SqlQueryable<UserNameView>(userSql).ToListAsync();
  514. if (userData.Any())
  515. {
  516. userData1 = userData;
  517. }
  518. //客户单位数据源 来源市场客户资料
  519. dynamic? clientData1 = null;
  520. string clientSql = $@"Select Client,Contact,Telephone,WeChat From Crm_NewClientData Where IsDel = 0";
  521. var clientData = await _sqlSugar.SqlQueryable<Crm_NewClientData>(clientSql).ToListAsync();
  522. if (clientData.Any())
  523. {
  524. clientData1 = clientData.Select(it => new
  525. {
  526. Client = AesEncryptionHelper.Decrypt(it.Client),
  527. Contact = AesEncryptionHelper.Decrypt(it.Contact),
  528. Telephone = AesEncryptionHelper.Decrypt(it.Telephone),
  529. Wechat = AesEncryptionHelper.Decrypt(it.Wechat)
  530. }).ToList();
  531. }
  532. var userDepDatas = new List<TextView>();
  533. userDepDatas.Insert(0, new TextView() { Text = "全部", Value = "全部" });
  534. userDepDatas.Insert(1, new TextView() { Text = "国交部", Value = "国交部" });
  535. userDepDatas.Insert(2, new TextView() { Text = "市场部", Value = "市场部" });
  536. userDepDatas.Insert(3, new TextView() { Text = "策划部", Value = "策划部" });
  537. var rankDatas = await _sqlSugar.Queryable<Sys_SetData>().Where(x => x.IsDel == 0 && x.STid == 56).Select(x => new TextView { Value = x.Id.ToString(), Text = x.Name }).ToListAsync();
  538. rankDatas.Insert(0, new TextView { Value = "0", Text = "全部" });
  539. result.Code = 0;
  540. result.Msg = "成功!";
  541. result.Data = new
  542. {
  543. teamTypeData = teamTypeData1,
  544. teamLevData = teamLevData1,
  545. userData = userData1,
  546. clientData = clientData1,
  547. depData = userDepDatas,
  548. rankData = rankDatas
  549. };
  550. }
  551. return result;
  552. }
  553. /// <summary>
  554. /// 团组信息操作
  555. /// </summary>
  556. /// <param name="dto"></param>
  557. /// <returns></returns>
  558. public async Task<Result>GroupOperation(GroupOperationDto dto)
  559. {
  560. Result result = new Result() { Code = -2, Msg = "未知错误" };
  561. if (dto.PortType == 1 || dto.PortType == 2 || dto.PortType == 3) //web
  562. {
  563. #region 添加出访起止时间
  564. var startTime = new DateTime();
  565. var endTime = new DateTime();
  566. if (DateTime.TryParse(dto.VisitDate, out startTime))
  567. {
  568. endTime = startTime.AddDays(dto.VisitDays - 1);//含当天
  569. }
  570. #endregion
  571. if (dto.Status == 1) //添加
  572. {
  573. string selectSql = string.Format(@"Select * From Grp_DelegationInfo
  574. Where IsDel = 0
  575. And TeamName = '{0}'
  576. And ClientName = '{1}'
  577. And ClientUnit ='{2}'
  578. And VisitDate ='{3}'",dto.TeamName, dto.ClientName, dto.ClientUnit, dto.VisitDate);
  579. var selectGroupInfo = _sqlSugar.SqlQueryable<Grp_DelegationInfo>(selectSql).First();
  580. if (selectGroupInfo != null)
  581. {
  582. result.Msg = "数据已存在,请勿重复添加!";
  583. return result;
  584. }
  585. //string teamCodeSql = string.Format("Select SalesQuoteNo From Grp_DelegationInfo");
  586. //var teamCodeItem = await _sqlSugar.SqlQueryable<TeamCodeView>(teamCodeSql).ToListAsync();
  587. //string SalesQuoteNo = "";
  588. //while (true)
  589. //{
  590. // SalesQuoteNo = Tools.CommonFun.GetRandomStr(6);
  591. // if (!teamCodeItem.Equals(SalesQuoteNo))
  592. // {
  593. // break;
  594. // }
  595. //}
  596. string countrys = string.Empty;
  597. string countryReq = dto.VisitCountry;
  598. if (!string.IsNullOrEmpty(countryReq))
  599. {
  600. if (countryReq.Contains(",")) countrys = countryReq.Replace(',','|');
  601. else if (countryReq.Contains(",")) countrys = countryReq.Replace(',', '|');
  602. else if (countryReq.Contains(" ")) countrys = countryReq.Replace(' ', '|');
  603. else if (countryReq.Contains("、")) countrys = countryReq.Replace('、', '|');
  604. else if (countryReq.Contains(".")) countrys = countryReq.Replace('.', '|');
  605. else countrys = countryReq;
  606. }
  607. //建团时 默认出团 设置 团组code
  608. string teamCode="";
  609. string teamCodeSql = string.Format("Select TourCode From Grp_DelegationInfo");
  610. var teamCodeItem = await _sqlSugar.SqlQueryable<TeamCodeView>(teamCodeSql).ToListAsync();
  611. while (true)
  612. {
  613. teamCode = Tools.CommonFun.GetRandomAllStr(6);
  614. if (!teamCodeItem.Equals(teamCode))
  615. {
  616. break;
  617. }
  618. }
  619. Grp_DelegationInfo delegationInfo = new Grp_DelegationInfo()
  620. {
  621. SalesQuoteNo = dto.SalesQuoteNo,
  622. TeamLevSId = dto.TeamLevSId,
  623. ClientName = dto.ClientName,
  624. ClientUnit = dto.ClientUnit,
  625. TeamName = dto.TeamName,
  626. TeamDid = dto.TeamDid,
  627. VisitDate = Convert.ToDateTime(dto.VisitDate),
  628. VisitCountry = countrys,
  629. VisitPurpose = dto.VisitPurpose,
  630. VisitDays = dto.VisitDays,
  631. VisitPNumber = dto.VisitPNumber,
  632. SpecialNeeds = dto.SpecialNeeds,
  633. OtherNeeds = dto.OtherNeeds,
  634. Remark = dto.Remark,
  635. JietuanOperator = dto.JietuanOperator,
  636. TellPhone = dto.TellPhone,
  637. WeChatNo = dto.WeChatNo,
  638. CGRWSPBMMC = dto.CGRWSPBMMC,
  639. CGRWSPWH = dto.CGRWSPWH,
  640. ZZSCBMMC = dto.ZZSCBMMC,
  641. ZZSCSPWH = dto.ZZSCSPWH,
  642. TontractTime = string.IsNullOrEmpty(dto.TontractTime) ? null : Convert.ToDateTime(dto.TontractTime),
  643. IsBid = dto.IsBid,
  644. PaymentMoney = dto.PaymentMoney,
  645. PayDay = dto.PayDay,
  646. TourCode = teamCode,
  647. GroupsOperator = dto.UserId,
  648. GroupsTime = DateTime.Now,
  649. SalesDate = DateTime.Now,
  650. IsState = 0, //默认团组未完成 0
  651. JietuanTime = DateTime.Now,
  652. IsDel = 0,
  653. BudgetCost = 0.00M,
  654. HotelComplain = 0,
  655. OPComplain = 0,
  656. OAComplain = 0,
  657. AirComplain = 0,
  658. VisaComplain = 0,
  659. CreateUserId = dto.UserId,
  660. CreateTime = DateTime.Now,
  661. DeleteUserId = null,
  662. DeleteTime = new DateTime(1990, 1, 1).ToString("yyyy-MM-dd HH:mm:ss"),
  663. OpRoyaltyLv = dto.OpRoyaltyLv,
  664. OpRoyaltyRemark=dto.opRoyaltyRemark,
  665. Officialneeds = dto.Officialneeds,
  666. VisitStartDate = startTime,
  667. VisitEndDate = endTime,
  668. };
  669. var addId = _sqlSugar.Insertable(delegationInfo).ExecuteReturnIdentity();
  670. if (addId > 0)
  671. {
  672. result.Code = 0;
  673. result.Msg = "添加成功!";
  674. result.Data = addId;
  675. }
  676. else
  677. {
  678. result.Msg = "添加失败!";
  679. }
  680. }
  681. else if (dto.Status == 2) //修改
  682. {
  683. var updateStatus = await UpdateAsync(a => a.Id == dto.Id, a => new Grp_DelegationInfo
  684. {
  685. SalesQuoteNo = dto.SalesQuoteNo,
  686. TeamLevSId = dto.TeamLevSId,
  687. ClientName = dto.ClientName,
  688. ClientUnit = dto.ClientUnit,
  689. TeamName = dto.TeamName,
  690. TeamDid = dto.TeamDid,
  691. VisitDate = Convert.ToDateTime(dto.VisitDate),
  692. VisitCountry = dto.VisitCountry,
  693. VisitPurpose = dto.VisitPurpose,
  694. VisitDays = dto.VisitDays,
  695. VisitPNumber = dto.VisitPNumber,
  696. SpecialNeeds = dto.SpecialNeeds,
  697. OtherNeeds = dto.OtherNeeds,
  698. Remark = dto.Remark,
  699. JietuanOperator = dto.JietuanOperator,
  700. TellPhone = dto.TellPhone,
  701. WeChatNo = dto.WeChatNo,
  702. CGRWSPBMMC = dto.CGRWSPBMMC,
  703. CGRWSPWH = dto.CGRWSPWH,
  704. ZZSCBMMC = dto.ZZSCBMMC,
  705. ZZSCSPWH = dto.ZZSCSPWH,
  706. TontractTime = string.IsNullOrEmpty(dto.TontractTime) ? null : Convert.ToDateTime(dto.TontractTime),
  707. IsBid = dto.IsBid,
  708. PaymentMoney = dto.PaymentMoney,
  709. PayDay = dto.PayDay,
  710. OpRoyaltyLv = dto.OpRoyaltyLv,
  711. OpRoyaltyRemark = dto.opRoyaltyRemark,
  712. Officialneeds = dto.Officialneeds,
  713. VisitStartDate = startTime,
  714. VisitEndDate = endTime,
  715. });
  716. if (updateStatus)
  717. {
  718. result.Code = 0;
  719. result.Msg = "修改成功!";
  720. }
  721. else
  722. {
  723. result.Msg = "修改失败!";
  724. }
  725. }
  726. else if (dto.Status == 3) //删除
  727. {
  728. var deleteStatus = await UpdateAsync(a => a.Id == dto.Id, a => new Grp_DelegationInfo
  729. {
  730. DeleteUserId = dto.UserId,
  731. DeleteTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
  732. IsDel = 1
  733. });
  734. if (deleteStatus)
  735. {
  736. result.Code = 0;
  737. result.Msg = "删除成功!";
  738. }
  739. else
  740. {
  741. result.Msg = "删除失败!";
  742. }
  743. }
  744. }
  745. return result;
  746. }
  747. /// <summary>
  748. /// 团组信息操作 - 删除
  749. /// </summary>
  750. /// <param name="dto"></param>
  751. /// <returns></returns>
  752. public async Task<Result> GroupDel(GroupDelDto dto)
  753. {
  754. Result result = new Result() { Code = -2, Msg = "未知错误" };
  755. if (dto.PortType == 1 || dto.PortType == 2 || dto.PortType == 3) //web
  756. {
  757. var deleteStatus = await UpdateAsync(a => a.Id == dto.Id, a => new Grp_DelegationInfo
  758. {
  759. DeleteUserId = dto.UserId,
  760. DeleteTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
  761. IsDel = 1
  762. });
  763. if (deleteStatus)
  764. {
  765. result.Code = 0;
  766. result.Msg = "删除成功!";
  767. }
  768. else
  769. {
  770. result.Msg = "删除失败!";
  771. }
  772. }
  773. return result;
  774. }
  775. /// <summary>
  776. /// 获取销售报价号
  777. /// </summary>
  778. /// <returns></returns>
  779. public async Task<Result> GetGroupSalesQuoteNo()
  780. {
  781. Result result = new Result() { Code = -2, Msg = "未知错误" };
  782. string teamCodeSql = string.Format("Select SalesQuoteNo From Grp_DelegationInfo");
  783. var teamCodeItem = await _sqlSugar.SqlQueryable<SalesQuoteNoView>(teamCodeSql).ToListAsync();
  784. string teamCode = "";
  785. while (true)
  786. {
  787. teamCode = Tools.CommonFun.GetRandomAllStr(6);
  788. if (!teamCodeItem.Equals(teamCode))
  789. {
  790. break;
  791. }
  792. }
  793. result.Code = 0;
  794. result.Msg = "成功!";
  795. result.Data = teamCode;
  796. return result;
  797. }
  798. /// <summary>
  799. /// 团组删除
  800. /// </summary>
  801. /// <returns></returns>
  802. public async Task<Result> GroupDeleteById()
  803. {
  804. Result result = new Result() { Code = -2, Msg = "未知错误" };
  805. string teamCodeSql = string.Format("Select TourCode From Grp_DelegationInfo");
  806. var teamCodeItem = await _sqlSugar.SqlQueryable<TeamCodeView>(teamCodeSql).ToListAsync();
  807. string teamCode = "";
  808. while (true)
  809. {
  810. teamCode = Tools.CommonFun.GetRandomAllStr(6);
  811. if (!teamCodeItem.Equals(teamCode))
  812. {
  813. break;
  814. }
  815. }
  816. result.Code = 0;
  817. result.Msg = "成功!";
  818. result.Data = teamCode;
  819. return result;
  820. }
  821. /// <summary>
  822. /// 团组确认出团
  823. /// </summary>
  824. /// <returns></returns>
  825. public async Task<Result> ConfirmationGroup(ConfirmationGroupDto dto)
  826. {
  827. Result result = new Result() { Code = -2, Msg = "未知错误" };
  828. string teamCode = "";
  829. if (dto.PortType == 1 || dto.PortType == 2 || dto.PortType == 3) //web
  830. {
  831. string teamCodeSql = string.Format("Select TourCode From Grp_DelegationInfo");
  832. var teamCodeItem = await _sqlSugar.SqlQueryable<TeamCodeView>(teamCodeSql).ToListAsync();
  833. while (true)
  834. {
  835. teamCode = Tools.CommonFun.GetRandomAllStr(6);
  836. if (!teamCodeItem.Equals(teamCode))
  837. {
  838. break;
  839. }
  840. }
  841. var deleteStatus = await UpdateAsync(a => a.Id == dto.GroupId, a => new Grp_DelegationInfo
  842. {
  843. TourCode = teamCode,
  844. GroupsOperator = dto.GroupsOperator,
  845. GroupsTime = DateTime.Now
  846. });
  847. if (deleteStatus)
  848. {
  849. result.Code = 0;
  850. result.Msg = "确认出团设置成功!";
  851. }
  852. else
  853. {
  854. result.Msg = "确认出团设置失败!";
  855. }
  856. }
  857. result.Code = 0;
  858. result.Msg = "成功!";
  859. result.Data = teamCode;
  860. return result;
  861. }
  862. /// <summary>
  863. /// 获取接团名称List
  864. /// </summary>
  865. /// <param name="dto"></param>
  866. /// <returns></returns>
  867. public async Task<JsonView> GetGroupNameList(GroupNameDto dto)
  868. {
  869. var view = new JsonView() { Code = StatusCodes.Status400BadRequest, Msg = "操作失败!" };
  870. if (dto.PortType == 1 || dto.PortType == 2 || dto.PortType == 3) //web
  871. {
  872. //2025-02-17 更改团组列表排序功能 按照团出访时间排序(降序)
  873. string sql = string.Format(@"Select Id,TeamName GroupName From Grp_DelegationInfo
  874. Where TeamName != '' And IsDel = 0
  875. Order By VisitStartDate Desc");
  876. var _groupNameList = await _sqlSugar.SqlQueryable<GroupNameView>(sql).ToListAsync();
  877. if (_groupNameList.Count > 0)
  878. {
  879. for (int i = 0; i < _groupNameList.Count; i++)
  880. {
  881. var info = _groupNameList[i];
  882. _groupNameList[i].GroupName = FormartTeamName(info.GroupName);
  883. }
  884. view.Code = StatusCodes.Status200OK;
  885. view.Msg = "成功!";
  886. view.Data = _groupNameList;
  887. }
  888. else
  889. {
  890. view.Msg = "暂无团组信息";
  891. }
  892. }
  893. return view;
  894. }
  895. //PostGroupNameScreen
  896. /// <summary>
  897. /// 获取接团名称 Page List
  898. /// </summary>
  899. /// <param name="dto"></param>
  900. /// <returns></returns>
  901. public async Task<JsonView> GetGroupNameList(int portType,int pageIndex,int pageSize, string groupName,int userId)
  902. {
  903. var _res = new JsonView() { Code = 400 , Msg = MsgTips.Fail };
  904. string sql = "";
  905. string sqlWhere = "";
  906. string mobileSqlWhere = "";
  907. if (!string.IsNullOrEmpty(groupName))
  908. {
  909. sqlWhere += string.Format($@"And TeamName Like '%{groupName}%'");
  910. mobileSqlWhere += string.Format($@"GroupName Like '%{groupName}%'");
  911. }
  912. List<int> userIds = new List<int>() { -1, 21 };
  913. if (!userIds.Contains(userId))
  914. {
  915. sqlWhere += string.Format($@"And JietuanOperator = {userId}");
  916. }
  917. sql = string.Format($@"Select ROW_NUMBER()Over(Order By Id Desc) as RowNumber,Id,TeamName GroupName From Grp_DelegationInfo
  918. Where IsDel = 0 {sqlWhere}");
  919. if (portType == 1) //web
  920. { }
  921. else if (portType == 2 || portType == 3)
  922. {
  923. //国交部 7 (主管 22,经理 32)团操操作权限 市场部 6 接团人
  924. var userInfo = await _sqlSugar.Queryable<Sys_Users>().Where(it => it.Id == userId && it.IsDel == 0).FirstAsync();
  925. if (userInfo != null)
  926. {
  927. if (userInfo.DepId == 7)
  928. {
  929. if (userInfo.JobPostId != 22 || userInfo.JobPostId != 32)
  930. {
  931. if (!string.IsNullOrEmpty(mobileSqlWhere)) mobileSqlWhere = $" Where {mobileSqlWhere}";
  932. sql = string.Format($@"Select
  933. ROW_NUMBER()Over(Order By Id Desc) as RowNumber,
  934. Id,
  935. GroupName
  936. From (
  937. Select
  938. distinct
  939. di.Id,
  940. di.TeamName GroupName
  941. From Grp_GroupsTaskAssignment gta With(NoLock)
  942. Inner Join Grp_DelegationInfo di With(NoLock) On gta.DIId = di.Id
  943. Where gta.IsDel = 0 And di.IsDel = 0 And gta.UId = {userId}
  944. ) Temp {mobileSqlWhere}");
  945. }
  946. }
  947. }
  948. }
  949. RefAsync<int> total = 0;
  950. var groupNamePageData = await _sqlSugar.SqlQueryable<GroupNamePageView>(sql).ToPageListAsync(pageIndex, pageSize, total);
  951. _res.Code = 200;
  952. _res.Data = groupNamePageData;
  953. _res.Msg = MsgTips.Succeed;
  954. _res.Count = total;
  955. return _res;
  956. }
  957. /// <summary>
  958. /// 获取接团名称List And 签证国别
  959. /// </summary>
  960. /// <param name="dto"></param>
  961. /// <returns></returns>
  962. public async Task<Result> GetGroupNameAndVisaNationality(GroupNameDto dto)
  963. {
  964. Result result = new Result() { Code = -2, Msg = "未知错误" };
  965. if (dto.PortType == 1 || dto.PortType == 2 || dto.PortType == 3) //web
  966. {
  967. string sql = string.Format(@"Select Id,TeamName GroupName From Grp_DelegationInfo
  968. Where TeamName != '' And IsDel = 0
  969. Order By Id Desc");
  970. var _groupNameList = await _sqlSugar.SqlQueryable<GroupNameView>(sql).ToListAsync();
  971. string visaSql = string.Format(@"Select Id,Name From Sys_SetData Where STid = 41 And IsDel = 0");
  972. var _setDataList = await _sqlSugar.SqlQueryable<SetDataInfoView>(visaSql).ToListAsync();
  973. var data = new {
  974. groupNameData = _groupNameList,
  975. visaNationalityData = _setDataList
  976. };
  977. result.Data = data;
  978. result.Code = 0;
  979. }
  980. return result;
  981. }
  982. #endregion
  983. #region 团组&签证
  984. /// <summary>
  985. /// 根据团组Id查询客户
  986. /// </summary>
  987. /// <param name="dto"></param>
  988. /// <returns></returns>
  989. public async Task<Result> GetCrmByGroupId(ClientByGroupIdDto dto)
  990. {
  991. Result result = new Result() { Code = -2 };
  992. if (dto.PortType == 1 || dto.PortType == 2 || dto.PortType == 3)
  993. {
  994. string sql = string.Format(@"Select gdjc.GrpDCId grpId,cdc.Id,cdc.LastName+cdc.FirstName clientName,cdc.Tel,ccc.CertNo CerdNo
  995. From Grp_DelegationJoinCustomer gdjc
  996. Inner join Crm_DeleClient cdc On gdjc.CrmDCId = cdc.Id
  997. Left Join Crm_CustomerCert ccc On ccc.SdId = 773 And cdc.Id = ccc.DcId
  998. Where gdjc.GrpDCId = {0}", dto.GroupId);
  999. var clientList = await _sqlSugar.SqlQueryable<CrmByGroupIdView>(sql).ToListAsync();
  1000. if (clientList.Count > 0)
  1001. {
  1002. result.Code = 0;
  1003. result.Msg = "成功!";
  1004. result.Data = clientList;
  1005. }
  1006. else
  1007. {
  1008. result.Msg = "暂无数据!";
  1009. }
  1010. }
  1011. return result;
  1012. }
  1013. #endregion
  1014. #region 团组&出入境费用
  1015. /// <summary>
  1016. /// 获取单组名称并验证出入境费用明细是否填写
  1017. /// </summary>
  1018. /// <param name="dto"></param>
  1019. /// <returns></returns>
  1020. public async Task<Result> EnterExitCostGroupNameAsync()
  1021. {
  1022. var result = new Result() { Code = -2, Msg = "未知错误" };
  1023. var groupSql = string.Format(@$"SELECT
  1024. Id,
  1025. TeamName GroupName,
  1026. CASE
  1027. WHEN (
  1028. SELECT
  1029. COUNT(*)
  1030. FROM
  1031. Grp_EnterExitCost
  1032. WHERE
  1033. IsDel = 0
  1034. AND DiId = di.Id
  1035. ) > 0 THEN 'false'
  1036. ELSE 'true'
  1037. END AS [IsNull]
  1038. FROM
  1039. Grp_DelegationInfo di
  1040. WHERE
  1041. di.Isdel = 0
  1042. ORDER BY
  1043. VisitStartDate Desc");
  1044. result.Data = await _sqlSugar.SqlQueryable<EnterExitCostGroupNameView>(groupSql).ToListAsync();
  1045. result.Code = 0;
  1046. return result;
  1047. }
  1048. #endregion
  1049. }
  1050. }