ProceedsReceivedRepository.cs 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340
  1. using AutoMapper;
  2. using OASystem.Domain;
  3. using OASystem.Domain.Dtos.Financial;
  4. using OASystem.Domain.Entities.Financial;
  5. using OASystem.Domain.ViewModels.Financial;
  6. using System;
  7. using System.Collections.Generic;
  8. using System.Linq;
  9. using System.Text;
  10. using System.Threading.Tasks;
  11. namespace OASystem.Infrastructure.Repositories.Financial
  12. {
  13. /// <summary>
  14. /// 财务 - 团组已收款项
  15. /// 雷怡 2023.08.16 15:24
  16. /// </summary>
  17. public class ProceedsReceivedRepository:BaseRepository<Fin_ProceedsReceived,Fin_ProceedsReceivedView>
  18. {
  19. private readonly IMapper _mapper;
  20. /// <summary>
  21. ///
  22. /// </summary>
  23. /// <param name="sqlSugar"></param>
  24. /// <param name="mapper"></param>
  25. public ProceedsReceivedRepository(SqlSugarClient sqlSugar, IMapper mapper)
  26. : base(sqlSugar)
  27. {
  28. _mapper = mapper;
  29. }
  30. /// <summary>
  31. /// 根据diid查询团组已收款项 已关联应收款项
  32. /// </summary>
  33. /// <param name="diid"></param>
  34. /// <returns></returns>
  35. public async Task<Result> GetGroupReceivedByDiid(int diid)
  36. {
  37. Result result = new() { Code = -2 };
  38. string sql = string.Format(@"Select * From Fin_ProceedsReceived Where IsDel=0 And Diid={0}", diid);
  39. var groupReceivablesList = await _sqlSugar.SqlQueryable<Fin_ProceedsReceivedView>(sql).ToListAsync();
  40. result.Code = 0;
  41. result.Msg = "查询成功!";
  42. result.Data = groupReceivablesList;
  43. return result;
  44. }
  45. /// <summary>
  46. /// 根据diid 数组 查询团组已收款项 已关联应收款项
  47. /// </summary>
  48. /// <param name="diid"></param>
  49. /// <returns></returns>
  50. public async Task<Result> GetGroupReceivedByDiids(int[] diids)
  51. {
  52. Result result = new() { Code = -2 };
  53. var groupReceivablesList = await _sqlSugar.Queryable<Fin_ProceedsReceived>()
  54. .Where(fr => fr.IsDel == 0 && diids.Contains(fr.Diid)) .ToListAsync();
  55. result.Code = 0;
  56. result.Msg = "查询成功!";
  57. result.Data = groupReceivablesList;
  58. return result;
  59. }
  60. /// <summary>
  61. /// 已收款项 已关联应收款项 删除
  62. /// </summary>
  63. /// <param name="dto"></param>
  64. /// <returns></returns>
  65. public async Task<Result> _Del(ProceedsReceivedDelDto dto)
  66. {
  67. Result result = new Result() { Code = -1, Msg = "程序错误!" };
  68. var res = await _sqlSugar.Updateable<Fin_ProceedsReceived>()
  69. .Where(it => it.Id == dto.Id)
  70. .SetColumns(it => new Fin_ProceedsReceived()
  71. {
  72. IsDel = 1,
  73. DeleteUserId = dto.UserId,
  74. DeleteTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")
  75. }
  76. ).ExecuteCommandAsync();
  77. if (res > 0)
  78. {
  79. result.Msg = "删除成功!";
  80. result.Code = 0;
  81. }
  82. else
  83. {
  84. result.Msg = "删除失败!";
  85. }
  86. return result;
  87. }
  88. /// <summary>
  89. /// 已收款项 已关联应收款项
  90. /// Add And Update
  91. /// </summary>
  92. /// <param name="diid"></param>
  93. /// <returns></returns>
  94. public async Task<Result> PostAmountReceivedOperate(ProceedsReceivedDto dto)
  95. {
  96. Result result = new() { Code = -2 };
  97. if (dto._ProceedsReceivedInfos.Count <= 0)
  98. {
  99. result.Msg = "已收款项没有信息,不能进行,添加或修改操作!!!";
  100. return result;
  101. }
  102. int addCount = 0, updateCount = 0;
  103. if (dto.PortType == 1)
  104. {
  105. List<Fin_ProceedsReceived> _ProceedsReceived = new List<Fin_ProceedsReceived>();
  106. foreach (var item in dto._ProceedsReceivedInfos)
  107. {
  108. _ProceedsReceived.Add(new Fin_ProceedsReceived()
  109. {
  110. Diid = dto.DiId,
  111. Id = item.Id,
  112. SectionTime = item.SectionTime,
  113. Price = item.Price,
  114. Currency = item.Currency,
  115. ReceivablesType = item.ReceivablesType,
  116. Client = item.Client,
  117. CustomerName = item.CustomerName,
  118. CustomerTel = item.CustomerTel,
  119. FID = item.FID,
  120. CreateUserId = dto.UserId,
  121. CreateTime = DateTime.Now,
  122. Remark = item.Remark
  123. });
  124. }
  125. if (_ProceedsReceived.Count > 0)
  126. {
  127. var x = _sqlSugar.Storageable(_ProceedsReceived).ToStorage();
  128. addCount = x.AsInsertable.ExecuteCommand(); //不存在插入
  129. updateCount = x.AsUpdateable.ExecuteCommand(); //存在更新
  130. }
  131. result.Code = 0;
  132. result.Msg = string.Format(@"操作成功!添加:{0}条;更新:{1};", addCount, updateCount);
  133. }
  134. return result;
  135. }
  136. /// <summary>
  137. /// 已收款项 已关联应收款项
  138. /// 分配已收款项至 应收项下
  139. /// </summary>
  140. /// <param name="diid"></param>
  141. /// <returns></returns>
  142. public async Task<Result> PostAllocateAmountReceived(AllocateAmountReceivedDto dto)
  143. {
  144. Result result = new() { Code = -2 };
  145. if (dto.SubIds.Count <= 0)
  146. {
  147. result.Msg = "请选择要添加的已收款项!";
  148. return result;
  149. }
  150. if (dto.PortType == 1)
  151. {
  152. List<Fin_ProceedsReceived> _proceedsReceived = new List<Fin_ProceedsReceived>();
  153. foreach (var id in dto.SubIds)
  154. {
  155. _proceedsReceived.Add(new Fin_ProceedsReceived() { Id = id, FID = dto.ParentId });
  156. }
  157. var res = await _sqlSugar.Updateable(_proceedsReceived).
  158. WhereColumns(it => new { it.Id })
  159. .UpdateColumns(it => new { it.FID })
  160. .ExecuteCommandAsync();
  161. result.Code = 0;
  162. }
  163. return result;
  164. }
  165. /// <summary>
  166. /// 根据diid查询团组已收款项
  167. /// 全字段
  168. /// </summary>
  169. /// <param name="diid"></param>
  170. /// <returns></returns>
  171. public async Task<Result> PostAmountReceivedByDiId(int diId)
  172. {
  173. Result result = new() { Code = -2 };
  174. string sql = string.Format(@"Select * From Fin_ProceedsReceived Where IsDel=0 And Diid={0}", diId);
  175. var groupReceivablesList = await _sqlSugar.SqlQueryable<Fin_ProceedsReceivedView>(sql).ToListAsync();
  176. result.Code = 0;
  177. result.Msg = "查询成功!";
  178. result.Data = groupReceivablesList;
  179. return result;
  180. }
  181. /// <summary>
  182. /// 根据diid查询团组已收款项
  183. /// </summary>
  184. /// <param name="diid"></param>
  185. /// <returns></returns>
  186. public async Task<Result> PostAmountReceived(int diid)
  187. {
  188. Result result = new() { Code = -2 };
  189. string sql = string.Format(@"Select Id,Diid,SectionTime,Price,Currency,ReceivablesType,Client,CustomerName,CustomerTel, Remark From Fin_ProceedsReceived
  190. Where IsDel=0 And Diid={0}", diid);
  191. var groupReceivablesList = await _sqlSugar.SqlQueryable<ProceedsReceived1View>(sql).ToListAsync();
  192. result.Code = 0;
  193. result.Msg = "查询成功!";
  194. result.Data = groupReceivablesList;
  195. return result;
  196. }
  197. /// <summary>
  198. /// 已收款项
  199. /// Add And Update
  200. /// </summary>
  201. /// <param name="diid"></param>
  202. /// <returns></returns>
  203. public async Task<Result> PostAmountReceivedAddOrEditDto(AmountReceivedAddOrEditDto dto)
  204. {
  205. Result result = new() { Code = -2 };
  206. if (dto._ProceedsReceivedInfos.Count <= 0)
  207. {
  208. result.Msg = "已收款项没有信息,不能进行,添加或修改操作!!!";
  209. return result;
  210. }
  211. int addCount = 0, updateCount = 0;
  212. if (dto.PortType == 1)
  213. {
  214. List<Fin_ProceedsReceived> _ProceedsReceived = new List<Fin_ProceedsReceived>();
  215. foreach (var item in dto._ProceedsReceivedInfos)
  216. {
  217. _ProceedsReceived.Add(new Fin_ProceedsReceived()
  218. {
  219. Diid = dto.DiId,
  220. Id = item.Id,
  221. SectionTime = item.SectionTime,
  222. Price = item.Price,
  223. Currency = item.Currency,
  224. ReceivablesType = item.ReceivablesType,
  225. Client = item.Client,
  226. CustomerName = item.CustomerName,
  227. CustomerTel = item.CustomerTel,
  228. FID = 0,
  229. CreateUserId = dto.UserId,
  230. CreateTime = DateTime.Now,
  231. Remark = item.Remark
  232. });
  233. }
  234. if (_ProceedsReceived.Count > 0)
  235. {
  236. var x = _sqlSugar.Storageable(_ProceedsReceived).ToStorage();
  237. addCount = x.AsInsertable.ExecuteCommand(); //不存在插入
  238. updateCount = x.AsUpdateable.IgnoreColumns(p => new
  239. {
  240. p.SectionTime,
  241. p.Price,
  242. p.Currency,
  243. p.ReceivablesType,
  244. p.Client,
  245. p.CustomerName,
  246. p.CustomerTel,
  247. p.Remark
  248. }).ExecuteCommand(); //存在更新
  249. }
  250. result.Code = 0;
  251. result.Msg = string.Format(@"操作成功!添加:{0}条;更新:{1};", addCount, updateCount);
  252. }
  253. return result;
  254. }
  255. /// <summary>
  256. /// 已收款项 删除
  257. /// </summary>
  258. /// <param name="dto"></param>
  259. /// <returns></returns>
  260. public async Task<Result> PostAmountReceivedDel(AmountReceivedDelDto dto)
  261. {
  262. Result result = new Result() { Code = -1, Msg = "程序错误!" };
  263. var res = await _sqlSugar.Updateable<Fin_ProceedsReceived>()
  264. .Where(it => it.Id == dto.Id)
  265. .SetColumns(it => new Fin_ProceedsReceived()
  266. {
  267. IsDel = 1,
  268. DeleteUserId = dto.UserId,
  269. DeleteTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")
  270. }
  271. ).ExecuteCommandAsync();
  272. if (res > 0)
  273. {
  274. result.Msg = "删除成功!";
  275. result.Code = 0;
  276. }
  277. else
  278. {
  279. result.Msg = "删除失败!";
  280. }
  281. return result;
  282. }
  283. }
  284. }