GroupsController.cs 92 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169
  1. using Aspose.Cells;
  2. using Aspose.Cells.Drawing.Texts;
  3. using Aspose.Words;
  4. using Aspose.Words.Tables;
  5. using NPOI.Util;
  6. using OASystem.API.OAMethodLib;
  7. using OASystem.API.OAMethodLib.File;
  8. using OASystem.Domain.Dtos.Groups;
  9. using OASystem.Domain.Entities.Groups;
  10. using OASystem.Domain.ViewModels.Groups;
  11. using OASystem.Infrastructure.Repositories.Groups;
  12. using TencentCloud.Ocr.V20181119.Models;
  13. using OASystem.Infrastructure.Tools;
  14. using System.Web;
  15. using System.Data;
  16. using static OASystem.Infrastructure.Repositories.Groups.AirTicketResRepository;
  17. using static OpenAI.GPT3.ObjectModels.SharedModels.IOpenAiModels;
  18. using Cell = Aspose.Words.Tables.Cell;
  19. using Row = Aspose.Words.Tables.Row;
  20. using System.Runtime.Intrinsics.Arm;
  21. using Microsoft.AspNetCore.Mvc.Filters;
  22. using OASystem.Domain.Entities.Customer;
  23. using NPOI.SS.Formula.Functions;
  24. using OASystem.Domain.Dtos.CRM;
  25. namespace OASystem.API.Controllers
  26. {
  27. /// <summary>
  28. /// 团组相关
  29. /// </summary>
  30. //[Authorize]
  31. [Route("api/[controller]/[action]")]
  32. public class GroupsController : ControllerBase
  33. {
  34. private readonly GrpScheduleRepository _grpScheduleRep;
  35. private readonly IMapper _mapper;
  36. private readonly DelegationInfoRepository _groupRepository;
  37. private readonly TaskAssignmentRepository _taskAssignmentRep;
  38. private readonly AirTicketResRepository _airTicketResRep;
  39. private readonly DecreasePaymentsRepository _decreasePaymentsRep;
  40. private readonly InvitationOfficialActivitiesRepository _InvitationOfficialActivitiesRep;
  41. private readonly DelegationEnDataRepository _delegationEnDataRep;
  42. private readonly SqlSugarClient _sqlSugar;
  43. private string url;
  44. private string path;
  45. public GroupsController(IMapper mapper, SqlSugarClient sqlSugar, GrpScheduleRepository grpScheduleRep, DelegationInfoRepository groupRepository,
  46. TaskAssignmentRepository taskAssignmentRep, AirTicketResRepository airTicketResRep, DecreasePaymentsRepository decreasePaymentsRep,
  47. InvitationOfficialActivitiesRepository InvitationOfficialActivitiesRep, DelegationEnDataRepository delegationEnDataRep)
  48. {
  49. _mapper = mapper;
  50. _grpScheduleRep = grpScheduleRep;
  51. _groupRepository = groupRepository;
  52. _taskAssignmentRep = taskAssignmentRep;
  53. _airTicketResRep = airTicketResRep;
  54. _sqlSugar = sqlSugar;
  55. url = AppSettingsHelper.Get("ExcelBaseUrl");
  56. path = AppSettingsHelper.Get("ExcelBasePath");
  57. if (!System.IO.Directory.Exists(path))
  58. {
  59. System.IO.Directory.CreateDirectory(path);//不存在就创建文件夹
  60. }
  61. _decreasePaymentsRep = decreasePaymentsRep;
  62. _InvitationOfficialActivitiesRep = InvitationOfficialActivitiesRep;
  63. _delegationEnDataRep = delegationEnDataRep;
  64. }
  65. #region 流程管控
  66. /// <summary>
  67. /// 获取团组流程管控信息
  68. /// </summary>
  69. /// <param name="paras">参数Json字符串</param>
  70. /// <returns></returns>
  71. [HttpPost]
  72. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  73. public async Task<IActionResult> PostSearchGrpSchedule(JsonDtoBase _jsonDto)
  74. {
  75. if (string.IsNullOrEmpty(_jsonDto.Paras))
  76. {
  77. return Ok(JsonView(false, "参数为空"));
  78. }
  79. Grp_ScheduleDto _ScheduleDto = JsonConvert.DeserializeObject<Grp_ScheduleDto>(_jsonDto.Paras);
  80. if (_ScheduleDto != null)
  81. {
  82. if (_ScheduleDto.SearchType == 2)//获取列表
  83. {
  84. List<Grp_ScheduleView> _grpScheduleViewList = await _grpScheduleRep.GetViewList_GrpSchedule(_ScheduleDto);
  85. return Ok(JsonView(_grpScheduleViewList));
  86. }
  87. else//获取对象
  88. {
  89. Grp_ScheduleCombinView _grpScheduleView = await _grpScheduleRep.GetView_GrpSchedule(_ScheduleDto);
  90. if (_grpScheduleView != null)
  91. {
  92. return Ok(JsonView(_grpScheduleView));
  93. }
  94. }
  95. }
  96. else
  97. {
  98. return Ok(JsonView(false, "参数反序列化失败"));
  99. }
  100. return Ok(JsonView(false, "暂无数据!"));
  101. }
  102. /// <summary>
  103. /// 修改团组流程管控详细表数据
  104. /// </summary>
  105. /// <param name="paras"></param>
  106. /// <returns></returns>
  107. [HttpPost]
  108. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  109. public async Task<IActionResult> PostUpdateGrpScheduleDetail(Grp_ScheduleDetailUpdDto dto)
  110. {
  111. Grp_ScheduleDetailInfo _detail = _mapper.Map<Grp_ScheduleDetailInfo>(dto);
  112. var result = await _grpScheduleRep._sqlSugar.Updateable<Grp_ScheduleDetailInfo>()
  113. .SetColumns(it => it.Duty == _detail.Duty)
  114. .SetColumns(it => it.ExpectBeginDt == _detail.ExpectBeginDt)
  115. .SetColumns(it => it.ExpectEndDt == _detail.ExpectEndDt)
  116. .SetColumns(it => it.JobContent == _detail.JobContent)
  117. .SetColumns(it => it.Remark == _detail.Remark)
  118. .SetColumns(it => it.StepStatus == _detail.StepStatus)
  119. .Where(s => s.Id == dto.Id)
  120. //.UpdateColumns(s => new { s.Duty, s.ExpectBeginDt, s.ExpectEndDt, s.JobContent, s.Remark, s.StepStatus })
  121. .ExecuteCommandAsync();
  122. if (result > 0)
  123. {
  124. return Ok(JsonView(true, "保存成功!"));
  125. }
  126. return Ok(JsonView(false, "保存失败!"));
  127. }
  128. /// <summary>
  129. /// 删除团组流程管控详细表数据,删除人Id请放在Duty
  130. /// </summary>
  131. /// <param name="dto"></param>
  132. /// <returns></returns>
  133. [HttpPost]
  134. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  135. public async Task<ActionResult> PostDeleteGrpScheduleDetail(Grp_ScheduleDetailUpdDto dto)
  136. {
  137. Grp_ScheduleDetailInfo _detail = _mapper.Map<Grp_ScheduleDetailInfo>(dto);
  138. _detail.IsDel = 1;
  139. _detail.DeleteUserId = dto.Duty;
  140. _detail.DeleteTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  141. var result = await _grpScheduleRep._sqlSugar.Updateable<Grp_ScheduleDetailInfo>()
  142. .SetColumns(it => it.IsDel == _detail.IsDel)
  143. .SetColumns(it => it.DeleteUserId == _detail.DeleteUserId)
  144. .SetColumns(it => it.DeleteTime == _detail.DeleteTime)
  145. .Where(it => it.Id == dto.Id)
  146. //.UpdateColumns(s => new { s.IsDel, s.DeleteUserId, s.DeleteTime })
  147. //.WhereColumns(s => s.Id == dto.Id)
  148. .ExecuteCommandAsync();
  149. if (result > 0)
  150. {
  151. return Ok(JsonView(true, "删除成功!"));
  152. }
  153. return Ok(JsonView(false, "删除失败!"));
  154. }
  155. /// <summary>
  156. /// 增加团组流程管控详细表数据
  157. /// </summary>
  158. /// <param name="dto"></param>
  159. /// <returns></returns>
  160. [HttpPost]
  161. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  162. public async Task<ActionResult> PostInsertGrpScheduleDetail(Grp_ScheduleDetailInsertDto dto)
  163. {
  164. Grp_ScheduleDetailInfo _detail = _mapper.Map<Grp_ScheduleDetailInfo>(dto);
  165. if (DateTime.Now < _detail.ExpectBeginDt)
  166. {
  167. _detail.StepStatus = 0;
  168. }
  169. else
  170. {//若大于设置时间,不考虑设置的预计结束日期,统一视为进行中
  171. _detail.StepStatus = 1;
  172. }
  173. var result = await _grpScheduleRep._sqlSugar.Insertable(_detail).ExecuteReturnIdentityAsync();
  174. if (result > 0)
  175. {
  176. Grp_ScheduleDetailView _result = await _grpScheduleRep.GetInsertBackData(result);
  177. return Ok(JsonView(true, "添加成功!", _result));
  178. }
  179. return Ok(JsonView(false, "添加失败!"));
  180. }
  181. #endregion
  182. #region 团组基本信息
  183. /// <summary>
  184. /// 接团信息列表
  185. /// </summary>
  186. /// <param name="dto">团组列表请求dto</param>
  187. /// <returns></returns>
  188. [HttpPost]
  189. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  190. public async Task<IActionResult> GetGroupList(GroupListDto dto)
  191. {
  192. var groupData = await _groupRepository.GetGroupList(dto);
  193. if (groupData.Code != 0)
  194. {
  195. return Ok(JsonView(false, groupData.Msg));
  196. }
  197. return Ok(JsonView(groupData.Data));
  198. }
  199. /// <summary>
  200. /// 接团信息详情
  201. /// </summary>
  202. /// <param name="dto">团组info请求dto</param>
  203. /// <returns></returns>
  204. [HttpPost]
  205. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  206. public async Task<IActionResult> GetGroupInfo(GroupInfoDto dto)
  207. {
  208. var groupData = await _groupRepository.GetGroupInfo(dto);
  209. if (groupData.Code != 0)
  210. {
  211. return Ok(JsonView(false, groupData.Msg));
  212. }
  213. return Ok(JsonView(groupData.Data));
  214. }
  215. /// <summary>
  216. /// 接团信息 编辑添加
  217. /// 基础信息数据源
  218. /// </summary>
  219. /// <param name="dto"></param>
  220. /// <returns></returns>
  221. [HttpPost]
  222. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  223. public async Task<IActionResult> GroupEditBasicSource(GroupListDto dto)
  224. {
  225. var groupData = await _groupRepository.GroupEditBasicSource(dto);
  226. if (groupData.Code != 0)
  227. {
  228. return Ok(JsonView(false, groupData.Msg));
  229. }
  230. return Ok(JsonView(groupData.Data));
  231. }
  232. /// <summary>
  233. /// 接团信息 操作(增改)
  234. /// </summary>
  235. /// <param name="dto"></param>
  236. /// <returns></returns>
  237. [HttpPost]
  238. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  239. public async Task<IActionResult> GroupOperation(GroupOperationDto dto)
  240. {
  241. try
  242. {
  243. var groupData = await _groupRepository.GroupOperation(dto);
  244. if (groupData.Code != 0)
  245. {
  246. return Ok(JsonView(false, groupData.Msg));
  247. }
  248. return Ok(JsonView(true));
  249. }
  250. catch (Exception ex)
  251. {
  252. Logs("[response]" + JsonConvert.SerializeObject(dto));
  253. Logs(ex.Message);
  254. return Ok(JsonView(false, ex.Message));
  255. }
  256. }
  257. /// <summary>
  258. /// 接团信息 操作(删除)
  259. /// </summary>
  260. /// <param name="dto"></param>
  261. /// <returns></returns>
  262. [HttpPost]
  263. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  264. public async Task<IActionResult> GroupDel(GroupDelDto dto)
  265. {
  266. try
  267. {
  268. var groupData = await _groupRepository.GroupDel(dto);
  269. if (groupData.Code != 0)
  270. {
  271. return Ok(JsonView(false, groupData.Msg));
  272. }
  273. return Ok(JsonView(true));
  274. }
  275. catch (Exception ex)
  276. {
  277. Logs("[response]" + JsonConvert.SerializeObject(dto));
  278. Logs(ex.Message);
  279. return Ok(JsonView(false, ex.Message));
  280. }
  281. }
  282. /// <summary>
  283. /// 获取团组销售报价号
  284. /// 团组添加时 使用
  285. /// </summary>
  286. /// <returns></returns>
  287. [HttpPost]
  288. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  289. public async Task<IActionResult> GetGroupSalesQuoteNo()
  290. {
  291. var groupData = await _groupRepository.GetGroupSalesQuoteNo();
  292. if (groupData.Code != 0)
  293. {
  294. return Ok(JsonView(false, groupData.Msg));
  295. }
  296. object salesQuoteNo = new
  297. {
  298. SalesQuoteNo = groupData.Data
  299. };
  300. return Ok(JsonView(salesQuoteNo));
  301. }
  302. /// <summary>
  303. /// 设置确认出团
  304. /// </summary>
  305. /// <param name="dto"></param>
  306. /// <returns></returns>
  307. [HttpPost]
  308. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  309. public async Task<IActionResult> SetConfirmationGroup(ConfirmationGroupDto dto)
  310. {
  311. var groupData = await _groupRepository.ConfirmationGroup(dto);
  312. if (groupData.Code != 0)
  313. {
  314. return Ok(JsonView(false, groupData.Msg));
  315. }
  316. GroupStepForDelegation.CreateWorkStep(dto.GroupId); //创建管控流程
  317. return Ok(JsonView(groupData.Data));
  318. }
  319. /// <summary>
  320. /// 获取团组名称 List
  321. /// </summary>
  322. /// <param name="dto"></param>
  323. /// <returns></returns>
  324. [HttpPost]
  325. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  326. public async Task<IActionResult> GetGroupNameList(GroupNameDto dto)
  327. {
  328. var groupData = await _groupRepository.GetGroupNameList(dto);
  329. if (groupData.Code != 0)
  330. {
  331. return Ok(JsonView(false, groupData.Msg));
  332. }
  333. return Ok(JsonView(groupData.Data, groupData.Data.Count));
  334. }
  335. /// <summary>
  336. /// 获取团组名称data And 签证国别Data
  337. /// </summary>
  338. /// <param name="dto"></param>
  339. /// <returns></returns>
  340. [HttpPost]
  341. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  342. public async Task<IActionResult> GetGroupNameAndVisaNationality(GroupNameDto dto)
  343. {
  344. var groupData = await _groupRepository.GetGroupNameAndVisaNationality(dto);
  345. if (groupData.Code != 0)
  346. {
  347. return Ok(JsonView(false, groupData.Msg));
  348. }
  349. return Ok(JsonView(groupData.Data));
  350. }
  351. #endregion
  352. #region 团组&签证
  353. /// <summary>
  354. /// 根据团组Id获取签证客户信息List
  355. /// </summary>
  356. /// <param name="dto">请求dto</param>
  357. /// <returns></returns>
  358. [HttpPost]
  359. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  360. public async Task<IActionResult> GetCrmByGroupId(ClientByGroupIdDto dto)
  361. {
  362. var groupData = await _groupRepository.GetCrmByGroupId(dto);
  363. if (groupData.Code != 0)
  364. {
  365. return Ok(JsonView(false, groupData.Msg));
  366. }
  367. return Ok(JsonView(groupData.Data));
  368. }
  369. #endregion
  370. #region 团组任务分配
  371. /// <summary>
  372. /// 团组任务分配初始化
  373. /// </summary>
  374. /// <param name="dto"></param>
  375. /// <returns></returns>
  376. [HttpPost]
  377. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  378. public async Task<IActionResult> GetTaskAssignmen()
  379. {
  380. var groupData = await _taskAssignmentRep.GetTaskAssignmen();
  381. if (groupData.Code != 0)
  382. {
  383. return Ok(JsonView(false, groupData.Msg));
  384. }
  385. return Ok(JsonView(true, groupData.Msg, groupData.Data));
  386. }
  387. /// <summary>
  388. /// 团组任务分配查询
  389. /// </summary>
  390. /// <param name="dto"></param>
  391. /// <returns></returns>
  392. [HttpPost]
  393. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  394. public async Task<IActionResult> TaskAssignmenQuery(TaskAssignmenQueryDto dto)
  395. {
  396. var groupData = await _taskAssignmentRep.TaskAssignmenQuery(dto);
  397. if (groupData.Code != 0)
  398. {
  399. return Ok(JsonView(false, groupData.Msg));
  400. }
  401. return Ok(JsonView(true, groupData.Msg, groupData.Data));
  402. }
  403. /// <summary>
  404. /// 团组任务分配操作
  405. /// </summary>
  406. /// <param name="dto"></param>
  407. /// <returns></returns>
  408. [HttpPost]
  409. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  410. public async Task<IActionResult> GetTaskAssignmenOp(TaskAssignmenDto dto)
  411. {
  412. Result groupData = await _taskAssignmentRep.GetTaskAssignmenOp(dto);
  413. if (groupData.Code != 0)
  414. {
  415. return Ok(JsonView(false, groupData.Msg));
  416. }
  417. return Ok(JsonView(true, groupData.Msg, groupData.Data));
  418. }
  419. #endregion
  420. #region 团组费用审核
  421. /// <summary>
  422. /// 获取团组费用审核
  423. /// </summary>
  424. /// <param name="paras">参数Json字符串</param>
  425. /// <returns></returns>
  426. [HttpPost]
  427. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  428. public async Task<IActionResult> PostSearchGrpCreditCardPayment(Search_GrpCreditCardPaymentDto _dto)
  429. {
  430. if (_dto.DiId < 1)
  431. {
  432. return Ok(JsonView(false, "团组Id为空"));
  433. }
  434. Grp_CreditCardPaymentView _view = new Grp_CreditCardPaymentView();
  435. #region 团组基本信息
  436. Grp_DelegationInfo _delegation = _groupRepository.Query<Grp_DelegationInfo>(s => s.Id == _dto.DiId).First();
  437. if (_delegation != null)
  438. {
  439. _view.ClientName = _delegation.ClientName;
  440. _view.DiId = _dto.DiId;
  441. _view.TeamName = _delegation.TeamName;
  442. _view.VisitCountry = _delegation.VisitCountry;
  443. _view.VisitDate = _delegation.VisitStartDate.ToString("yyyy-MM-dd") + " ~ " + _delegation.VisitEndDate.ToString("yyyy-MM-dd");
  444. _view.VisitDays = _delegation.VisitDays;
  445. _view.VisitPNumber = _delegation.VisitPNumber;
  446. }
  447. else
  448. {
  449. return Ok(JsonView(false, "团组信息为空"));
  450. }
  451. #endregion
  452. #region 费用清单
  453. var exp = Expressionable.Create<Grp_CreditCardPayment>();
  454. exp.AndIF(_dto.AuditStatus != -1, it => it.IsAuditGM == _dto.AuditStatus);
  455. exp.AndIF(_dto.Label != -1, it => it.CTable == _dto.Label);
  456. List<Grp_CreditCardPayment> entityList = _groupRepository
  457. .Query<Grp_CreditCardPayment>(s => s.DIId == _dto.DiId && s.IsDel == 0 && s.CreateUserId > 0)
  458. .Where(exp.ToExpression())
  459. .ToList();
  460. List<Grp_CreditCardPaymentDetailView> detailList = new List<Grp_CreditCardPaymentDetailView>();
  461. decimal CNY = 0;
  462. decimal PayCNY = 0;
  463. decimal BalanceCNY = 0;
  464. decimal YSFYCNY = 0;
  465. decimal USD = 0;
  466. decimal PayUSD = 0;
  467. decimal BalanceUSD = 0;
  468. decimal YSFYUSD = 0;
  469. decimal EUR = 0;
  470. decimal PayEUR = 0;
  471. decimal BalanceEUR = 0;
  472. decimal YSFYEUR = 0;
  473. foreach (var entity in entityList)
  474. {
  475. Grp_CreditCardPaymentDetailView _detail = new Grp_CreditCardPaymentDetailView();
  476. _detail.Id = entity.Id;
  477. /*
  478. * Bus名称
  479. */
  480. _detail.BusName = "";
  481. /*
  482. *费用所属
  483. */
  484. switch (entity.CTable)
  485. {
  486. case 85:
  487. Grp_AirTicketReservations jpRes = _groupRepository.Query<Grp_AirTicketReservations>(s => s.Id == entity.CId).First();
  488. if (jpRes != null)
  489. {
  490. string FlightsDescription = jpRes.FlightsDescription;
  491. string PriceDescription = jpRes.PriceDescription;
  492. _detail.PriceMsgContent = "航班号:" + jpRes.FlightsCode + "<br/>城市A-B:" + jpRes.FlightsCity + "<br/>航班描述:" + FlightsDescription.Replace("\r\n", "<br />") + "<br/>" + "价格描述:" + PriceDescription;
  493. _detail.PriceNameContent = "(" + jpRes.FlightsCode + ")";
  494. }
  495. break;
  496. case 79:
  497. _detail.BusName = "待增加";
  498. break;
  499. case 98:
  500. Grp_DecreasePayments gdpRes = _groupRepository.Query<Grp_DecreasePayments>(s => s.Id == entity.CId).First();
  501. if (gdpRes != null)
  502. {
  503. _detail.PriceMsgContent = "备注:" + gdpRes.Remark;
  504. _detail.PriceNameContent = gdpRes.PriceName;
  505. }
  506. break;
  507. default:
  508. break;
  509. }
  510. /*
  511. * 费用模块
  512. */
  513. Sys_SetData sdPriceName = _groupRepository.Query<Sys_SetData>(s => s.Id == entity.CTable).First();
  514. if (sdPriceName != null)
  515. {
  516. _detail.PriceName = sdPriceName.Name;
  517. }
  518. /*
  519. * 应付款金额
  520. */
  521. Sys_SetData sdPaymentCurrency_WaitPay = _groupRepository.Query<Sys_SetData>(s => s.Id == entity.PaymentCurrency).First();
  522. string PaymentCurrency_WaitPay = "Unknown";
  523. if (sdPaymentCurrency_WaitPay != null)
  524. {
  525. PaymentCurrency_WaitPay = sdPaymentCurrency_WaitPay.Name;
  526. }
  527. _detail.WaitPay = entity.PayMoney.ToString("#0.00") + " " + PaymentCurrency_WaitPay;
  528. /*
  529. * 此次付款金额
  530. */
  531. decimal CurrPayStr = 0;
  532. if (entity.PayPercentage == 0)
  533. {
  534. if (entity.PayThenMoney != 0)
  535. CurrPayStr = entity.PayThenMoney * entity.DayRate;
  536. }
  537. else
  538. {
  539. CurrPayStr = entity.PayMoney * (decimal.Parse(entity.PayPercentage.ToString("#0.00")) / 100 * entity.DayRate);
  540. }
  541. _detail.CurrPay = CurrPayStr.ToString("#0.00") + " CNY";
  542. /*
  543. * 剩余尾款
  544. */
  545. decimal BalanceStr = 0;
  546. if (entity.PayMoney - (CurrPayStr / entity.DayRate) < 0.01M)
  547. BalanceStr = 0;
  548. else
  549. BalanceStr = (entity.PayMoney - CurrPayStr / entity.DayRate);
  550. _detail.Balance = BalanceStr.ToString("#0.00") + " " + PaymentCurrency_WaitPay;
  551. /*
  552. * 申请人
  553. */
  554. string operatorName = "无";
  555. Sys_Users _opUser = _groupRepository.Query<Sys_Users>(s => s.Id == entity.CreateUserId).First();
  556. if (_opUser != null)
  557. {
  558. operatorName = _opUser.CnName;
  559. }
  560. _detail.OperatorName = operatorName;
  561. /*
  562. * 审核人
  563. */
  564. string auditOperatorName = "Unknown";
  565. if (entity.AuditGMOperate == 0)
  566. auditOperatorName = "无";
  567. else if (entity.AuditGMOperate == 4)
  568. auditOperatorName = "自动审核";
  569. else
  570. {
  571. Sys_Users _adUser = _groupRepository.Query<Sys_Users>(s => s.Id == entity.AuditGMOperate).First();
  572. if (_adUser != null)
  573. {
  574. auditOperatorName = _adUser.CnName;
  575. }
  576. }
  577. _detail.AuditOperatorName = auditOperatorName;
  578. /*
  579. *
  580. * *超预算比例
  581. */
  582. string overBudgetStr = "";
  583. if (entity.ExceedBudget == -1)
  584. overBudgetStr = sdPriceName.Name + "尚无预算";
  585. else if (entity.ExceedBudget == 0)
  586. overBudgetStr = "未超预算";
  587. else
  588. overBudgetStr = entity.ExceedBudget.ToString("P");
  589. _detail.OverBudget = overBudgetStr;
  590. /*
  591. * 费用总计
  592. */
  593. if (entity.PaymentCurrency == 48)
  594. {
  595. CNY += entity.PayMoney;
  596. PayCNY += CurrPayStr;
  597. BalanceCNY += BalanceStr;
  598. YSFYCNY += CurrPayStr;
  599. }
  600. if (entity.PaymentCurrency == 49)
  601. {
  602. USD += entity.PayMoney;
  603. PayUSD += CurrPayStr;
  604. BalanceUSD += BalanceStr;
  605. YSFYUSD += CurrPayStr;
  606. }
  607. if (entity.PaymentCurrency == 51)
  608. {
  609. EUR += entity.PayMoney;
  610. PayEUR += CurrPayStr;
  611. BalanceEUR += BalanceStr;
  612. YSFYEUR += CurrPayStr;
  613. }
  614. _detail.IsAuditGM = entity.IsAuditGM;
  615. detailList.Add(_detail);
  616. }
  617. #endregion
  618. _view.DetailList = new List<Grp_CreditCardPaymentDetailView>(detailList);
  619. _view.TotalStr1 = string.Format(@"应付款总金额:{0}CNY&nbsp;|&nbsp;{1}USD&nbsp;|&nbsp;{2}EUR", CNY, USD, EUR);
  620. _view.TotalStr2 = string.Format(@"此次付款总金额:{0}CNY&nbsp;|&nbsp;{1}USD&nbsp;|&nbsp;{2}EUR", PayCNY, PayUSD, PayEUR);
  621. _view.TotalStr3 = string.Format(@"目前剩余尾款总金额:{0}CNY&nbsp;|&nbsp;{1}USD&nbsp;|&nbsp;{2}EUR", BalanceCNY, BalanceUSD, BalanceEUR);
  622. _view.TotalStr4 = string.Format(@"已审费用总额:{0}CNY&nbsp;|&nbsp;{1}USD&nbsp;|&nbsp;{2}EUR", YSFYCNY, YSFYUSD, YSFYEUR);
  623. return Ok(JsonView(_view));
  624. }
  625. /// <summary>
  626. /// 修改团组费用审核状态
  627. /// </summary>
  628. /// <param name="paras">参数Json字符串</param>
  629. /// <returns></returns>
  630. [HttpPost]
  631. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  632. public async Task<IActionResult> PostAuditGrpCreditCardPayment(Edit_GrpCreditCardPaymentDto _dto)
  633. {
  634. List<string> idList = _dto.CreditIdStr.Split(',').ToList();
  635. Grp_CreditCardPayment _detail = _mapper.Map<Grp_CreditCardPayment>(_dto);
  636. DateTime dtNow = DateTime.Now;
  637. _groupRepository.BeginTran();
  638. int rst = 0;
  639. foreach (var item in idList)
  640. {
  641. int CreditId = int.Parse(item);
  642. var result = await _grpScheduleRep._sqlSugar.Updateable<Grp_CreditCardPayment>()
  643. .SetColumns(it => it.IsAuditGM == _dto.AuditCode)
  644. .SetColumns(it => it.AuditGMOperate == _dto.User)
  645. .SetColumns(it => it.AuditGMDate == dtNow.ToString())
  646. .Where(s => s.Id == CreditId)
  647. .ExecuteCommandAsync();
  648. if (result < 1)
  649. {
  650. rst = -1;
  651. }
  652. else
  653. {
  654. _groupRepository.RollbackTran();
  655. return Ok(JsonView(false, "保存失败并回滚!"));
  656. }
  657. }
  658. _groupRepository.CommitTran();
  659. if (rst == 0)
  660. {
  661. return Ok(JsonView(true, "保存成功!"));
  662. }
  663. return Ok(JsonView(false, "保存失败!"));
  664. }
  665. #endregion
  666. #region 机票费用录入
  667. /// <summary>
  668. /// 机票录入当前登录人可操作团组
  669. /// </summary>
  670. /// <param name="dto"></param>
  671. /// <returns></returns>
  672. [HttpPost]
  673. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  674. public async Task<IActionResult> AirTicketResSelect(AirTicketResDto dto)
  675. {
  676. try
  677. {
  678. Result groupData = await _airTicketResRep.AirTicketResSelect(dto);
  679. if (groupData.Code != 0)
  680. {
  681. return Ok(JsonView(false, groupData.Msg));
  682. }
  683. return Ok(JsonView(true, groupData.Msg, groupData.Data));
  684. }
  685. catch (Exception ex)
  686. {
  687. return Ok(JsonView(false, "程序错误!"));
  688. throw;
  689. }
  690. }
  691. /// <summary>
  692. /// 机票费用录入列表
  693. /// </summary>
  694. /// <param name="dto"></param>
  695. /// <returns></returns>
  696. [HttpPost]
  697. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  698. public async Task<IActionResult> AirTicketResList(AirTicketResDto dto)
  699. {
  700. try
  701. {
  702. Result groupData = await _airTicketResRep.AirTicketResList(dto);
  703. if (groupData.Code != 0)
  704. {
  705. return Ok(JsonView(false, groupData.Msg));
  706. }
  707. return Ok(JsonView(true, groupData.Msg, groupData.Data));
  708. }
  709. catch (Exception ex)
  710. {
  711. return Ok(JsonView(false, "程序错误!"));
  712. throw;
  713. }
  714. }
  715. /// <summary>
  716. /// 根据id查询费用录入信息
  717. /// </summary>
  718. /// <param name="dto"></param>
  719. /// <returns></returns>
  720. [HttpPost]
  721. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  722. public async Task<IActionResult> AirTicketResById(AirTicketResByIdDto dto)
  723. {
  724. try
  725. {
  726. Result groupData = await _airTicketResRep.AirTicketResById(dto);
  727. if (groupData.Code != 0)
  728. {
  729. return Ok(JsonView(false, groupData.Msg));
  730. }
  731. return Ok(JsonView(true, groupData.Msg, groupData.Data));
  732. }
  733. catch (Exception ex)
  734. {
  735. return Ok(JsonView(false, "程序错误!"));
  736. throw;
  737. }
  738. }
  739. /// <summary>
  740. /// 机票费用录入操作(Status:1.新增,2.修改)
  741. /// </summary>
  742. /// <param name="dto"></param>
  743. /// <returns></returns>
  744. [HttpPost]
  745. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  746. public async Task<IActionResult> OpAirTicketRes(AirTicketResOpDto dto)
  747. {
  748. try
  749. {
  750. Result groupData = await _airTicketResRep.OpAirTicketRes(dto);
  751. if (groupData.Code != 0)
  752. {
  753. return Ok(JsonView(false, groupData.Msg));
  754. }
  755. return Ok(JsonView(true, groupData.Msg, groupData.Data));
  756. }
  757. catch (Exception ex)
  758. {
  759. return Ok(JsonView(false, "程序错误!"));
  760. throw;
  761. }
  762. }
  763. /// <summary>
  764. /// 根据舱位类型查询接团客户名单信息
  765. /// </summary>
  766. /// <param name="dto"></param>
  767. /// <returns></returns>
  768. [HttpPost]
  769. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  770. public async Task<IActionResult> tankType(AirTicketResByIdDto dto)
  771. {
  772. try
  773. {
  774. List<Crm_GroupCustomer> crm_Groups = _sqlSugar.Queryable<Crm_GroupCustomer>().Where(a=>a.IsDel==0 && a.AirType==dto.Id).ToList();
  775. if (crm_Groups.Count!=0)
  776. {
  777. List<dynamic> Customer = new List<dynamic>();
  778. foreach (var item in crm_Groups)
  779. {
  780. var data = new
  781. {
  782. Id = item.Id,
  783. Pinyin = item.Pinyin,
  784. Name = item.LastName+item.FirstName
  785. };
  786. Customer.Add(data);
  787. }
  788. return Ok(JsonView(true, "查询成功!", Customer));
  789. }
  790. return Ok(JsonView(true, "暂无数据", crm_Groups));
  791. }
  792. catch (Exception ex)
  793. {
  794. return Ok(JsonView(false, "程序错误!"));
  795. throw;
  796. }
  797. }
  798. /// <summary>
  799. /// 机票费用录入,删除
  800. /// </summary>
  801. /// <param name="dto"></param>
  802. /// <returns></returns>
  803. [HttpPost]
  804. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  805. public async Task<IActionResult> DelAirTicketRes(DelBaseDto dto)
  806. {
  807. try
  808. {
  809. var res = await _airTicketResRep.SoftDeleteByIdAsync<Grp_AirTicketReservations>(dto.Id.ToString(), dto.DeleteUserId);
  810. if (!res)
  811. {
  812. return Ok(JsonView(false, "删除失败"));
  813. }
  814. return Ok(JsonView(true, "删除成功!"));
  815. }
  816. catch (Exception ex)
  817. {
  818. return Ok(JsonView(false, "程序错误!"));
  819. throw;
  820. }
  821. }
  822. /// <summary>
  823. /// 导出机票录入报表
  824. /// </summary>
  825. /// <param name="dto"></param>
  826. /// <returns></returns>
  827. [HttpPost]
  828. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  829. public async Task<IActionResult> DeriveAirTicketRes(AirTicketResDto dto)
  830. {
  831. try
  832. {
  833. Result groupData = await _airTicketResRep.DeriveAirTicketRes(dto);
  834. if (groupData.Code != 0)
  835. {
  836. return Ok(JsonView(false, groupData.Msg));
  837. }
  838. else
  839. {
  840. List<AirTicketReservationsPayView> AirTicketReservations = groupData.Data.GetType().GetProperty("AirTicketRes").GetValue(groupData.Data);
  841. if (AirTicketReservations.Count != 0)
  842. {
  843. Grp_DelegationInfo DelegationInfo = groupData.Data.GetType().GetProperty("Delegation").GetValue(groupData.Data);
  844. Sys_Users _Users = groupData.Data.GetType().GetProperty("Users").GetValue(groupData.Data);
  845. string diCode = DelegationInfo != null ? DelegationInfo.TourCode : "XXX";
  846. string diName = DelegationInfo != null ? DelegationInfo.TeamName : "XXX";
  847. WorkbookDesigner designer = new WorkbookDesigner();
  848. designer.Workbook = new Workbook(AppSettingsHelper.Get("ExcelBasePath") + "Template/机票预订费用报表模板.xlsx");
  849. decimal countCost = 0;
  850. foreach (var item in AirTicketReservations)
  851. {
  852. if (item.BankType == "其他")
  853. {
  854. item.BankNo = "--";
  855. }
  856. else
  857. {
  858. item.BankNo = item.BankType + ":" + item.BankNo.Substring(0, 3);
  859. }
  860. item.PrePrice = System.Decimal.Round(item.PrePrice, 2);
  861. item.Price = System.Decimal.Round(item.Price, 2);
  862. countCost += Convert.ToDecimal(item.Price);
  863. }
  864. designer.SetDataSource("Export", AirTicketReservations);
  865. designer.SetDataSource("ExportDiCode", diCode);
  866. designer.SetDataSource("ExportDiName", diName);
  867. designer.SetDataSource("ExportOpUserName", _Users.CnName);
  868. designer.SetDataSource("ExportCountCost", countCost + "(" + AirTicketReservations[0].CurrencyStr);
  869. designer.Process();
  870. string fileName = "AirfareStatement/" + diName + "机票费用报表" + "_" + DateTime.Now.ToString("yyyyMMddHHmmss") + ".xlsx";
  871. designer.Workbook.Save(AppSettingsHelper.Get("ExcelBasePath") + fileName);
  872. string rst = AppSettingsHelper.Get("ExcelBaseUrl") + AppSettingsHelper.Get("ExcelFtpPath") + fileName;
  873. return Ok(JsonView(true, "成功", url = rst));
  874. }
  875. else
  876. {
  877. return Ok(JsonView(false, "暂无数据!"));
  878. }
  879. }
  880. }
  881. catch (Exception ex)
  882. {
  883. return Ok(JsonView(false, "程序错误!"));
  884. throw;
  885. }
  886. }
  887. Dictionary<string, string> transDic = new Dictionary<string, string>();
  888. /// <summary>
  889. /// 行程单导出
  890. /// </summary>
  891. /// <param name="dto"></param>
  892. /// <returns></returns>
  893. [HttpPost]
  894. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  895. public async Task<IActionResult> ItineraryAirTicketRes(ItineraryAirTicketResDto dto)
  896. {
  897. try
  898. {
  899. Result groupData = await _airTicketResRep.ItineraryAirTicketRes(dto);
  900. if (groupData.Code != 0)
  901. {
  902. return Ok(JsonView(false, groupData.Msg));
  903. }
  904. else
  905. {
  906. List<AirTicketReservationsView> _AirTicketReservations = groupData.Data;
  907. if (dto.Language == "CN")
  908. {
  909. Document doc = new Document(AppSettingsHelper.Get("WordBasePath") + "Template/电子客票行程单模板_CN.docx");
  910. DocumentBuilder builder = new DocumentBuilder(doc);
  911. int tableIndex = 0;//表格索引
  912. //得到文档中的第一个表格
  913. Table table = (Table)doc.GetChild(NodeType.Table, tableIndex, true);
  914. foreach (var item in _AirTicketReservations)
  915. {
  916. #region 处理固定数据
  917. string[] FlightsCode = item.FlightsCode.Split('/');
  918. if (FlightsCode.Length != 0)
  919. {
  920. Res_AirCompany _AirCompany = _sqlSugar.Queryable<Res_AirCompany>().First(a => a.ShortCode == FlightsCode[0].Substring(0, 2));
  921. if (_AirCompany != null)
  922. {
  923. table.Range.Bookmarks["AirlineCompany"].Text = _AirCompany.CnName;
  924. }
  925. else
  926. {
  927. table.Range.Bookmarks["AirlineCompany"].Text = "--";
  928. }
  929. }
  930. table.Range.Bookmarks["AirlineRecordCode"].Text = "--";
  931. table.Range.Bookmarks["ReservationRecordCode"].Text = "--";
  932. string[] nameArray = Regex.Split(item.ClientName, "\\d+\\.", RegexOptions.IgnoreCase);
  933. nameArray = nameArray.Where(str => str != "" && str != " " && !string.IsNullOrEmpty(str)).ToArray();
  934. string name = "";
  935. foreach (string clientName in nameArray)
  936. {
  937. if (!name.Contains(clientName))
  938. {
  939. name += clientName + ",";
  940. }
  941. }
  942. if (!string.IsNullOrWhiteSpace(name))
  943. {
  944. table.Range.Bookmarks["ClientName"].Text = name.Substring(0, name.Length - 1);
  945. }
  946. else
  947. {
  948. table.Range.Bookmarks["ClientName"].Text = "--";
  949. }
  950. table.Range.Bookmarks["TicketNumber"].Text = "--";
  951. table.Range.Bookmarks["IdentificationCode"].Text = "--";
  952. table.Range.Bookmarks["JointTicket"].Text = "--";
  953. table.Range.Bookmarks["TimeIssue"].Text = "--";
  954. table.Range.Bookmarks["DrawingAgent"].Text = "--";
  955. table.Range.Bookmarks["NavigationCode"].Text = "--";
  956. table.Range.Bookmarks["AgentsAddress"].Text = "--";
  957. table.Range.Bookmarks["AgentPhone"].Text = "--";
  958. table.Range.Bookmarks["AgentFacsimile"].Text = "--";
  959. #endregion
  960. #region 循环数据处理
  961. List<AirInfo> airs = new List<AirInfo>();
  962. string[] DayArray = Regex.Split(item.FlightsDescription, "\\d+\\.", RegexOptions.IgnoreCase);
  963. DayArray = DayArray.Where(s => s != " " && s != "" && !string.IsNullOrEmpty(s)).ToArray();
  964. for (int i = 0; i < FlightsCode.Length; i++)
  965. {
  966. AirInfo air = new AirInfo();
  967. string[] tempstr = DayArray[i]
  968. .Replace("\r\n", string.Empty)
  969. .Replace("\\r\\n", string.Empty)
  970. .TrimStart().TrimEnd()
  971. .Split(new char[] { ' ' }, StringSplitOptions.RemoveEmptyEntries);
  972. Res_ThreeCode star_Three = _sqlSugar.Queryable<Res_ThreeCode>().First(a => a.Three == tempstr[3].Substring(0, 3));
  973. string starCity = "";
  974. if (star_Three != null)
  975. {
  976. starCity = star_Three.AirPort;
  977. }
  978. Res_ThreeCode End_Three = _sqlSugar.Queryable<Res_ThreeCode>().First(a => a.Three == tempstr[3].Substring(3, 3));
  979. string EndCity = "";
  980. if (End_Three != null)
  981. {
  982. EndCity = End_Three.AirPort;
  983. }
  984. air.Destination = starCity + "/" + EndCity;
  985. air.Flight = FlightsCode[i];
  986. air.SeatingClass = item.CTypeName;
  987. string dateTime = tempstr[2];
  988. string DateTemp = dateTime.Substring(2, 5).ToUpper();
  989. air.FlightDate = DateTemp;
  990. air.DepartureTime = tempstr[5];
  991. air.LandingTime = tempstr[6];
  992. air.ValidityPeriod = DateTemp + "/" + DateTemp;
  993. air.TicketStatus = "--";
  994. air.Luggage = "--";
  995. air.DepartureTerminal = "--";
  996. air.LandingTerminal = "--";
  997. airs.Add(air);
  998. }
  999. int row = 13;
  1000. for (int i = 0; i < airs.Count; i++)
  1001. {
  1002. if (airs.Count > 2)
  1003. {
  1004. for (int j = 0; j < airs.Count - 2; j++)
  1005. {
  1006. var CopyRow = table.Rows[12].Clone(true);
  1007. table.Rows.Add(CopyRow);
  1008. }
  1009. }
  1010. PropertyInfo[] properties = airs[i].GetType().GetProperties();
  1011. int index = 0;
  1012. foreach (PropertyInfo property in properties)
  1013. {
  1014. string value = property.GetValue(airs[i]).ToString();
  1015. Cell ishcel0 = table.Rows[row].Cells[index];
  1016. Paragraph p = new Paragraph(doc);
  1017. string s = value;
  1018. p.AppendChild(new Run(doc, s));
  1019. p.ParagraphFormat.Alignment = ParagraphAlignment.Center;//水平居中对齐
  1020. ishcel0.AppendChild(p);
  1021. ishcel0.CellFormat.VerticalAlignment = CellVerticalAlignment.Center;//垂直居中对齐
  1022. index++;
  1023. }
  1024. row++;
  1025. }
  1026. #endregion
  1027. Paragraph lastParagraph = new Paragraph(doc);
  1028. //第一个表格末尾加段落
  1029. table.ParentNode.InsertAfter(lastParagraph, table);
  1030. //复制第一个表格
  1031. Table cloneTable = (Table)table.Clone(true);
  1032. //在文档末尾段落后面加入复制的表格
  1033. table.ParentNode.InsertAfter(cloneTable, lastParagraph);
  1034. if (item != _AirTicketReservations[_AirTicketReservations.Count - 1])
  1035. {
  1036. int rownewsIndex = 13;
  1037. for (int i = 0; i < 2; i++)
  1038. {
  1039. var CopyRow = table.Rows[12].Clone(true);
  1040. table.Rows.RemoveAt(13);
  1041. table.Rows.Add(CopyRow);
  1042. rownewsIndex++;
  1043. }
  1044. }
  1045. else
  1046. {
  1047. table.Rows.RemoveAt(12);
  1048. }
  1049. cloneTable.Rows.RemoveAt(12);
  1050. }
  1051. if (_AirTicketReservations.Count != 0)
  1052. {
  1053. string[] FlightsCode = _AirTicketReservations[0].FlightsCode.Split('/');
  1054. if (FlightsCode.Length != 0)
  1055. {
  1056. Res_AirCompany _AirCompany = _sqlSugar.Queryable<Res_AirCompany>().First(a => a.ShortCode == FlightsCode[0].Substring(0, 2));
  1057. if (_AirCompany != null)
  1058. {
  1059. table.Range.Bookmarks["AirlineCompany"].Text = _AirCompany.CnName;
  1060. }
  1061. else
  1062. {
  1063. table.Range.Bookmarks["AirlineCompany"].Text = "--";
  1064. }
  1065. }
  1066. table.Range.Bookmarks["AirlineRecordCode"].Text = "--";
  1067. table.Range.Bookmarks["ReservationRecordCode"].Text = "--";
  1068. string[] nameArray = Regex.Split(_AirTicketReservations[0].ClientName, "\\d+\\.", RegexOptions.IgnoreCase);
  1069. nameArray = nameArray.Where(str => str != "" && str != " " && !string.IsNullOrEmpty(str)).ToArray();
  1070. string name = "";
  1071. foreach (string clientName in nameArray)
  1072. {
  1073. if (!name.Contains(clientName))
  1074. {
  1075. name += clientName + ",";
  1076. }
  1077. }
  1078. if (!string.IsNullOrWhiteSpace(name))
  1079. {
  1080. table.Range.Bookmarks["ClientName"].Text = name.Substring(0, name.Length - 1);
  1081. }
  1082. else
  1083. {
  1084. table.Range.Bookmarks["ClientName"].Text = "--";
  1085. }
  1086. table.Range.Bookmarks["TicketNumber"].Text = "--";
  1087. table.Range.Bookmarks["IdentificationCode"].Text = "--";
  1088. table.Range.Bookmarks["JointTicket"].Text = "--";
  1089. table.Range.Bookmarks["TimeIssue"].Text = "--";
  1090. table.Range.Bookmarks["DrawingAgent"].Text = "--";
  1091. table.Range.Bookmarks["NavigationCode"].Text = "--";
  1092. table.Range.Bookmarks["AgentsAddress"].Text = "--";
  1093. table.Range.Bookmarks["AgentPhone"].Text = "--";
  1094. table.Range.Bookmarks["AgentFacsimile"].Text = "--";
  1095. }
  1096. doc.MailMerge.Execute(new[] { "PageCount" }, new object[] { doc.PageCount });
  1097. //保存合并后的文档
  1098. string fileName = "AirItinerary/电子客票中文行程单_CN.docx";
  1099. string rst = AppSettingsHelper.Get("WordBaseUrl") + AppSettingsHelper.Get("WordFtpPath") + fileName;
  1100. doc.Save(AppSettingsHelper.Get("WordBasePath") + fileName);
  1101. return Ok(JsonView(true, "成功!", rst));
  1102. }
  1103. else
  1104. {
  1105. Document doc = new Document(AppSettingsHelper.Get("WordBasePath") + "Template/电子客票行程单模板_EN.docx");
  1106. DocumentBuilder builder = new DocumentBuilder(doc);
  1107. int tableIndex = 0;//表格索引
  1108. //得到文档中的第一个表格
  1109. Table table = (Table)doc.GetChild(NodeType.Table, tableIndex, true);
  1110. List<string> texts = new List<string>();
  1111. foreach (var item in _AirTicketReservations)
  1112. {
  1113. string[] FlightsCode = item.FlightsCode.Split('/');
  1114. if (FlightsCode.Length != 0)
  1115. {
  1116. Res_AirCompany _AirCompany = _sqlSugar.Queryable<Res_AirCompany>().First(a => a.ShortCode == FlightsCode[0].Substring(0, 2));
  1117. if (_AirCompany != null)
  1118. {
  1119. if (!transDic.ContainsKey(_AirCompany.CnName))
  1120. {
  1121. transDic.Add(_AirCompany.CnName, _AirCompany.EnName);
  1122. }
  1123. }
  1124. else
  1125. {
  1126. if (!transDic.ContainsKey("--"))
  1127. {
  1128. transDic.Add("--", "--");
  1129. }
  1130. }
  1131. }
  1132. string[] nameArray = Regex.Split(item.ClientName, "\\d+\\.", RegexOptions.IgnoreCase);
  1133. nameArray = nameArray.Where(str => str != "" && str != " " && !string.IsNullOrEmpty(str)).ToArray();
  1134. string name = "";
  1135. foreach (string clientName in nameArray)
  1136. {
  1137. name += clientName + ",";
  1138. }
  1139. if (!texts.Contains(name))
  1140. {
  1141. texts.Add(name);
  1142. }
  1143. List<AirInfo> airs = new List<AirInfo>();
  1144. string[] DayArray = Regex.Split(item.FlightsDescription, "\\d+\\.", RegexOptions.IgnoreCase);
  1145. DayArray = DayArray.Where(s => s != " " && s != "" && !string.IsNullOrEmpty(s)).ToArray();
  1146. for (int i = 0; i < FlightsCode.Length; i++)
  1147. {
  1148. AirInfo air = new AirInfo();
  1149. string[] tempstr = DayArray[i]
  1150. .Replace("\r\n", string.Empty)
  1151. .Replace("\\r\\n", string.Empty)
  1152. .TrimStart().TrimEnd()
  1153. .Split(new char[] { ' ' }, StringSplitOptions.RemoveEmptyEntries);
  1154. Res_ThreeCode star_Three = _sqlSugar.Queryable<Res_ThreeCode>().First(a => a.Three == tempstr[3].Substring(0, 3));
  1155. if (star_Three != null)
  1156. {
  1157. if (!transDic.ContainsKey(star_Three.AirPort))
  1158. {
  1159. transDic.Add(star_Three.AirPort, star_Three.AirPort_En);
  1160. }
  1161. }
  1162. Res_ThreeCode End_Three = _sqlSugar.Queryable<Res_ThreeCode>().First(a => a.Three == tempstr[3].Substring(3, 3));
  1163. if (End_Three != null)
  1164. {
  1165. if (!transDic.ContainsKey(End_Three.AirPort))
  1166. {
  1167. transDic.Add(End_Three.AirPort, End_Three.AirPort_En);
  1168. }
  1169. }
  1170. if (!texts.Contains(item.CTypeName))
  1171. {
  1172. texts.Add(item.CTypeName);
  1173. }
  1174. }
  1175. }
  1176. List<TranslateResult> transData = _airTicketResRep.ReTransBatch(texts, "en");
  1177. if (transData.Count > 0)
  1178. {
  1179. foreach (TranslateResult item in transData)
  1180. {
  1181. if (!transDic.ContainsKey(item.Query))
  1182. {
  1183. transDic.Add(item.Query, item.Translation);
  1184. }
  1185. }
  1186. }
  1187. foreach (var item in _AirTicketReservations)
  1188. {
  1189. #region 处理固定数据
  1190. string[] FlightsCode = item.FlightsCode.Split('/');
  1191. if (FlightsCode.Length != 0)
  1192. {
  1193. Res_AirCompany _AirCompany = _sqlSugar.Queryable<Res_AirCompany>().First(a => a.ShortCode == FlightsCode[0].Substring(0, 2));
  1194. if (_AirCompany != null)
  1195. {
  1196. string str = "--";
  1197. string translateResult = transDic.Where(s => s.Key == _AirCompany.CnName).FirstOrDefault().Value;
  1198. if (!string.IsNullOrEmpty(translateResult))
  1199. {
  1200. str = translateResult;
  1201. str = _airTicketResRep.Processing(str);
  1202. }
  1203. table.Range.Bookmarks["AirlineCompany"].Text = str;
  1204. }
  1205. else
  1206. {
  1207. table.Range.Bookmarks["AirlineCompany"].Text = "--";
  1208. }
  1209. }
  1210. table.Range.Bookmarks["AirlineRecordCode"].Text = "--";
  1211. table.Range.Bookmarks["ReservationRecordCode"].Text = "--";
  1212. string[] nameArray = Regex.Split(item.ClientName, "\\d+\\.", RegexOptions.IgnoreCase);
  1213. nameArray = nameArray.Where(str => str != "" && str != " " && !string.IsNullOrEmpty(str)).ToArray();
  1214. string names = "";
  1215. foreach (string clientName in nameArray)
  1216. {
  1217. names += clientName + ",";
  1218. }
  1219. if (!string.IsNullOrWhiteSpace(names))
  1220. {
  1221. string str = "--";
  1222. string translateResult = transDic.Where(s => s.Key == names).FirstOrDefault().Value;
  1223. if (!string.IsNullOrEmpty(translateResult))
  1224. {
  1225. str = translateResult;
  1226. str = _airTicketResRep.Processing(str);
  1227. }
  1228. table.Range.Bookmarks["ClientName"].Text = str;
  1229. }
  1230. else
  1231. {
  1232. table.Range.Bookmarks["ClientName"].Text = "--";
  1233. }
  1234. table.Range.Bookmarks["TicketNumber"].Text = "--";
  1235. table.Range.Bookmarks["IdentificationCode"].Text = "--";
  1236. table.Range.Bookmarks["JointTicket"].Text = "--";
  1237. table.Range.Bookmarks["TimeIssue"].Text = "--";
  1238. table.Range.Bookmarks["DrawingAgent"].Text = "--";
  1239. table.Range.Bookmarks["NavigationCode"].Text = "--";
  1240. table.Range.Bookmarks["AgentsAddress"].Text = "--";
  1241. table.Range.Bookmarks["AgentPhone"].Text = "--";
  1242. table.Range.Bookmarks["AgentFacsimile"].Text = "--";
  1243. #endregion
  1244. #region 循环数据处理
  1245. List<AirInfo> airs = new List<AirInfo>();
  1246. string[] DayArray = Regex.Split(item.FlightsDescription, "\\d+\\.", RegexOptions.IgnoreCase);
  1247. DayArray = DayArray.Where(s => s != " " && s != "" && !string.IsNullOrEmpty(s)).ToArray();
  1248. for (int i = 0; i < FlightsCode.Length; i++)
  1249. {
  1250. AirInfo air = new AirInfo();
  1251. string[] tempstr = DayArray[i]
  1252. .Replace("\r\n", string.Empty)
  1253. .Replace("\\r\\n", string.Empty)
  1254. .TrimStart().TrimEnd()
  1255. .Split(new char[] { ' ' }, StringSplitOptions.RemoveEmptyEntries);
  1256. Res_ThreeCode star_Three = _sqlSugar.Queryable<Res_ThreeCode>().First(a => a.Three == tempstr[3].Substring(0, 3));
  1257. string starCity = "";
  1258. if (star_Three != null)
  1259. {
  1260. string str2 = "--";
  1261. string translateResult2 = transDic.Where(s => s.Key == star_Three.AirPort).FirstOrDefault().Value;
  1262. if (!string.IsNullOrEmpty(translateResult2))
  1263. {
  1264. str2 = translateResult2;
  1265. str2 = _airTicketResRep.Processing(str2);
  1266. }
  1267. starCity = str2;
  1268. }
  1269. Res_ThreeCode End_Three = _sqlSugar.Queryable<Res_ThreeCode>().First(a => a.Three == tempstr[3].Substring(3, 3));
  1270. string EndCity = "";
  1271. if (End_Three != null)
  1272. {
  1273. string str1 = "--";
  1274. string translateResult1 = transDic.Where(s => s.Key == End_Three.AirPort).FirstOrDefault().Value;
  1275. if (!string.IsNullOrEmpty(translateResult1))
  1276. {
  1277. str1 = translateResult1;
  1278. str1 = _airTicketResRep.Processing(str1);
  1279. }
  1280. EndCity = str1;
  1281. }
  1282. air.Destination = starCity + "/" + EndCity;
  1283. air.Flight = FlightsCode[i];
  1284. string str = "--";
  1285. string translateResult = transDic.Where(s => s.Key == item.CTypeName).FirstOrDefault().Value;
  1286. if (!string.IsNullOrEmpty(translateResult))
  1287. {
  1288. str = translateResult;
  1289. str = _airTicketResRep.Processing(str);
  1290. }
  1291. air.SeatingClass = str;
  1292. string dateTime = tempstr[2];
  1293. string DateTemp = dateTime.Substring(2, 5).ToUpper();
  1294. air.FlightDate = DateTemp;
  1295. air.DepartureTime = tempstr[5];
  1296. air.LandingTime = tempstr[6];
  1297. air.ValidityPeriod = DateTemp + "/" + DateTemp;
  1298. air.TicketStatus = "--";
  1299. air.Luggage = "--";
  1300. air.DepartureTerminal = "--";
  1301. air.LandingTerminal = "--";
  1302. airs.Add(air);
  1303. }
  1304. int row = 13;
  1305. for (int i = 0; i < airs.Count; i++)
  1306. {
  1307. if (airs.Count > 2)
  1308. {
  1309. for (int j = 0; j < airs.Count - 2; j++)
  1310. {
  1311. var CopyRow = table.Rows[12].Clone(true);
  1312. table.Rows.Add(CopyRow);
  1313. }
  1314. }
  1315. PropertyInfo[] properties = airs[i].GetType().GetProperties();
  1316. int index = 0;
  1317. foreach (PropertyInfo property in properties)
  1318. {
  1319. string value = property.GetValue(airs[i]).ToString();
  1320. Cell ishcel0 = table.Rows[row].Cells[index];
  1321. Paragraph p = new Paragraph(doc);
  1322. string s = value;
  1323. p.AppendChild(new Run(doc, s));
  1324. p.ParagraphFormat.Alignment = ParagraphAlignment.Center;//水平居中对齐
  1325. ishcel0.AppendChild(p);
  1326. ishcel0.CellFormat.VerticalAlignment = CellVerticalAlignment.Center;//垂直居中对齐
  1327. //ishcel0.CellFormat.VerticalAlignment=
  1328. index++;
  1329. }
  1330. row++;
  1331. }
  1332. #endregion
  1333. Paragraph lastParagraph = new Paragraph(doc);
  1334. //第一个表格末尾加段落
  1335. table.ParentNode.InsertAfter(lastParagraph, table);
  1336. //复制第一个表格
  1337. Table cloneTable = (Table)table.Clone(true);
  1338. //在文档末尾段落后面加入复制的表格
  1339. table.ParentNode.InsertAfter(cloneTable, lastParagraph);
  1340. if (item != _AirTicketReservations[_AirTicketReservations.Count - 1])
  1341. {
  1342. int rownewsIndex = 13;
  1343. for (int i = 0; i < 2; i++)
  1344. {
  1345. var CopyRow = table.Rows[12].Clone(true);
  1346. table.Rows.RemoveAt(13);
  1347. table.Rows.Add(CopyRow);
  1348. rownewsIndex++;
  1349. }
  1350. }
  1351. else
  1352. {
  1353. table.Rows.RemoveAt(12);
  1354. }
  1355. cloneTable.Rows.RemoveAt(12);
  1356. }
  1357. if (_AirTicketReservations.Count != 0)
  1358. {
  1359. string[] FlightsCode = _AirTicketReservations[0].FlightsCode.Split('/');
  1360. if (FlightsCode.Length != 0)
  1361. {
  1362. Res_AirCompany _AirCompany = _sqlSugar.Queryable<Res_AirCompany>().First(a => a.ShortCode == FlightsCode[0].Substring(0, 2));
  1363. if (_AirCompany != null)
  1364. {
  1365. string str = "--";
  1366. string translateResult = transDic.Where(s => s.Key == _AirCompany.CnName).FirstOrDefault().Value;
  1367. if (!string.IsNullOrEmpty(translateResult))
  1368. {
  1369. str = translateResult;
  1370. str = _airTicketResRep.Processing(str);
  1371. }
  1372. table.Range.Bookmarks["AirlineCompany"].Text = str;
  1373. }
  1374. else
  1375. {
  1376. table.Range.Bookmarks["AirlineCompany"].Text = "--";
  1377. }
  1378. }
  1379. table.Range.Bookmarks["AirlineRecordCode"].Text = "--";
  1380. table.Range.Bookmarks["ReservationRecordCode"].Text = "--";
  1381. string[] nameArray = Regex.Split(_AirTicketReservations[0].ClientName, "\\d+\\.", RegexOptions.IgnoreCase);
  1382. nameArray = nameArray.Where(str => str != "" && str != " " && !string.IsNullOrEmpty(str)).ToArray();
  1383. string names = "";
  1384. foreach (string clientName in nameArray)
  1385. {
  1386. names += clientName + ",";
  1387. }
  1388. if (!string.IsNullOrWhiteSpace(names))
  1389. {
  1390. string str = "--";
  1391. string translateResult = transDic.Where(s => s.Key == names).FirstOrDefault().Value;
  1392. if (!string.IsNullOrEmpty(translateResult))
  1393. {
  1394. str = translateResult;
  1395. str = _airTicketResRep.Processing(str);
  1396. }
  1397. table.Range.Bookmarks["ClientName"].Text = str;
  1398. }
  1399. else
  1400. {
  1401. table.Range.Bookmarks["ClientName"].Text = "--";
  1402. }
  1403. table.Range.Bookmarks["TicketNumber"].Text = "--";
  1404. table.Range.Bookmarks["IdentificationCode"].Text = "--";
  1405. table.Range.Bookmarks["JointTicket"].Text = "--";
  1406. table.Range.Bookmarks["TimeIssue"].Text = "--";
  1407. table.Range.Bookmarks["DrawingAgent"].Text = "--";
  1408. table.Range.Bookmarks["NavigationCode"].Text = "--";
  1409. table.Range.Bookmarks["AgentsAddress"].Text = "--";
  1410. table.Range.Bookmarks["AgentPhone"].Text = "--";
  1411. table.Range.Bookmarks["AgentFacsimile"].Text = "--";
  1412. }
  1413. doc.MailMerge.Execute(new[] { "PageCount" }, new object[] { doc.PageCount });
  1414. //保存合并后的文档
  1415. string fileName = "AirItinerary/电子客票英文行程单_EN.docx";
  1416. string rst = AppSettingsHelper.Get("WordBaseUrl") + AppSettingsHelper.Get("WordFtpPath") + fileName;
  1417. doc.Save(AppSettingsHelper.Get("WordBasePath") + fileName);
  1418. return Ok(JsonView(true, "成功!", rst));
  1419. }
  1420. }
  1421. }
  1422. catch (Exception ex)
  1423. {
  1424. return Ok(JsonView(false, "程序错误!"));
  1425. throw;
  1426. }
  1427. }
  1428. #endregion
  1429. #region 团组增减款项
  1430. /// <summary>
  1431. /// 团组增减款项下拉框绑定
  1432. /// </summary>
  1433. /// <param name="dto"></param>
  1434. /// <returns></returns>
  1435. [HttpPost]
  1436. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  1437. public async Task<IActionResult> DecreasePaymentsSelect(DecreasePaymentsDto dto)
  1438. {
  1439. try
  1440. {
  1441. Result groupData = await _decreasePaymentsRep.DecreasePaymentsSelect(dto);
  1442. if (groupData.Code != 0)
  1443. {
  1444. return Ok(JsonView(false, groupData.Msg));
  1445. }
  1446. return Ok(JsonView(true, groupData.Msg, groupData.Data));
  1447. }
  1448. catch (Exception ex)
  1449. {
  1450. return Ok(JsonView(false, "程序错误!"));
  1451. throw;
  1452. }
  1453. }
  1454. /// <summary>
  1455. /// 根据团组Id查询团组增减款项
  1456. /// </summary>
  1457. /// <param name="dto"></param>
  1458. /// <returns></returns>
  1459. [HttpPost]
  1460. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  1461. public async Task<IActionResult> DecreasePaymentsList(DecreasePaymentsListDto dto)
  1462. {
  1463. try
  1464. {
  1465. Result groupData = await _decreasePaymentsRep.DecreasePaymentsList(dto);
  1466. if (groupData.Code != 0)
  1467. {
  1468. return Ok(JsonView(false, groupData.Msg));
  1469. }
  1470. return Ok(JsonView(true, groupData.Msg, groupData.Data));
  1471. }
  1472. catch (Exception ex)
  1473. {
  1474. return Ok(JsonView(false, "程序错误!"));
  1475. throw;
  1476. }
  1477. }
  1478. /// <summary>
  1479. /// 团组增减款项操作(Status:1.新增,2.修改)
  1480. /// </summary>
  1481. /// <param name="dto"></param>
  1482. /// <returns></returns>
  1483. [HttpPost]
  1484. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  1485. public async Task<IActionResult> OpDecreasePayments(DecreasePaymentsOpDto dto)
  1486. {
  1487. try
  1488. {
  1489. Result groupData = await _decreasePaymentsRep.OpDecreasePayments(dto);
  1490. if (groupData.Code != 0)
  1491. {
  1492. return Ok(JsonView(false, groupData.Msg));
  1493. }
  1494. return Ok(JsonView(true, groupData.Msg, groupData.Data));
  1495. }
  1496. catch (Exception ex)
  1497. {
  1498. return Ok(JsonView(false, "程序错误!"));
  1499. throw;
  1500. }
  1501. }
  1502. /// <summary>
  1503. /// 团组增减款项操作 删除
  1504. /// </summary>
  1505. /// <param name="dto"></param>
  1506. /// <returns></returns>
  1507. [HttpPost]
  1508. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  1509. public async Task<IActionResult> DelDecreasePayments(DelBaseDto dto)
  1510. {
  1511. try
  1512. {
  1513. var res = await _decreasePaymentsRep.SoftDeleteByIdAsync<Grp_DecreasePayments>(dto.Id.ToString(), dto.DeleteUserId);
  1514. if (!res)
  1515. {
  1516. return Ok(JsonView(false, "删除失败"));
  1517. }
  1518. return Ok(JsonView(true, "删除成功!"));
  1519. }
  1520. catch (Exception ex)
  1521. {
  1522. return Ok(JsonView(false, "程序错误!"));
  1523. throw;
  1524. }
  1525. }
  1526. /// <summary>
  1527. /// 根据团组增减款项Id查询
  1528. /// </summary>
  1529. /// <param name="dto"></param>
  1530. /// <returns></returns>
  1531. [HttpPost]
  1532. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  1533. public async Task<IActionResult> QueryDecreasePaymentsById(DecreasePaymentsByIdDto dto)
  1534. {
  1535. try
  1536. {
  1537. Result groupData = await _decreasePaymentsRep.QueryDecreasePaymentsById(dto);
  1538. if (groupData.Code != 0)
  1539. {
  1540. return Ok(JsonView(false, groupData.Msg));
  1541. }
  1542. return Ok(JsonView(true, groupData.Msg, groupData.Data));
  1543. }
  1544. catch (Exception ex)
  1545. {
  1546. return Ok(JsonView(false, "程序错误!"));
  1547. throw;
  1548. }
  1549. }
  1550. #endregion
  1551. #region 文件上传、删除
  1552. /// <summary>
  1553. /// region 文件上传 可以带参数
  1554. /// </summary>
  1555. /// <param name="file"></param>
  1556. /// <returns></returns>
  1557. [HttpPost]
  1558. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  1559. public async Task<IActionResult> UploadProject(IFormFile file)
  1560. {
  1561. try
  1562. {
  1563. var TypeName = Request.Headers["TypeName"].ToString();
  1564. if (file != null)
  1565. {
  1566. var fileDir = AppSettingsHelper.Get("GrpFileBasePath");
  1567. //文件名称
  1568. string projectFileName = file.FileName;
  1569. //上传的文件的路径
  1570. string filePath = "";
  1571. if (TypeName == "A")//A代表团组增减款项
  1572. {
  1573. if (!Directory.Exists(fileDir))
  1574. {
  1575. Directory.CreateDirectory(fileDir);
  1576. }
  1577. //上传的文件的路径
  1578. filePath = fileDir + $@"\团组增减款项相关文件\{projectFileName}";
  1579. }
  1580. else if (TypeName == "B")//B代表商邀相关文件
  1581. {
  1582. if (!Directory.Exists(fileDir))
  1583. {
  1584. Directory.CreateDirectory(fileDir);
  1585. }
  1586. //上传的文件的路径
  1587. filePath = fileDir + $@"\商邀相关文件\{projectFileName}";
  1588. }
  1589. using (FileStream fs = System.IO.File.Create(filePath))
  1590. {
  1591. file.CopyTo(fs);
  1592. fs.Flush();
  1593. }
  1594. return Ok(JsonView(true, "上传成功!", projectFileName));
  1595. }
  1596. else
  1597. {
  1598. return Ok(JsonView(false, "上传失败!"));
  1599. }
  1600. }
  1601. catch (Exception ex)
  1602. {
  1603. return Ok(JsonView(false, "程序错误!"));
  1604. throw;
  1605. }
  1606. }
  1607. /// <summary>
  1608. /// 删除指定文件
  1609. /// </summary>
  1610. /// <param name="dto"></param>
  1611. /// <returns></returns>
  1612. [HttpPost]
  1613. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  1614. public async Task<IActionResult> DelFile(DelFileDto dto)
  1615. {
  1616. try
  1617. {
  1618. var TypeName = Request.Headers["TypeName"].ToString();
  1619. string filePath = "";
  1620. var fileDir = AppSettingsHelper.Get("GrpFileBasePath");
  1621. // 返回与指定虚拟路径相对应的物理路径即绝对路径
  1622. int id = 0;
  1623. if (TypeName == "A")
  1624. {
  1625. filePath = fileDir + "/团组增减款项相关文件/" + dto.fileName;
  1626. // 删除该文件
  1627. System.IO.File.Delete(filePath);
  1628. id = await _sqlSugar.Updateable<Grp_DecreasePayments>().Where(a => a.Id == dto.Id).SetColumns(a => new Grp_DecreasePayments { FilePath = "" }).ExecuteCommandAsync();
  1629. }
  1630. else if (TypeName == "B")
  1631. {
  1632. filePath = fileDir + "/商邀相关文件/" + dto.fileName;
  1633. // 删除该文件
  1634. System.IO.File.Delete(filePath);
  1635. id = await _sqlSugar.Updateable<Grp_InvitationOfficialActivities>().Where(a => a.Id == dto.Id).SetColumns(a => new Grp_InvitationOfficialActivities { Attachment = "" }).ExecuteCommandAsync();
  1636. }
  1637. if (id != 0)
  1638. {
  1639. return Ok(JsonView(true, "成功!"));
  1640. }
  1641. else
  1642. {
  1643. return Ok(JsonView(false, "失败!"));
  1644. }
  1645. }
  1646. catch (Exception ex)
  1647. {
  1648. return Ok(JsonView(false, "程序错误!"));
  1649. throw;
  1650. }
  1651. }
  1652. #endregion
  1653. #region 商邀费用录入
  1654. /// <summary>
  1655. /// 根据团组Id查询商邀费用列表
  1656. /// </summary>
  1657. /// <param name="dto"></param>
  1658. /// <returns></returns>
  1659. [HttpPost]
  1660. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  1661. public async Task<IActionResult> InvitationOfficialActivitiesList(InvitationOfficialActivitiesListDto dto)
  1662. {
  1663. try
  1664. {
  1665. Result groupData = await _InvitationOfficialActivitiesRep.InvitationOfficialActivitiesList(dto);
  1666. if (groupData.Code != 0)
  1667. {
  1668. return Ok(JsonView(false, groupData.Msg));
  1669. }
  1670. return Ok(JsonView(true, groupData.Msg, groupData.Data));
  1671. }
  1672. catch (Exception ex)
  1673. {
  1674. return Ok(JsonView(false, "程序错误!"));
  1675. throw;
  1676. }
  1677. }
  1678. /// <summary>
  1679. /// 根据商邀费用ID查询C表和商邀费用数据
  1680. /// </summary>
  1681. /// <param name="dto"></param>
  1682. /// <returns></returns>
  1683. [HttpPost]
  1684. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  1685. public async Task<IActionResult> InvitationOfficialActivitiesById(InvitationOfficialActivitiesByIdDto dto)
  1686. {
  1687. try
  1688. {
  1689. Result groupData = await _InvitationOfficialActivitiesRep.InvitationOfficialActivitiesById(dto);
  1690. if (groupData.Code != 0)
  1691. {
  1692. return Ok(JsonView(false, groupData.Msg));
  1693. }
  1694. return Ok(JsonView(true, groupData.Msg, groupData.Data));
  1695. }
  1696. catch (Exception ex)
  1697. {
  1698. return Ok(JsonView(false, "程序错误!"));
  1699. throw;
  1700. }
  1701. }
  1702. /// <summary>
  1703. /// 商邀费用录入操作(Status:1.新增,2.修改)
  1704. /// </summary>
  1705. /// <param name="dto"></param>
  1706. /// <returns></returns>
  1707. [HttpPost]
  1708. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  1709. public async Task<IActionResult> OpInvitationOfficialActivities(OpInvitationOfficialActivitiesDto dto)
  1710. {
  1711. try
  1712. {
  1713. Result groupData = await _InvitationOfficialActivitiesRep.OpInvitationOfficialActivities(dto);
  1714. if (groupData.Code != 0)
  1715. {
  1716. return Ok(JsonView(false, groupData.Msg));
  1717. }
  1718. return Ok(JsonView(true, groupData.Msg, groupData.Data));
  1719. }
  1720. catch (Exception ex)
  1721. {
  1722. return Ok(JsonView(false, "程序错误!"));
  1723. throw;
  1724. }
  1725. }
  1726. /// <summary>
  1727. /// 商邀删除
  1728. /// </summary>
  1729. /// <param name="dto"></param>
  1730. /// <returns></returns>
  1731. [HttpPost]
  1732. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  1733. public async Task<IActionResult> DelInvitationOfficialActivities(DelBaseDto dto)
  1734. {
  1735. try
  1736. {
  1737. var res = await _InvitationOfficialActivitiesRep.SoftDeleteByIdAsync<Grp_InvitationOfficialActivities>(dto.Id.ToString(), dto.DeleteUserId);
  1738. if (!res)
  1739. {
  1740. return Ok(JsonView(false, "删除失败"));
  1741. }
  1742. return Ok(JsonView(true, "删除成功!"));
  1743. }
  1744. catch (Exception ex)
  1745. {
  1746. return Ok(JsonView(false, "程序错误!"));
  1747. throw;
  1748. }
  1749. }
  1750. #endregion
  1751. #region 团组英文资料
  1752. /// <summary>
  1753. /// 查询团组英文所有资料
  1754. /// </summary>
  1755. /// <param name="dto"></param>
  1756. /// <returns></returns>
  1757. [HttpPost]
  1758. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  1759. public async Task<IActionResult> QueryDelegationEnData(QueryDelegationEnDataDto dto)
  1760. {
  1761. try
  1762. {
  1763. Result groupData = await _delegationEnDataRep.QueryDelegationEnData(dto);
  1764. if (groupData.Code != 0)
  1765. {
  1766. return Ok(JsonView(false, groupData.Msg));
  1767. }
  1768. return Ok(JsonView(true, groupData.Msg, groupData.Data));
  1769. }
  1770. catch (Exception ex)
  1771. {
  1772. return Ok(JsonView(false, "程序错误!"));
  1773. throw;
  1774. }
  1775. }
  1776. /// <summary>
  1777. /// 团组英文资料操作(Status:1.新增,2.修改)
  1778. /// </summary>
  1779. /// <param name="dto"></param>
  1780. /// <returns></returns>
  1781. [HttpPost]
  1782. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  1783. public async Task<IActionResult> OpDelegationEnData(OpDelegationEnDataDto dto)
  1784. {
  1785. try
  1786. {
  1787. Result groupData = await _delegationEnDataRep.OpDelegationEnData(dto);
  1788. if (groupData.Code != 0)
  1789. {
  1790. return Ok(JsonView(false, groupData.Msg));
  1791. }
  1792. return Ok(JsonView(true, groupData.Msg, groupData.Data));
  1793. }
  1794. catch (Exception ex)
  1795. {
  1796. return Ok(JsonView(false, "程序错误!"));
  1797. throw;
  1798. }
  1799. }
  1800. /// <summary>
  1801. /// 团组英文资料Id查询数据
  1802. /// </summary>
  1803. /// <param name="dto"></param>
  1804. /// <returns></returns>
  1805. [HttpPost]
  1806. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  1807. public async Task<IActionResult> QueryDelegationEnDataById(QueryDelegationEnDataByIdDto dto)
  1808. {
  1809. try
  1810. {
  1811. Grp_DelegationEnData _DelegationEnData=await _sqlSugar.Queryable<Grp_DelegationEnData>().FirstAsync(it => it.Id==dto.Id && it.IsDel==0);
  1812. if (_DelegationEnData != null)
  1813. {
  1814. return Ok(JsonView(true, "查询成功!", _DelegationEnData));
  1815. }
  1816. return Ok(JsonView(true, "暂无数据!",_DelegationEnData));
  1817. }
  1818. catch (Exception ex)
  1819. {
  1820. return Ok(JsonView(false, "程序错误!"));
  1821. throw;
  1822. }
  1823. }
  1824. /// <summary>
  1825. /// 团组英文资料删除
  1826. /// </summary>
  1827. /// <param name="dto"></param>
  1828. /// <returns></returns>
  1829. [HttpPost]
  1830. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  1831. public async Task<IActionResult> DelDelegationEnData(DelBaseDto dto)
  1832. {
  1833. try
  1834. {
  1835. var res = await _delegationEnDataRep.SoftDeleteByIdAsync<Grp_DelegationEnData>(dto.Id.ToString(), dto.DeleteUserId);
  1836. if (!res)
  1837. {
  1838. return Ok(JsonView(false, "删除失败"));
  1839. }
  1840. return Ok(JsonView(true, "删除成功!"));
  1841. }
  1842. catch (Exception ex)
  1843. {
  1844. return Ok(JsonView(false, "程序错误!"));
  1845. throw;
  1846. }
  1847. }
  1848. #endregion
  1849. #region 导出邀请函
  1850. /// <summary>
  1851. /// 导出邀请函页面初始化
  1852. /// </summary>
  1853. /// <param name="dto"></param>
  1854. /// <returns></returns>
  1855. [HttpPost]
  1856. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  1857. public async Task<IActionResult> QueryinvitationLetter(DecreasePaymentsListDto dto)
  1858. {
  1859. try
  1860. {
  1861. List<Grp_DelegationInfo> grp_Delegations = await _sqlSugar.Queryable<Grp_DelegationInfo>().Where(a => a.IsDel==0).OrderBy(a=>a.Id,OrderByType.Desc).ToListAsync();
  1862. List<Crm_DeleClient> crm_Deles = new List<Crm_DeleClient>();
  1863. if (dto.DiId==0)
  1864. {
  1865. crm_Deles = await _sqlSugar.Queryable<Crm_DeleClient>().Where(a => a.DiId==grp_Delegations[0].Id && a.IsDel==0).ToListAsync();
  1866. }
  1867. else
  1868. {
  1869. crm_Deles = await _sqlSugar.Queryable<Crm_DeleClient>().Where(a => a.DiId==dto.DiId && a.IsDel==0).ToListAsync();
  1870. }
  1871. return Ok(JsonView(true, "查询成功!",new
  1872. {
  1873. deleClient = crm_Deles,
  1874. delegations= grp_Delegations
  1875. }));
  1876. }
  1877. catch (Exception ex)
  1878. {
  1879. return Ok(JsonView(false, "程序错误!"));
  1880. throw;
  1881. }
  1882. }
  1883. /// <summary>
  1884. /// 导出邀请函
  1885. /// </summary>
  1886. /// <param name="dto"></param>
  1887. /// <returns></returns>
  1888. [HttpPost]
  1889. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  1890. public async Task<IActionResult> invitationLetter(DecreasePaymentsListDto dto)
  1891. {
  1892. try
  1893. {
  1894. Dictionary<string, string> transDic = new Dictionary<string, string>();
  1895. List<Crm_DeleClient> crm_DeleClients = await _sqlSugar.Queryable<Crm_DeleClient>().Where(a => a.DiId==dto.DiId && a.IsDel==0).ToListAsync();
  1896. List<string> texts = new List<string>();
  1897. if (crm_DeleClients.Count!=0)
  1898. {
  1899. foreach (Crm_DeleClient item in crm_DeleClients)
  1900. {
  1901. if (!string.IsNullOrWhiteSpace(item.Pinyin))
  1902. {
  1903. transDic.Add(item.LastName+item.FirstName, item.Pinyin);
  1904. }
  1905. else
  1906. {
  1907. string name = item.LastName + item.FirstName;
  1908. texts.Add(name);
  1909. }
  1910. if (!string.IsNullOrEmpty(item.Job) && !texts.Contains(item.Job))
  1911. {
  1912. if (!transDic.ContainsKey(item.Job))
  1913. {
  1914. texts.Add(item.Job);
  1915. }
  1916. }
  1917. if (item.CrmCompanyId!=0)
  1918. {
  1919. Crm_CustomerCompany crm_Customer = await _sqlSugar.Queryable<Crm_CustomerCompany>().FirstAsync(a => a.Id==item.CrmCompanyId && a.IsDel==0);
  1920. if (!transDic.ContainsKey(crm_Customer.CompanyName))
  1921. {
  1922. texts.Add(crm_Customer.CompanyName);
  1923. }
  1924. }
  1925. }
  1926. List<TranslateResult> transData = _airTicketResRep.ReTransBatch(texts, "en");
  1927. if (transData.Count > 0)
  1928. {
  1929. foreach (TranslateResult item in transData)
  1930. {
  1931. if (!transDic.ContainsKey(item.Query))
  1932. {
  1933. transDic.Add(item.Query, item.Translation);
  1934. }
  1935. }
  1936. }
  1937. List<guestList> list = new List<guestList>();
  1938. foreach (Crm_DeleClient dele in crm_DeleClients)
  1939. {
  1940. guestList guestList = new guestList();
  1941. if (!string.IsNullOrWhiteSpace(dele.Pinyin))
  1942. {
  1943. guestList.Name = dele.Pinyin;
  1944. }
  1945. else
  1946. {
  1947. string Name = transDic.Where(s => s.Key == dele.LastName + dele.FirstName).FirstOrDefault().Value;
  1948. guestList.Name = Name;
  1949. }
  1950. if (dele.Sex ==0)
  1951. {
  1952. guestList.Sex = "Male";
  1953. }
  1954. else if (dele.Sex == 1)
  1955. {
  1956. guestList.Sex = "Female";
  1957. }
  1958. guestList.DOB = dele.BirthDay.Replace('-', '.');
  1959. Crm_CustomerCompany crm_Customer = await _sqlSugar.Queryable<Crm_CustomerCompany>().FirstAsync(a => a.Id==dele.CrmCompanyId && a.IsDel==0);
  1960. string jobName = transDic.Where(s => s.Key == crm_Customer.CompanyName).FirstOrDefault().Value + " "+transDic.Where(s => s.Key == dele.Job).FirstOrDefault().Value;
  1961. guestList.Job = jobName;
  1962. list.Add(guestList);
  1963. }
  1964. //载入模板
  1965. Document doc = new Document(AppSettingsHelper.Get("WordBasePath") + "Template/邀请函模板0210.docx");
  1966. DocumentBuilder builder = new DocumentBuilder(doc);
  1967. //获取word里所有表格
  1968. NodeCollection allTables = doc.GetChildNodes(NodeType.Table, true);
  1969. //获取所填表格的序数
  1970. Aspose.Words.Tables.Table tableOne = allTables[0] as Aspose.Words.Tables.Table;
  1971. var rowStart = tableOne.Rows[0]; //获取第1行
  1972. //循环赋值
  1973. for (int i = 0; i < list.Count; i++)
  1974. {
  1975. builder.MoveToCell(0, i + 1, 0, 0);
  1976. builder.Write(list[i].Name.ToString());
  1977. builder.MoveToCell(0, i + 1, 1, 0);
  1978. builder.Write(list[i].Sex.ToString());
  1979. builder.MoveToCell(0, i + 1, 2, 0);
  1980. builder.Write(list[i].DOB.ToString());
  1981. builder.MoveToCell(0, i + 1, 3, 0);
  1982. builder.Write(list[i].Job.ToString());
  1983. }
  1984. //删除多余行
  1985. while (tableOne.Rows.Count > list.Count + 1)
  1986. {
  1987. tableOne.Rows.RemoveAt(list.Count + 1);
  1988. }
  1989. var fileDir = AppSettingsHelper.Get("GrpFileBasePath");
  1990. string fileName = "邀请函"+DateTime.Now.ToString("yyyy-MM-dd")+".docx";
  1991. string filePath = fileDir + $@"商邀相关文件/{fileName}";
  1992. doc.Save(filePath);
  1993. string Url= AppSettingsHelper.Get("WordBaseUrl") + "Office/GrpFile/商邀相关文件"+fileName;
  1994. return Ok(JsonView(true, "成功!", Url));
  1995. }
  1996. else
  1997. {
  1998. return Ok(JsonView(false, "失败,该团组没有客户名单!"));
  1999. }
  2000. }
  2001. catch (Exception ex)
  2002. {
  2003. return Ok(JsonView(false, "程序错误!"));
  2004. throw;
  2005. }
  2006. }
  2007. #endregion
  2008. }
  2009. }