| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263 | using OASystem.Domain.Dtos.Financial;using OASystem.Domain.Entities.Financial;using OASystem.Domain.Entities.Groups;using OASystem.Domain.ViewModels.Financial;using OASystem.Domain.ViewModels.Groups;using OASystem.Infrastructure.Repositories.Financial;using OASystem.Infrastructure.Repositories.Groups;namespace OASystem.API.OAMethodLib{    /// <summary>    /// 团组提成    /// 雷怡 2023-08-14 16:04    /// </summary>    public static class GroupCommission    {        //团组信息        private readonly static DelegationInfoRepository _dirRep = AutofacIocManager.Instance.GetService<DelegationInfoRepository>();        //团组实付金额        private readonly static CreditCardPaymentRepository _ccpRep = AutofacIocManager.Instance.GetService<CreditCardPaymentRepository>();        //团组应收款项        private readonly static ForeignReceivablesRepository _frRep = AutofacIocManager.Instance.GetService<ForeignReceivablesRepository>();        //团组已收款项        private readonly static ProceedsReceivedRepository _prRep = AutofacIocManager.Instance.GetService<ProceedsReceivedRepository>();        //团组其他款项        private readonly static OtherPriceRepository _opRep = AutofacIocManager.Instance.GetService<OtherPriceRepository>();        /// <summary>        /// 获取团组提成 Page List        /// </summary>        public static async Task<Result> GetCommissionPageList(GroupCommissionDto dto)        {            Result result = new Result() { Code = -1 };            var groupResult = await _dirRep.GetGroupPageList(dto);            if (groupResult.Code != 0)            {                result.Code = groupResult.Code;                result.Msg = groupResult.Msg;                return result;            }            if (groupResult.Data == null) { }            // ListViewBase<DelegationPageListView> groupData = JsonConvert.DeserializeObject<ListViewBase<DelegationPageListView>>(groupResult.Data);            result.Data = groupResult.Data;            List<int> diids = new List<int>();            foreach (var item in result.Data.DataList)            {                diids.Add(item.Id);            }            await GetCommissionByDiids(diids.ToArray());            return result;        }        /// <summary>        /// 根据团组Id计算 团组利润        /// </summary>        /// <param name="DiId">团组Id</param>        public static async Task<Fin_GroupProfitInfoView> GetCommissionByDiid(int DiId)        {            int[] ints = new int[DiId];            decimal sumFr = 0.00M,  //团组 应收款项                    sumPr = 0.00M,  //团组 已收款项                    refund = 0.00M, //团组 退款和其他费用                    cost = 0.00M;   //团组 成本费用            if (DiId == 0) return new Fin_GroupProfitInfoView();            #region 计算各项费用            //应收款项            Result frData = await _frRep.GetGroupReceivablesByDiid(DiId);            if (frData.Code == 0 && frData.Data != null)            {                foreach (var item in frData.Data)                {                    sumFr += item.Price;                }            }            //已收款项            Result prData = await _prRep.GetGroupReceivedByDiid(DiId);            if (frData.Code == 0 && frData.Data != null)            {                foreach (var item in prData.Data)                {                    sumPr += item.Price;                }            }            //收款退还费用            Result ccpData = await _ccpRep.GetGroupRefundByDiid(DiId, true);            if (ccpData.Code == 0 && ccpData.Data != null)            {                foreach (var item in ccpData.Data)                {                    refund += item.Price;                }            }            //实际的团组类型已收金额需除去退款             sumPr = sumPr - refund;            //团组与非团组产生的成本费用数据            Result _ccpData = await _ccpRep.GetGroupPaymentInfoByDiid(DiId, true);            if (_ccpData.Code == 0 && _ccpData.Data != null)            {                foreach (Grp_Fin_CreditCardPaymentView item in _ccpData.Data)                {                    if (item.PayThenMoney != 0M)                        cost += item.PayThenMoney * item.DayRate;                    else                        cost += item.PayMoney * (item.PayPercentage * 0.01M) * item.DayRate;                }                //实际的团组成本需除去退款                 cost -= refund;            }            #endregion            //团组净利润=已收金额-成本            decimal groupProfit = sumPr - cost;            //团组尾款=应收款项-已收款项            decimal groupRatainage = sumPr - sumPr;            return new Fin_GroupProfitInfoView() { ReceivableFund = sumFr, ReceivedFund = sumPr, Refund = refund, Cost = cost, RetainedProfits = groupProfit, FinalPayment = groupRatainage };        }        /// <summary>        /// 根据团组 Ids 计算 团组利润        /// </summary>        /// <param name="DiIds"></param>        /// <returns></returns>        public static async Task<List<Fin_GroupProfitInfoView>> GetCommissionByDiids(int[] DiIds)        {            if (DiIds.Length <= 0) return new List<Fin_GroupProfitInfoView>();            List<Fin_GroupProfitInfoView> fin_GroupProfitInfoViews = new List<Fin_GroupProfitInfoView>();            #region string            //string _diidsStr = string.Empty;            //#region 处理Diid            //StringBuilder diidSb = new StringBuilder();            //for (int i = 0; i < DiIds.Length; i++)            //{            //    if (i == DiIds.Length - 1)            //    {            //        diidSb.Append(DiIds[i]);            //    }            //    else            //    {            //        diidSb.Append(DiIds[i]).Append(",");            //    }            //}            //_diidsStr = diidSb.ToString().Trim();            //#endregion            #endregion            #region 计算各项费用            //应收款项            Result frData = await _frRep.GetGroupReceivablesByDiids(DiIds);            //已收款项            Result prData = await _prRep.GetGroupReceivedByDiids(DiIds);            //收款退还费用            Result ccpData = await _ccpRep.GetGroupRefundByDiids(DiIds, true);            //团组与非团组产生的成本费用数据            Result ccpData1 = await _ccpRep.GetGroupPaymentInfoByDiids(DiIds, true);            foreach (int item in DiIds)            {                decimal sumFr = 0.00M,  //团组 应收款项                   sumPr = 0.00M,        //团组 已收款项                   refund = 0.00M,       //团组 退款和其他费用                   cost = 0.00M;         //团组 成本费用                //团组 应收款项                if (frData.Code == 0 && frData.Data != null)                {                    List<Fin_ForeignReceivables> _frData = JsonConvert.DeserializeObject<List<Fin_ForeignReceivables>>                        (JsonConvert.SerializeObject(frData.Data));                    _frData = _frData.Where(fr => item == fr.Diid).ToList();                    foreach (Fin_ForeignReceivables itemFr in _frData)                    {                        sumPr += itemFr.Price;                    }                }                //团组 已收款项                if (prData.Code == 0 && prData.Data != null)                {                    List<Fin_ProceedsReceived> _prData = JsonConvert.DeserializeObject<List<Fin_ProceedsReceived>>                        (JsonConvert.SerializeObject(prData.Data));                    _prData = _prData.Where(pr => item == pr.Diid).ToList();                    foreach (var itemPr in _prData)                    {                        sumFr += itemPr.Price;                    }                }                //团组 退款和其他费用                if (ccpData.Code == 0 && ccpData.Data != null)                {                    List<GroupRefundView> _ccpData = JsonConvert.DeserializeObject<List<GroupRefundView>>                        (JsonConvert.SerializeObject(ccpData.Data));                    _ccpData = _ccpData.Where(ccp => item == ccp.DIId).ToList();                    foreach (var itemCcp in _ccpData)                    {                        refund += itemCcp.Price;                    }                }                //实际的团组类型已收金额需除去退款                 sumPr = sumPr - refund;                if (ccpData1.Code == 0 && ccpData1.Data != null)                {                    List<Grp_CreditCardPayment> _ccpData1 = JsonConvert.DeserializeObject<List<Grp_CreditCardPayment>>                        (JsonConvert.SerializeObject(ccpData1.Data));                    _ccpData1 = _ccpData1.Where(ccp => item == ccp.DIId).ToList();                    foreach (Grp_CreditCardPayment itemCcp in _ccpData1)                    {                        if (itemCcp.PayThenMoney != 0M)                            cost += itemCcp.PayThenMoney * itemCcp.DayRate;                        else                            cost += itemCcp.PayMoney * (itemCcp.PayPercentage * 0.01M) * itemCcp.DayRate;                    }                    //实际的团组成本需除去退款                     cost -= refund;                }                #endregion                decimal groupProfit = 0.00M,    //团组净利润=已收金额-成本                    groupRatainage = 0.00M;     //团组尾款=应收款项-已收款项                groupProfit = sumPr - cost;                groupRatainage = sumPr - sumPr;                fin_GroupProfitInfoViews.Add(new Fin_GroupProfitInfoView() { Diid = item, ReceivableFund = sumFr, ReceivedFund = sumPr, Refund = refund, Cost = cost, RetainedProfits = groupProfit, FinalPayment = groupRatainage });            }            return fin_GroupProfitInfoViews;        }    }}
 |