| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271 | 
							- using AutoMapper;
 
- using MathNet.Numerics.Statistics.Mcmc;
 
- using NPOI.SS.Formula.Functions;
 
- using OASystem.Domain;
 
- using OASystem.Domain.Dtos.Financial;
 
- using OASystem.Domain.Dtos.Groups;
 
- using OASystem.Domain.Entities.Financial;
 
- using OASystem.Domain.ViewModels.Financial;
 
- using OASystem.Infrastructure.Repositories.Groups;
 
- using OASystem.Infrastructure.Repositories.System;
 
- using SqlSugar;
 
- using System;
 
- using System.Collections.Generic;
 
- using System.Linq;
 
- using System.Text;
 
- using System.Threading.Tasks;
 
- namespace OASystem.Infrastructure.Repositories.Financial
 
- {
 
-     /// <summary>
 
-     /// 财务 - 团组应收款项 仓库
 
-     /// 雷怡 2023.08.16 15:03
 
-     /// </summary>
 
-     public class ForeignReceivablesRepository : BaseRepository<Fin_ForeignReceivables, Fin_ForeignReceivablesView>
 
-     {
 
-         private readonly IMapper _mapper;
 
-         private readonly DelegationInfoRepository _delegationRep;
 
-         private readonly SetDataRepository _setDataRep;
 
-         
 
-         public ForeignReceivablesRepository(SqlSugarClient sqlSugar, IMapper mapper, DelegationInfoRepository delegationRep, SetDataRepository setDataRep)
 
-             : base(sqlSugar)
 
-         {
 
-             _mapper = mapper;
 
-             _delegationRep = delegationRep;
 
-             _setDataRep = setDataRep;
 
-         }
 
-         /// <summary>
 
-         /// 收款账单 数据源
 
-         /// </summary>
 
-         /// <returns></returns>
 
-         public async Task<Result> GetDataSource()
 
-         {
 
-             Result result = new() { Code = -2 };
 
-             var groupNameData = await _delegationRep.GetGroupNameList(new GroupNameDto());
 
-             var currencyData = await _setDataRep.GetSetDataBySTId(_setDataRep,66); //币种
 
-             var remittanceMethodData = await _setDataRep.GetSetDataBySTId(_setDataRep, 14); //汇款方式
 
-             result.Code = 0;
 
-             result.Msg = "成功!";
 
-             result.Data = new {
 
-                 GroupNameData= groupNameData.Data,
 
-                 CurrencyData = currencyData.Data,
 
-                 RemittanceMethodData = remittanceMethodData.Data
 
-             };
 
-             return result;
 
-         }
 
-         /// <summary>
 
-         /// 根据diid查询团组应收款项
 
-         /// </summary>
 
-         /// <param name="diid"></param>
 
-         /// <returns></returns>
 
-         public async Task<Result> GetGroupReceivablesInfoByDiId(ForForeignReceivablesInfoDto dto)
 
-         {
 
-             Result result = new() { Code = -2 };
 
-             var groupInfoData = await _delegationRep.GetGroupInfo(new GroupInfoDto() { Id = dto.DiId });
 
-             //应收款项
 
-             string groupReceivedSql = string.Format(@"Select * From Fin_ForeignReceivables Where IsDel=0 And Diid={0}", dto.DiId);
 
-             var groupReceivedList = await _sqlSugar.SqlQueryable<ForeignReceivablesView>(groupReceivedSql).ToListAsync();
 
-             //已收款项
 
-             string groupProceedsReceivedSql = string.Format(@"Select * From Fin_ProceedsReceived Where IsDel=0 And Diid={0}", dto.DiId);
 
-             var groupProceedsReceivedList = await _sqlSugar.SqlQueryable<ProceedsReceivedView>(groupProceedsReceivedSql).ToListAsync();
 
-             List<ProceedsReceivedView> NotFIDData = new List<ProceedsReceivedView>();
 
-             if (dto.PortType == 1 )
 
-             {
 
-                 foreach (var item in groupReceivedList)
 
-                 {
 
-                     item._ProceedsReceivedDatas = groupProceedsReceivedList.Where(s => s.FID == item.Id).ToList();
 
-                 }
 
-                 NotFIDData = groupProceedsReceivedList.Where(s =>! groupReceivedList.Any(e => s.FID == e.Id)).ToList();
 
-             }
 
-             result.Code = 0;
 
-             result.Msg = "查询成功!";
 
-             result.Data = new
 
-             {
 
-                 GroupInfo = groupInfoData.Data,
 
-                 GroupCollectionStatementData = new
 
-                 {
 
-                     ReceivedData = groupReceivedList,
 
-                     UnallocatedData = NotFIDData
 
-                 }
 
-             };
 
-             return result;
 
-         }
 
-         /// <summary>
 
-         /// 应收款项 删除
 
-         /// </summary>
 
-         /// <param name="dto"></param>
 
-         /// <returns></returns>
 
-         public async Task<Result> _Del(DelForForeignReceivablesInfoDto dto)
 
-         {
 
-             Result result = new Result() { Code = -1, Msg = "程序错误!" };
 
-             _sqlSugar.BeginTran();
 
-             try
 
-             {
 
-                 var res = await _sqlSugar.Updateable<Fin_ForeignReceivables>()
 
-                 .Where(it => it.Id == dto.Id)
 
-                 .SetColumns(it => new Fin_ForeignReceivables()
 
-                 {
 
-                     IsDel = 1,
 
-                     DeleteUserId = dto.UserId,
 
-                     DeleteTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")
 
-                 }
 
-                 ).ExecuteCommandAsync();
 
-                 if (res > 0)
 
-                 {
 
-                     await _sqlSugar.Updateable<Fin_ProceedsReceived>()
 
-                                       .Where(a => a.FID == dto.Id)
 
-                                       .SetColumns(a => new Fin_ProceedsReceived
 
-                                       {
 
-                                           IsDel = 1,
 
-                                           DeleteUserId = dto.UserId,
 
-                                           DeleteTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
 
-                                       }).ExecuteCommandAsync();
 
-                     _sqlSugar.CommitTran();
 
-                     result.Msg = "删除成功!";
 
-                     result.Code = 0;
 
-                 }
 
-                 else
 
-                 {
 
-                     _sqlSugar.RollbackTran();
 
-                     result.Msg = "删除失败!";
 
-                     return result;
 
-                 }
 
-             }
 
-             catch (Exception ex)
 
-             {
 
-                 _sqlSugar.RollbackTran();
 
-                 result.Msg= ex.Message;
 
-                 return result;
 
-             }
 
-             
 
-             return result;
 
-         }
 
-         /// <summary>
 
-         /// 财务模块
 
-         /// 收款账单 Add And Update
 
-         /// </summary>
 
-         /// <param name="diid"></param>
 
-         /// <returns></returns>
 
-         public async Task<Result> PostReceivablesOperate(ForeignReceivablesAddAndUpdateDto dto)
 
-         {
 
-             Result result = new() { Code = -2 };
 
-             if (dto.foreignReceivablesInfos.Count <= 0)
 
-             {
 
-                 result.Msg = "收款账单没有信息,不能进行,添加或修改操作!!!";
 
-                 return result;
 
-             }
 
-             int addCount = 0, updateCount = 0;
 
-             if (dto.PortType == 1)
 
-             {
 
-                 List<Fin_ForeignReceivables> _ForeignReceivables = new List<Fin_ForeignReceivables>();
 
-                 foreach (var item in dto.foreignReceivablesInfos)
 
-                 {
 
-                     _ForeignReceivables.Add(new Fin_ForeignReceivables()
 
-                     {
 
-                         Diid = dto.DiId,
 
-                         Id = item.Id,
 
-                         PriceName = item.PriceName,
 
-                         Price = item.Price,
 
-                         Count = item.Count,
 
-                         Unit = item.Unit,
 
-                         ItemSumPrice = item.ItemSumPrice,
 
-                         Rate = item.Rate,
 
-                         Currency = item.Currency,
 
-                         AddingWay = item.AddingWay,
 
-                         CreateUserId = dto.UserId,
 
-                         CreateTime = DateTime.Now,
 
-                         Remark = item.Remark
 
-                     });
 
-                 }
 
-                 if (_ForeignReceivables.Count > 0)
 
-                 {
 
-                     var x =  _sqlSugar.Storageable(_ForeignReceivables).ToStorage();
 
-                     addCount = x.AsInsertable.ExecuteCommand();        //不存在插入
 
-                     updateCount = x.AsUpdateable.ExecuteCommand();    //存在更新
 
-                 }
 
-                 result.Code = 0;
 
-                 result.Msg = string.Format(@"操作成功!添加:{0}条;更新:{1};", addCount, updateCount);
 
-             }
 
-             return result;
 
-         }
 
-         /// <summary>
 
-         /// 根据diid查询团组应收款项
 
-         /// </summary>
 
-         /// <param name="diid"></param>
 
-         /// <returns></returns>
 
-         public async Task<Result> GetGroupReceivablesByDiid(int diid)
 
-         {
 
-             Result result = new() { Code = -2 };
 
-             string sql = string.Format(@"Select * From Fin_ForeignReceivables Where IsDel=0 And Diid={0}", diid);
 
-             var groupReceivedList = await _sqlSugar.SqlQueryable<Fin_ForeignReceivables>(sql).ToListAsync();
 
-             result.Code = 0;
 
-             result.Msg = "查询成功!";
 
-             result.Data = groupReceivedList;
 
-             return result;
 
-         }
 
-         /// <summary>
 
-         /// 根据diid 数组 查询团组应收款项
 
-         /// </summary>
 
-         /// <param name="diid"></param>
 
-         /// <returns></returns>
 
-         public async Task<Result> GetGroupReceivablesByDiids(int[] diids)
 
-         {
 
-             Result result = new() { Code = -2 };
 
-             //string sql = string.Format(@"Select * From Fin_ProceedsReceived Where IsDel=0 And Diid={0}", diids);
 
-             var groupReceivedList = await _sqlSugar.Queryable<Fin_ForeignReceivables>()
 
-                 .Where(pr =>  pr.IsDel == 0 && diids.Contains(pr.Diid)).ToListAsync();
 
-             result.Code = 0;
 
-             result.Msg = "查询成功!";
 
-             result.Data = groupReceivedList;
 
-             return result;
 
-         }
 
-        
 
-     }
 
- }
 
 
  |