|
@@ -1,6 +1,10 @@
|
|
|
using Aspose.Cells;
|
|
|
+using Aspose.Words.Tables;
|
|
|
+using Microsoft.AspNetCore.Mvc.ViewEngines;
|
|
|
using Microsoft.EntityFrameworkCore.Metadata.Internal;
|
|
|
+using MySqlX.XDevAPI.Relational;
|
|
|
using NetUV.Core.Handles;
|
|
|
+using NPOI.POIFS.Properties;
|
|
|
using NPOI.SS.Formula.Functions;
|
|
|
using NPOI.SS.Formula.PTG;
|
|
|
using OASystem.API.OAMethodLib;
|
|
@@ -656,8 +660,6 @@ ORDER BY
|
|
|
Order By CreateTime", _dto.DiId, _dto.isAudit ? "And (ccp.IsAuditGM = 1 OR ccp.IsAuditGM = 3)" : " ");
|
|
|
}
|
|
|
|
|
|
-
|
|
|
-
|
|
|
groupCTGGRFeeViews = await _sqlSugar.SqlQueryable<GroupCTGGRFeeView>(CTGGRFeeSql).ToListAsync();
|
|
|
|
|
|
string CTGGRFeeStr = "";
|
|
@@ -1372,6 +1374,12 @@ ORDER BY
|
|
|
var hotelFeeDt = new DataTable($"HotelFeeView");
|
|
|
decimal hotelCNYTotalCost = 0.00M;
|
|
|
|
|
|
+ //地接费用相关
|
|
|
+ var OPFeeSheet = worksheets["地接费用"];
|
|
|
+ var OPFeeDt = new DataTable($"OPFeeView");
|
|
|
+ var OPFeeLabel = string.Empty;
|
|
|
+ decimal OPCNYTotalCost = 0.00M;
|
|
|
+
|
|
|
//签证费用相关
|
|
|
var visaFeeSheet = worksheets["签证费用"];
|
|
|
var visaFeeDt = new DataTable($"VisaFeeView");
|
|
@@ -1397,14 +1405,35 @@ ORDER BY
|
|
|
var otherFeeDt = new DataTable($"OtherFeeView");
|
|
|
decimal otherCNYTotalCost = 0.00M;
|
|
|
|
|
|
+ //收款退还相关
|
|
|
+ var SKTHFeeSheet = worksheets["收款退还"];
|
|
|
+ var SKTHFeeDt = new DataTable($"SKTHFeeView");
|
|
|
+ decimal SKTHCNYTotalCost = 0.00M;
|
|
|
+
|
|
|
+ var totalAmount = 0.00M; //支出成本合计
|
|
|
+ var accountsAmount = 0.00M; //应收金额合计
|
|
|
+ var receivedAmount = 0.00M; //已收金额合计
|
|
|
+ var accountsProfit = 0.00M; //应收利润合计
|
|
|
+ var receiveProfit = 0.00M; //已收利润合计
|
|
|
+ var profitMargin = 0.00M; //利润差合计
|
|
|
+
|
|
|
+ //应收合计相关
|
|
|
+ var receivableFeeSheet = worksheets["团组收入(未收)"];
|
|
|
+ var receivableFeeDt = new DataTable($"ReceivableFeeView");
|
|
|
+
|
|
|
+ //已收合计相关
|
|
|
+ var receivedFeeSheet = worksheets["团组收入(已收)"];
|
|
|
+ var receivedFeeDt = new DataTable($"ReceivedFeeView");
|
|
|
+
|
|
|
+ //团组收入支出利润
|
|
|
+ var groupIEProfitDt = new DataTable($"IEProfitFeeView");
|
|
|
+
|
|
|
#endregion
|
|
|
|
|
|
#region 酒店费用
|
|
|
|
|
|
if (hotelFeeSheet != null)
|
|
|
{
|
|
|
- var _setDatas = await _sqlSugar.Queryable<Sys_SetData>().Where(it => it.IsDel == 0).ToListAsync();
|
|
|
-
|
|
|
string hotelFeeSql = string.Format(@"
|
|
|
SELECT
|
|
|
hr.Id AS HrId,
|
|
@@ -1464,119 +1493,233 @@ ORDER BY
|
|
|
|
|
|
var groupHotelFeeViews = await _sqlSugar.SqlQueryable<GroupHotelFeeView>(hotelFeeSql).ToListAsync();
|
|
|
|
|
|
- var hotelSubIds = groupHotelFeeViews.Select(it => it.HrId).ToList();
|
|
|
+ if (groupHotelFeeViews.Any())
|
|
|
+ {
|
|
|
+ var _setDatas = await _sqlSugar.Queryable<Sys_SetData>().Where(it => it.IsDel == 0).ToListAsync();
|
|
|
|
|
|
- var groupHotelContentFeeViews = await _sqlSugar.Queryable<Grp_HotelReservationsContent>().Where(it => hotelSubIds.Contains(it.HrId)).ToListAsync();
|
|
|
+ var hotelSubIds = groupHotelFeeViews.Select(it => it.HrId).ToList();
|
|
|
|
|
|
- var teamRateData = await _teamRateRep.PostGroupRateInfoByDiId(_dto.DiId);
|
|
|
- foreach (var item in groupHotelFeeViews)
|
|
|
- {
|
|
|
- if (groupHotelContentFeeViews.Count > 0)
|
|
|
+ var groupHotelContentFeeViews = await _sqlSugar.Queryable<Grp_HotelReservationsContent>().Where(it => hotelSubIds.Contains(it.HrId)).ToListAsync();
|
|
|
+
|
|
|
+ var teamRateData = await _teamRateRep.PostGroupRateInfoByDiId(_dto.DiId);
|
|
|
+ foreach (var item in groupHotelFeeViews)
|
|
|
{
|
|
|
+ if (groupHotelContentFeeViews.Count > 0)
|
|
|
+ {
|
|
|
|
|
|
- string paymentStr = string.Empty;
|
|
|
+ string paymentStr = string.Empty;
|
|
|
|
|
|
- var roomData = groupHotelContentFeeViews.Find(it => it.HrId == item.HrId && it.PriceType == 1); //房费
|
|
|
+ var roomData = groupHotelContentFeeViews.Find(it => it.HrId == item.HrId && it.PriceType == 1); //房费
|
|
|
|
|
|
- item.RoomPrice = roomData?.Price ?? 0.00M;
|
|
|
- if (item.RoomPrice != 0)
|
|
|
- {
|
|
|
- if (roomData.IsPay == 0) paymentStr += $"房费:未付款<br/>";
|
|
|
+ item.RoomPrice = roomData?.Price ?? 0.00M;
|
|
|
+ if (item.RoomPrice != 0)
|
|
|
+ {
|
|
|
+ if (roomData.IsPay == 0) paymentStr += $"房费:未付款<br/>";
|
|
|
|
|
|
- item.RoomPriceCurrency = _setDatas.Find(it => it.Id == roomData?.Currency)?.Name;
|
|
|
- string feeMark1 = roomData?.OrbitalPrivateTransfer == 0 ? "公转" : "私转";
|
|
|
- string isFeeMark1 = roomData?.IsOppay == 1 ? "是" : "否";
|
|
|
- item.RoomInfoTips = @$"当时汇率:{roomData?.Rate.ToString("#0.0000")} <br/>
|
|
|
+ item.RoomPriceCurrency = _setDatas.Find(it => it.Id == roomData?.Currency)?.Name;
|
|
|
+ string feeMark1 = roomData?.OrbitalPrivateTransfer == 0 ? "公转" : "私转";
|
|
|
+ string isFeeMark1 = roomData?.IsOppay == 1 ? "是" : "否";
|
|
|
+ item.RoomInfoTips = @$"当时汇率:{roomData?.Rate.ToString("#0.0000")} <br/>
|
|
|
收款方:{roomData?.Payee}<br/>
|
|
|
费用标识:{feeMark1} <br/>
|
|
|
支付方式:{_setDatas.Find(it => it.Id == roomData?.PayDId)?.Name} <br/>
|
|
|
卡类型:{_setDatas.Find(it => it.Id == roomData?.CTDId)?.Name}<br/>
|
|
|
是否由地接支付:{isFeeMark1} <br/>";
|
|
|
- }
|
|
|
+ }
|
|
|
|
|
|
- var breakfastData = groupHotelContentFeeViews.Find(it => it.HrId == item.HrId && it.PriceType == 2); //早餐
|
|
|
+ var breakfastData = groupHotelContentFeeViews.Find(it => it.HrId == item.HrId && it.PriceType == 2); //早餐
|
|
|
|
|
|
- item.BreakfastPrice = breakfastData?.Price ?? 0.00M;
|
|
|
+ item.BreakfastPrice = breakfastData?.Price ?? 0.00M;
|
|
|
|
|
|
- if (item.BreakfastPrice != 0)
|
|
|
- {
|
|
|
- if (breakfastData.IsPay == 0) paymentStr += $"早餐:未付款<br/>";
|
|
|
+ if (item.BreakfastPrice != 0)
|
|
|
+ {
|
|
|
+ if (breakfastData.IsPay == 0) paymentStr += $"早餐:未付款<br/>";
|
|
|
|
|
|
- item.BreakfastCurrency = _setDatas.Find(it => it.Id == breakfastData?.Currency)?.Name;
|
|
|
- string feeMark2 = breakfastData?.OrbitalPrivateTransfer == 0 ? "公转" : "私转";
|
|
|
- string isFeeMark2 = breakfastData?.IsOppay == 1 ? "是" : "否";
|
|
|
- item.BreakfastInfoTips = @$"当时汇率:{breakfastData?.Rate.ToString("#0.0000")} <br/>
|
|
|
+ item.BreakfastCurrency = _setDatas.Find(it => it.Id == breakfastData?.Currency)?.Name;
|
|
|
+ string feeMark2 = breakfastData?.OrbitalPrivateTransfer == 0 ? "公转" : "私转";
|
|
|
+ string isFeeMark2 = breakfastData?.IsOppay == 1 ? "是" : "否";
|
|
|
+ item.BreakfastInfoTips = @$"当时汇率:{breakfastData?.Rate.ToString("#0.0000")} <br/>
|
|
|
收款方:{breakfastData?.Payee}<br/>
|
|
|
费用标识:{feeMark2} <br/>
|
|
|
支付方式:{_setDatas.Find(it => it.Id == roomData?.PayDId)?.Name} <br/>
|
|
|
卡类型:{_setDatas.Find(it => it.Id == roomData?.CTDId)?.Name} <br/>
|
|
|
是否由地接支付:{isFeeMark2} <br/>";
|
|
|
- }
|
|
|
+ }
|
|
|
|
|
|
- var landTaxData = groupHotelContentFeeViews.Find(it => it.HrId == item.HrId && it.PriceType == 3); //地税
|
|
|
+ var landTaxData = groupHotelContentFeeViews.Find(it => it.HrId == item.HrId && it.PriceType == 3); //地税
|
|
|
|
|
|
- item.GovernmentRent = landTaxData?.Price ?? 0.00M;
|
|
|
+ item.GovernmentRent = landTaxData?.Price ?? 0.00M;
|
|
|
|
|
|
- if (item.GovernmentRent != 0)
|
|
|
- {
|
|
|
- if (landTaxData.IsPay == 0) paymentStr += $"地税:未付款<br/>";
|
|
|
+ if (item.GovernmentRent != 0)
|
|
|
+ {
|
|
|
+ if (landTaxData.IsPay == 0) paymentStr += $"地税:未付款<br/>";
|
|
|
|
|
|
- item.GovernmentRentCurrency = _setDatas.Find(it => it.Id == landTaxData?.Currency)?.Name;
|
|
|
- string feeMark3 = landTaxData?.OrbitalPrivateTransfer == 0 ? "公转" : "私转";
|
|
|
- string isFeeMark3 = landTaxData?.IsOppay == 1 ? "是" : "否";
|
|
|
- item.GovernmentRentTips = @$"当时汇率:{landTaxData?.Rate.ToString("#0.0000")} <br/>
|
|
|
+ item.GovernmentRentCurrency = _setDatas.Find(it => it.Id == landTaxData?.Currency)?.Name;
|
|
|
+ string feeMark3 = landTaxData?.OrbitalPrivateTransfer == 0 ? "公转" : "私转";
|
|
|
+ string isFeeMark3 = landTaxData?.IsOppay == 1 ? "是" : "否";
|
|
|
+ item.GovernmentRentTips = @$"当时汇率:{landTaxData?.Rate.ToString("#0.0000")} <br/>
|
|
|
收款方:{landTaxData?.Payee}<br/>
|
|
|
费用标识:{feeMark3} <br/>
|
|
|
支付方式:{_setDatas.Find(it => it.Id == landTaxData?.PayDId)?.Name} <br/>
|
|
|
卡类型:{_setDatas.Find(it => it.Id == landTaxData?.CTDId)?.Name} <br/>
|
|
|
是否由地接支付:{isFeeMark3} <br/>";
|
|
|
- }
|
|
|
+ }
|
|
|
|
|
|
- var cityTaxData = groupHotelContentFeeViews.Find(it => it.HrId == item.HrId && it.PriceType == 4); //城市税
|
|
|
+ var cityTaxData = groupHotelContentFeeViews.Find(it => it.HrId == item.HrId && it.PriceType == 4); //城市税
|
|
|
|
|
|
- item.CityTax = cityTaxData?.Price ?? 0.00M;
|
|
|
+ item.CityTax = cityTaxData?.Price ?? 0.00M;
|
|
|
|
|
|
- if (item.CityTax != 0)
|
|
|
- {
|
|
|
- if (cityTaxData.IsPay == 0) paymentStr += $"城市税:未付款<br/>";
|
|
|
- item.CityTaxCurrency = _setDatas.Find(it => it.Id == cityTaxData?.Currency)?.Name;
|
|
|
- string feeMark4 = cityTaxData?.OrbitalPrivateTransfer == 0 ? "公转" : "私转";
|
|
|
- string isFeeMark4 = landTaxData?.IsOppay == 1 ? "是" : "否";
|
|
|
- item.CityTaxTips = @$"当时汇率:{cityTaxData?.Rate.ToString("#0.0000")} <br/>
|
|
|
+ if (item.CityTax != 0)
|
|
|
+ {
|
|
|
+ if (cityTaxData.IsPay == 0) paymentStr += $"城市税:未付款<br/>";
|
|
|
+ item.CityTaxCurrency = _setDatas.Find(it => it.Id == cityTaxData?.Currency)?.Name;
|
|
|
+ string feeMark4 = cityTaxData?.OrbitalPrivateTransfer == 0 ? "公转" : "私转";
|
|
|
+ string isFeeMark4 = landTaxData?.IsOppay == 1 ? "是" : "否";
|
|
|
+ item.CityTaxTips = @$"当时汇率:{cityTaxData?.Rate.ToString("#0.0000")} <br/>
|
|
|
收款方:{cityTaxData?.Payee}<br/>
|
|
|
费用标识:{feeMark4} <br/>
|
|
|
支付方式:{_setDatas.Find(it => it.Id == cityTaxData?.PayDId)?.Name} <br/>
|
|
|
卡类型:{_setDatas.Find(it => it.Id == cityTaxData?.CTDId)?.Name} <br/>
|
|
|
是否由地接支付:{isFeeMark4} <br/>";
|
|
|
+ }
|
|
|
+
|
|
|
+ if (!string.IsNullOrEmpty(paymentStr))
|
|
|
+ {
|
|
|
+ item.IsPay = 2;
|
|
|
+ item.PayTips = paymentStr;
|
|
|
+ }
|
|
|
+ //item.CNYPrice = roomData?.Price ?? 0.00M * roomData?.Rate ?? 0.00M +
|
|
|
+ // breakfastData?.Price ?? 0.00M * breakfastData?.Rate ?? 0.00M +
|
|
|
+ // landTaxData?.Price ?? 0.00M * landTaxData?.Rate ?? 0.00M +
|
|
|
+ // cityTaxData?.Price ?? 0.00M * cityTaxData?.Rate ?? 0.00M;
|
|
|
+ }
|
|
|
+ else
|
|
|
+ {
|
|
|
+ decimal roomPrice = (item.SingleRoomCount * item.SingleRoomPrice) +
|
|
|
+ (item.DoubleRoomCount * item.DoubleRoomPrice) +
|
|
|
+ (item.SuiteRoomCount * item.SuiteRoomPrice) +
|
|
|
+ (item.OtherRoomCount * item.OtherRoomPrice);
|
|
|
+ //item.RoomPrice = item.CardPrice;
|
|
|
+ item.RoomPriceCurrency = item.PaymentCurrency;
|
|
|
}
|
|
|
|
|
|
- if (!string.IsNullOrEmpty(paymentStr))
|
|
|
+ item.PayMoney = item.PayMoney.ConvertToDecimal1();
|
|
|
+ item.CNYPrice = item.CNYPrice.ConvertToDecimal1();
|
|
|
+ }
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ hotelCNYTotalCost = groupHotelFeeViews.Sum(x => x.CNYPrice);
|
|
|
+ hotelFeeDt = CommonFun.ToDataTableArray(groupHotelFeeViews);
|
|
|
+ hotelFeeDt.TableName = $"HotelFeeView";
|
|
|
+ }
|
|
|
+
|
|
|
+ #endregion
|
|
|
+
|
|
|
+ #region 地接费用
|
|
|
+ if (OPFeeSheet != null)
|
|
|
+ {
|
|
|
+ string CTGGRFeeSql = string.Empty;
|
|
|
+ if (groupInfo.VisitDate > Convert.ToDateTime("2024-04-17"))
|
|
|
+ {
|
|
|
+ CTGGRFeeSql = string.Format(@"Select ctggr.Id As CTGGRId,ctggr.DiId As CTGGRDiId,ctggr.PriceName As Area,ctggrc.*,ctggrc.Price As PayMoney,
|
|
|
+ sd2.name As PaymentCurrency,ccp.PayPercentage,
|
|
|
+ (ctggrc.Price * (ccp.PayPercentage / 100)) As AmountPaid,
|
|
|
+ (ctggrc.Price - ctggrc.Price * (ccp.PayPercentage / 100)) As BalancePayment,
|
|
|
+ ccp.DayRate,(ctggrc.Price * (ccp.PayPercentage / 100) * ccp.DayRate) As CNYPrice,ccp.Payee,ccp.AuditGMDate,
|
|
|
+ ccp.OrbitalPrivateTransfer,sd1.Name As PayWay,ccp.IsPay,u.CnName As Applicant,ctggr.CreateTime
|
|
|
+ From Grp_CarTouristGuideGroundReservations ctggr
|
|
|
+ Left Join ( Select cggrc.CTGGRId,sd1.Name As PriceName,cggrc.Price*cggrc.Count As Price,sd2.Name As PriceCurrency,
|
|
|
+ cggrc.DatePrice,cggrc.PriceContent
|
|
|
+ From Grp_CarTouristGuideGroundReservationsContent cggrc
|
|
|
+ Left Join Sys_SetData sd1 On cggrc.SId = sd1.Id
|
|
|
+ Left Join Sys_SetData sd2 On cggrc.Currency = sd2.Id
|
|
|
+ Where cggrc.ISdel = 0 And cggrc.Price != 0.00
|
|
|
+ ) ctggrc On ctggr.Id = ctggrc.CTGGRId
|
|
|
+ Left Join Grp_CreditCardPayment ccp On ccp.IsDel = 0 And ccp.CTable = 79 And ctggr.Id = ccp.CId
|
|
|
+ Left Join Sys_SetData sd1 On ccp.PayDId = sd1.Id
|
|
|
+ Left Join Sys_SetData sd2 On ccp.PaymentCurrency = sd2.Id
|
|
|
+ Left Join Sys_Users u On ccp.CreateUserId = u.Id
|
|
|
+ Where ctggr.IsDel = 0 {1} And ctggr.DiId = {0}
|
|
|
+ Order By CreateTime", _dto.DiId, _dto.isAudit ? "And (ccp.IsAuditGM = 1 OR ccp.IsAuditGM = 3)" : " ");
|
|
|
+ }
|
|
|
+ else
|
|
|
+ {
|
|
|
+ CTGGRFeeSql = string.Format(@"Select ctggr.Id As CTGGRId,ctggr.DiId As CTGGRDiId,ctggr.PriceName As Area,
|
|
|
+ ccp.PayMoney,sd2.name As PaymentCurrency,ccp.PayPercentage,
|
|
|
+ (ccp.PayMoney * (ccp.PayPercentage / 100)) As AmountPaid,
|
|
|
+ (ccp.PayMoney -ccp.PayMoney * (ccp.PayPercentage / 100)) As BalancePayment,
|
|
|
+ ccp.DayRate,(ccp.PayMoney * (ccp.PayPercentage / 100) * ccp.DayRate) As CNYPrice,
|
|
|
+ ccp.Payee,ccp.AuditGMDate,
|
|
|
+ ccp.OrbitalPrivateTransfer,sd1.Name As PayWay,ccp.IsPay,u.CnName As Applicant,ctggr.CreateTime
|
|
|
+ From Grp_CarTouristGuideGroundReservations ctggr
|
|
|
+ Left Join Grp_CreditCardPayment ccp On ccp.IsDel = 0 And ccp.CTable = 79 And ctggr.Id = ccp.CId
|
|
|
+ Left Join Sys_SetData sd1 On ccp.PayDId = sd1.Id
|
|
|
+ Left Join Sys_SetData sd2 On ccp.PaymentCurrency = sd2.Id
|
|
|
+ Left Join Sys_Users u On ccp.CreateUserId = u.Id
|
|
|
+ Where ctggr.IsDel = 0 {1} And ctggr.DiId = {0}
|
|
|
+ Order By CreateTime", _dto.DiId, _dto.isAudit ? "And (ccp.IsAuditGM = 1 OR ccp.IsAuditGM = 3)" : " ");
|
|
|
+ }
|
|
|
+
|
|
|
+ var groupOPFeeViews = await _sqlSugar.SqlQueryable<GroupCTGGRFeeView>(CTGGRFeeSql).ToListAsync();
|
|
|
+ string CTGGRFeeStr = "";
|
|
|
+ var OPToDataTableViews = groupOPFeeViews;
|
|
|
+
|
|
|
+ decimal CTGGRCNYTotalPrice = 0.00M;
|
|
|
+
|
|
|
+ //按1 地区,2 币种,3 汇率 分组计算
|
|
|
+ var groupCTGGRFeeDatas = groupOPFeeViews.GroupBy(it => it.Area);
|
|
|
+
|
|
|
+ foreach (var ctggfr in groupCTGGRFeeDatas)
|
|
|
+ {
|
|
|
+ var ctggfr_curr = ctggfr.GroupBy(it => it.PaymentCurrency);
|
|
|
+
|
|
|
+ if (ctggfr_curr.Count() > 0)
|
|
|
+ {
|
|
|
+ foreach (var curr in ctggfr_curr)
|
|
|
{
|
|
|
- item.IsPay = 2;
|
|
|
- item.PayTips = paymentStr;
|
|
|
+
|
|
|
+ var ctggfr_rate = curr.GroupBy(it => it.DayRate);
|
|
|
+
|
|
|
+ if (ctggfr_rate.Count() > 0)
|
|
|
+ {
|
|
|
+ foreach (var rate in ctggfr_rate)
|
|
|
+ {
|
|
|
+ CTGGRFeeStr += string.Format(@$"{ctggfr.Key} 总费用:{rate.Sum(it => it.AmountPaid).ToString("#0.00")} {rate.FirstOrDefault()?.PaymentCurrency}(人民币:{rate.Sum(it => Convert.ToDecimal(it.CNYPrice.ToString("#0.00"))).ToString("#0.00")} CNY 当时支付汇率:{rate.FirstOrDefault()?.DayRate.ToString("#0.0000")})\n");
|
|
|
+ CTGGRCNYTotalPrice += rate.Sum(it => Convert.ToDecimal(it.CNYPrice.ToString("#0.00")));
|
|
|
+ }
|
|
|
+ }
|
|
|
+ else
|
|
|
+ {
|
|
|
+ CTGGRFeeStr += string.Format(@$"{ctggfr.Key} 总费用:{curr.Sum(it => it.AmountPaid).ToString("#0.00")} {curr.FirstOrDefault()?.PaymentCurrency}(人民币:{curr.Sum(it => Convert.ToDecimal(it.CNYPrice.ToString("#0.00"))).ToString("#0.00")} CNY 当时支付汇率:{curr.FirstOrDefault()?.DayRate.ToString("#0.0000")})\n");
|
|
|
+ CTGGRCNYTotalPrice += curr.Sum(it => Convert.ToDecimal(it.CNYPrice.ToString("#0.00")));
|
|
|
+ }
|
|
|
}
|
|
|
- //item.CNYPrice = roomData?.Price ?? 0.00M * roomData?.Rate ?? 0.00M +
|
|
|
- // breakfastData?.Price ?? 0.00M * breakfastData?.Rate ?? 0.00M +
|
|
|
- // landTaxData?.Price ?? 0.00M * landTaxData?.Rate ?? 0.00M +
|
|
|
- // cityTaxData?.Price ?? 0.00M * cityTaxData?.Rate ?? 0.00M;
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
- decimal roomPrice = (item.SingleRoomCount * item.SingleRoomPrice) +
|
|
|
- (item.DoubleRoomCount * item.DoubleRoomPrice) +
|
|
|
- (item.SuiteRoomCount * item.SuiteRoomPrice) +
|
|
|
- (item.OtherRoomCount * item.OtherRoomPrice);
|
|
|
- //item.RoomPrice = item.CardPrice;
|
|
|
- item.RoomPriceCurrency = item.PaymentCurrency;
|
|
|
+ CTGGRFeeStr += string.Format(@$"{ctggfr.Key} 总费用:{ctggfr.Sum(it => it.AmountPaid).ToString("#0.00")} {ctggfr.FirstOrDefault()?.PaymentCurrency}(人民币:{ctggfr.Sum(it => Convert.ToDecimal(it.CNYPrice.ToString("#0.00"))).ToString("#0.00")} CNY 当时支付汇率:{ctggfr.FirstOrDefault()?.DayRate.ToString("#0.0000")})\n");
|
|
|
+ CTGGRCNYTotalPrice += ctggfr.Sum(it => Convert.ToDecimal(it.CNYPrice.ToString("#0.00")));
|
|
|
}
|
|
|
+ }
|
|
|
|
|
|
- item.PayMoney = item.PayMoney.ConvertToDecimal1();
|
|
|
- item.CNYPrice = item.CNYPrice.ConvertToDecimal1();
|
|
|
+ foreach (var item in groupOPFeeViews)
|
|
|
+ {
|
|
|
+ if (!string.IsNullOrEmpty(item.AuditGMDate))
|
|
|
+ {
|
|
|
+ item.AuditGMDate = Convert.ToDateTime(item.AuditGMDate).ToString("yyyy-MM-dd HH:mm:ss");
|
|
|
+ }
|
|
|
+
|
|
|
+ if (item.DatePrice != null)
|
|
|
+ {
|
|
|
+ item.PriceName = $"{item.PriceName}({Convert.ToDateTime(item.DatePrice).ToString("yyyy-MM-dd")})";
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
- hotelCNYTotalCost = groupHotelFeeViews.Sum(x => x.CNYPrice);
|
|
|
- hotelFeeDt = CommonFun.ToDataTableArray(groupHotelFeeViews);
|
|
|
- hotelFeeDt.TableName = $"HotelFeeView";
|
|
|
+ OPCNYTotalCost = CTGGRCNYTotalPrice;
|
|
|
+ OPFeeDt = CommonFun.ToDataTableArray(OPToDataTableViews);
|
|
|
+ OPFeeLabel = CTGGRFeeStr;
|
|
|
+ OPFeeDt.TableName = $"OPFeeView";
|
|
|
}
|
|
|
|
|
|
#endregion
|
|
@@ -1791,6 +1934,160 @@ ORDER BY
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
+ #region 收款退还
|
|
|
+
|
|
|
+ if (SKTHFeeSheet != null)
|
|
|
+ {
|
|
|
+ //删除了 And prom.PriceType = 1
|
|
|
+ string _ropSql = string.Format(@"Select u.CnName As Appliction,prom.Id As PrId,prom.DiId As PrDiId,prom.Price As PrPrice,
|
|
|
+ prom.PriceName AS PrPriceName,prom.CurrencyId As PrCurrencyId,
|
|
|
+ prom.PayType As PrPayType,prom.PriceType As PrPriceType,
|
|
|
+ ccp.RMBPrice * ccp.DayRate As RMBPrice,ccp.*,prom.CreateTime As PrCreateTime,prom.Remark AS SKTHRemark
|
|
|
+ From Fin_PaymentRefundAndOtherMoney prom
|
|
|
+ Left Join Grp_CreditCardPayment ccp On prom.DiId = ccp.DIId And prom.Id = ccp.CId
|
|
|
+ Left Join Sys_Users u On ccp.CreateUserId = u.Id
|
|
|
+ Where prom.IsDel = 0
|
|
|
+ And prom.PayType = 1
|
|
|
+ And ccp.CTable = 285
|
|
|
+ {1}
|
|
|
+ And prom.DiId = {0} Order By PrCreateTime", _dto.DiId, _dto.isAudit ? "And ccp.IsAuditGM = 1" : " ");
|
|
|
+ var _promDatas = await _sqlSugar.SqlQueryable<Gsd_PaymentRefundAndOtherMoneyDataSource1View>(_ropSql).ToListAsync();
|
|
|
+
|
|
|
+ if (_promDatas.Any())
|
|
|
+ {
|
|
|
+ var _promView = new List<Gsd_PaymentRefundAndOtherMoneyView>();
|
|
|
+ var _setDatas = await _sqlSugar.Queryable<Sys_SetData>().Where(it => it.IsDel == 0).ToListAsync();
|
|
|
+
|
|
|
+ foreach (var ropItem in _promDatas)
|
|
|
+ {
|
|
|
+ string thisCueencyCode = "Unknown";
|
|
|
+ string thisCueencyName = "Unknown";
|
|
|
+ var currency = _setDatas.Where(it => it.Id == ropItem.PaymentCurrency).FirstOrDefault();
|
|
|
+ if (currency != null)
|
|
|
+ {
|
|
|
+ thisCueencyCode = currency.Name;
|
|
|
+ thisCueencyName = currency.Remark;
|
|
|
+ }
|
|
|
+
|
|
|
+ string orbitalPrivateTransferStr = "Unknown";
|
|
|
+ var orbitalPrivateTransfer = _setDatas.Where(it => it.Id == ropItem.OrbitalPrivateTransfer).FirstOrDefault();
|
|
|
+ if (orbitalPrivateTransfer != null)
|
|
|
+ {
|
|
|
+ orbitalPrivateTransferStr = orbitalPrivateTransfer.Name;
|
|
|
+ }
|
|
|
+
|
|
|
+ string payStr = "Unknown";
|
|
|
+ var pay = _setDatas.Where(it => it.Id == ropItem.PayDId).FirstOrDefault();
|
|
|
+ if (pay != null)
|
|
|
+ {
|
|
|
+ payStr = pay.Name;
|
|
|
+ }
|
|
|
+
|
|
|
+ var gsd_PaymentRefund = new Gsd_PaymentRefundAndOtherMoneyView()
|
|
|
+ {
|
|
|
+ Id = ropItem.Id,
|
|
|
+ DiId = ropItem.DIId,
|
|
|
+ PriceName = ropItem.PrPriceName,
|
|
|
+ PayCurrencyCode = thisCueencyCode,
|
|
|
+ PayCurrencyName = thisCueencyName,
|
|
|
+ Price = ropItem.PrPrice,
|
|
|
+ CNYPrice = ropItem.PayMoney * ropItem.DayRate,
|
|
|
+ ThisRate = ropItem.DayRate,
|
|
|
+ Payee = ropItem.Payee,
|
|
|
+ PayTime = ropItem.AuditGMDate,
|
|
|
+ OrbitalPrivateTransfer = ropItem.OrbitalPrivateTransfer,
|
|
|
+ PayType = payStr,
|
|
|
+ IsPay = ropItem.IsPay,
|
|
|
+ Applicant = ropItem.Appliction,
|
|
|
+ Remark = ropItem.SKTHRemark
|
|
|
+ };
|
|
|
+
|
|
|
+ _promView.Add(gsd_PaymentRefund);
|
|
|
+ }
|
|
|
+
|
|
|
+ SKTHCNYTotalCost = _promView.Sum(x => x.CNYPrice);
|
|
|
+ SKTHFeeDt = CommonFun.ToDataTableArray(_promView);
|
|
|
+ SKTHFeeDt.TableName = $"SKTHFeeView";
|
|
|
+ }
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ #endregion
|
|
|
+
|
|
|
+ #region 应收金额(增加方式=实际报价时 费用必须审核才能进入团组报表)
|
|
|
+ decimal frTotalAmount = 0.00M;//应收总金额
|
|
|
+ string _frSql = string.Format(@" Select fr.Id,fr.AddingWay,fr.Status,u.CnName As Auditor,fr.AuditTime,fr.Diid,fr.PriceName,fr.Price,fr.Count,fr.Unit,fr.Currency,
|
|
|
+ sd.Name As CurrencyCode,sd.Remark As CurrencyName,fr.Rate,fr.ItemSumPrice,fr.CreateTime,fr.Remark
|
|
|
+ From Fin_ForeignReceivables fr
|
|
|
+ Left Join Sys_SetData sd On fr.Currency = sd.Id
|
|
|
+ Left Join Sys_Users u On fr.Auditor = u.Id
|
|
|
+ Where fr.IsDel = 0 And fr.Diid = {0} Order By CreateTime", _dto.DiId);
|
|
|
+ var _frViews = await _sqlSugar.SqlQueryable<Gsd_ForeignReceivablesView>(_frSql).ToListAsync();
|
|
|
+
|
|
|
+ _frViews.ForEach(x =>
|
|
|
+ {
|
|
|
+ string namePrefix = string.Empty;
|
|
|
+ if (x.AddingWay == 0) namePrefix = $"账单模块-";
|
|
|
+ else if (x.AddingWay == 1) namePrefix = $"成本预算模块-";
|
|
|
+ else if (x.AddingWay == 2) namePrefix = $"实际报价-";
|
|
|
+ x.PriceName = $"{namePrefix}{x.PriceName}";
|
|
|
+ });
|
|
|
+
|
|
|
+ if (_frViews.Any())
|
|
|
+ {
|
|
|
+ accountsAmount = _frViews.Sum(it => it.ItemSumPrice);
|
|
|
+ receivableFeeDt = CommonFun.ToDataTableArray(_frViews);
|
|
|
+ receivableFeeDt.TableName = $"ReceivedFeeView";
|
|
|
+ }
|
|
|
+
|
|
|
+ #endregion
|
|
|
+
|
|
|
+ #region 已收金额
|
|
|
+ decimal prTotalAmount = 0.00M;//已收总金额
|
|
|
+ string _prSql = string.Format(@"Select pr.Id,pr.Diid,pr.SectionTime As SectionTimeDt,pr.Price,pr.Currency,
|
|
|
+ sd1.Name As CurrencyCode,sd1.Remark As CurrencyName,pr.Client,
|
|
|
+ pr.ReceivablesType,sd2.Name As ReceivablesTypeName,pr.Remark,pr.CreateTime
|
|
|
+ From Fin_ProceedsReceived pr
|
|
|
+ Left Join Sys_SetData sd1 On pr.Currency = sd1.Id
|
|
|
+ Left Join Sys_SetData sd2 On pr.ReceivablesType = sd2.Id
|
|
|
+ Where pr.IsDel = 0 and pr.Diid = {0} Order By CreateTime", _dto.DiId);
|
|
|
+ var _prViews = await _sqlSugar.SqlQueryable<Gsd_ProceedsReceivedView>(_prSql).ToListAsync();
|
|
|
+
|
|
|
+ if (_prViews.Any())
|
|
|
+ {
|
|
|
+ receivedAmount = _prViews.Sum(it => it.Price);
|
|
|
+ receivedFeeDt = CommonFun.ToDataTableArray(_prViews);
|
|
|
+ receivedFeeDt.TableName = $"ReceivableFeeView";
|
|
|
+ }
|
|
|
+
|
|
|
+ #endregion
|
|
|
+
|
|
|
+ #region 团组收入支出利润
|
|
|
+ groupIEProfitDt.Columns.AddRange(new DataColumn[] {
|
|
|
+ new DataColumn(){ ColumnName = "ModuleName"},
|
|
|
+ new DataColumn(){ ColumnName = "FeeTotal",DataType = typeof(decimal)},
|
|
|
+ new DataColumn(){ ColumnName = "FeeCurrency"},
|
|
|
+ });
|
|
|
+
|
|
|
+ var groupIEProfitDt_rows = new[] {
|
|
|
+ new object[] { $"签证费用", visaCNYTotalCost, $"CNY" },
|
|
|
+ new object[] { $"酒店费用", hotelCNYTotalCost, $"CNY" },
|
|
|
+ new object[] { $"地接费用", OPCNYTotalCost, $"CNY" },
|
|
|
+ new object[] { $"商邀费用", OACNYTotalCost, $"CNY" },
|
|
|
+ new object[] { $"机票费用", airTicketCNYTotalCost, $"CNY" },
|
|
|
+ new object[] { $"保险费用", insureCNYTotalCost, $"CNY" },
|
|
|
+ new object[] { $"其他费用", otherCNYTotalCost, $"CNY" },
|
|
|
+ new object[] { $"收款退还费用", SKTHCNYTotalCost, $"CNY" },
|
|
|
+ };
|
|
|
+
|
|
|
+ // 批量添加
|
|
|
+ foreach (var rowData in groupIEProfitDt_rows)
|
|
|
+ {
|
|
|
+ groupIEProfitDt.Rows.Add(rowData);
|
|
|
+ }
|
|
|
+
|
|
|
+ #endregion
|
|
|
+
|
|
|
#region 统一填充数据源
|
|
|
designer.SetDataSource("GroupNo", groupNo);
|
|
|
designer.SetDataSource("GroupName", groupName);
|
|
@@ -1800,156 +2097,129 @@ ORDER BY
|
|
|
designer.SetDataSource(hotelFeeDt);
|
|
|
designer.SetDataSource("HotelCNYTotalCost", $"{hotelCNYTotalCost.ToString("#0.00")} CNY");
|
|
|
|
|
|
+ //地接
|
|
|
+ designer.SetDataSource(OPFeeDt);
|
|
|
+ designer.SetDataSource("OPFeeLabel", OPFeeLabel);
|
|
|
+ designer.SetDataSource("OPCNYTotalCost", $"{OPCNYTotalCost.ToString("#0.00")} CNY");
|
|
|
+
|
|
|
//签证
|
|
|
designer.SetDataSource(visaFeeDt);
|
|
|
designer.SetDataSource("VisaCNYTotalCost", $"{visaCNYTotalCost.ToString("#0.00")} CNY");
|
|
|
+
|
|
|
//商邀
|
|
|
designer.SetDataSource(OAFeeDt);
|
|
|
designer.SetDataSource("OACNYTotalCost", $"{OACNYTotalCost.ToString("#0.00")} CNY");
|
|
|
+
|
|
|
//机票
|
|
|
designer.SetDataSource(airTicketFeeDt);
|
|
|
designer.SetDataSource("AirTicketCNYTotalCost", $"{airTicketCNYTotalCost.ToString("#0.00")} CNY");
|
|
|
+
|
|
|
//保险
|
|
|
designer.SetDataSource(insureFeeDt);
|
|
|
designer.SetDataSource("InsureCNYTotalCost", $"{insureCNYTotalCost.ToString("#0.00")} CNY");
|
|
|
+
|
|
|
//其他费用
|
|
|
designer.SetDataSource(otherFeeDt);
|
|
|
designer.SetDataSource("OtherCNYTotalCost", $"{otherCNYTotalCost.ToString("#0.00")} CNY");
|
|
|
|
|
|
+ //收款退还
|
|
|
+ designer.SetDataSource(SKTHFeeDt);
|
|
|
+ designer.SetDataSource("SKTHCNYTotalCost", $"{SKTHCNYTotalCost.ToString("#0.00")}");
|
|
|
+
|
|
|
+ //已收金额
|
|
|
+ designer.SetDataSource(receivedFeeDt);
|
|
|
+ designer.SetDataSource("ReceivedAmount", $"{receivedAmount.ToString("#0.00")}");
|
|
|
+
|
|
|
+ //应收金额
|
|
|
+ designer.SetDataSource(receivableFeeDt);
|
|
|
+ designer.SetDataSource("AccountsAmount", $"{accountsAmount.ToString("#0.00")}");
|
|
|
+
|
|
|
+ //应收已收 -- 尾款
|
|
|
+ var balancePayment = accountsAmount - SKTHCNYTotalCost - receivedAmount;
|
|
|
+ designer.SetDataSource("BalancePayment", $"{balancePayment.ToString("#0.00")}");
|
|
|
+
|
|
|
+ //团组收入支出利润
|
|
|
+ designer.SetDataSource(groupIEProfitDt);
|
|
|
+ #region 各项费用计算
|
|
|
+ /*
|
|
|
+ * 团组报表计算方式
|
|
|
+ * 当前总支出 = 团组支出.Sum() + 超支费用.Sum()
|
|
|
+ * 应收金额 = 应收表.Sum() - 收款退还
|
|
|
+ * 已收金额 = 已收表.Sum() - 收款退还
|
|
|
+ * 应收利润(应收-支出) = 应收金额 - 当前总支出
|
|
|
+ * 已收利润(已收-支出) = 已收金额 - 当前总支出
|
|
|
+ * 利润差 = 应收利润 - 已收利润
|
|
|
+ */
|
|
|
+
|
|
|
+ totalAmount = visaCNYTotalCost + hotelCNYTotalCost + OPCNYTotalCost + OACNYTotalCost + airTicketCNYTotalCost + insureCNYTotalCost + otherCNYTotalCost;//合计金额
|
|
|
+ accountsProfit = accountsAmount - totalAmount - SKTHCNYTotalCost; //应收利润
|
|
|
+ receiveProfit = receivedAmount - totalAmount - SKTHCNYTotalCost; //已收利润
|
|
|
+ profitMargin = accountsProfit - receiveProfit; //利润差
|
|
|
+
|
|
|
+ designer.SetDataSource("TotalAmount", $"{totalAmount.ToString("#0.00")}");
|
|
|
+ designer.SetDataSource("AccountsProfit", $"{accountsProfit.ToString("#0.00")}");
|
|
|
+ designer.SetDataSource("ReceiveProfit", $"{receiveProfit.ToString("#0.00")}");
|
|
|
+ designer.SetDataSource("ProfitMargin", $"{profitMargin.ToString("#0.00")}");
|
|
|
+ #endregion
|
|
|
+
|
|
|
designer.Process();
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
#region 单元格样式设置 未付款设置为红色
|
|
|
+
|
|
|
/*
|
|
|
- * 设置单元格样式
|
|
|
- */
|
|
|
+ * 设置单元格样式
|
|
|
+ */
|
|
|
//背景颜色
|
|
|
Style style = designer.Workbook.CreateStyle();
|
|
|
- style.ForegroundColor = Color.FromArgb(255, 182, 193);
|
|
|
+ style.ForegroundColor = Color.FromArgb(254, 242, 203);
|
|
|
style.Pattern = BackgroundType.Solid;
|
|
|
//字体
|
|
|
style.Font.Name = "微软雅黑"; // 字体名称
|
|
|
style.Font.Size = 10; // 字体大小
|
|
|
style.Font.Color = System.Drawing.Color.Black; // 字体颜色
|
|
|
|
|
|
- #region 酒店费用单元格
|
|
|
- for (int i = 0; i < hotelFeeDt.Rows.Count; i++)
|
|
|
- {
|
|
|
- var isPayStr = hotelFeeDt.Rows[i]["IsPayLable"].ToString();
|
|
|
- if (string.IsNullOrEmpty(isPayStr)) continue;
|
|
|
-
|
|
|
- if (isPayStr.Contains("未付款"))
|
|
|
- {
|
|
|
- var excelIndex = 8 + i;
|
|
|
-
|
|
|
- if (hotelFeeSheet != null)
|
|
|
- {
|
|
|
- Aspose.Cells.Range range = hotelFeeSheet.Cells.CreateRange($"A{excelIndex}", $"V{excelIndex}");
|
|
|
- range.ApplyStyle(style, new StyleFlag() { CellShading = true, Font = true });
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
- #endregion
|
|
|
-
|
|
|
- #region 签证费用单元格
|
|
|
- for (int i = 0; i < visaFeeDt.Rows.Count; i++)
|
|
|
- {
|
|
|
- var isPayStr = visaFeeDt.Rows[i]["IsPay"].ToString();
|
|
|
- if (string.IsNullOrEmpty(isPayStr)) continue;
|
|
|
-
|
|
|
- if (isPayStr.Equals("未付款"))
|
|
|
- {
|
|
|
- var excelIndex = 6 + i;
|
|
|
-
|
|
|
- if (visaFeeSheet != null)
|
|
|
- {
|
|
|
- Aspose.Cells.Range range = visaFeeSheet.Cells.CreateRange($"A{excelIndex}", $"I{excelIndex}");
|
|
|
- range.ApplyStyle(style, new StyleFlag() { CellShading = true, Font = true });
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
- #endregion
|
|
|
-
|
|
|
- #region 商邀费用单元格
|
|
|
- for (int i = 0; i < OAFeeDt.Rows.Count; i++)
|
|
|
- {
|
|
|
- var isPayStr = OAFeeDt.Rows[i]["IsPay"].ToString();
|
|
|
- if (string.IsNullOrEmpty(isPayStr)) continue;
|
|
|
- if (isPayStr.Equals("未付款"))
|
|
|
- {
|
|
|
- var excelIndex = 6 + i;
|
|
|
-
|
|
|
- if (OAFeeSheet != null)
|
|
|
- {
|
|
|
- Aspose.Cells.Range range = OAFeeSheet.Cells.CreateRange($"A{excelIndex}", $"R{excelIndex}");
|
|
|
- range.ApplyStyle(style, new StyleFlag() { CellShading = true, Font = true });
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
+ StatementExportExcelSetCell(designer, hotelFeeSheet, hotelFeeDt, style, "IsPayLable", 8, "A", "V"); //酒店
|
|
|
+ StatementExportExcelSetCell(designer, OPFeeSheet, OPFeeDt, style, "IsPayLabel", 6, "A", "M"); //OP
|
|
|
+ StatementExportExcelSetCell(designer, visaFeeSheet, visaFeeDt, style, "IsPay", 6, "A", "I"); //签证
|
|
|
+ StatementExportExcelSetCell(designer, OAFeeSheet, OAFeeDt, style, "IsPay", 6, "A", "R"); //商邀
|
|
|
+ StatementExportExcelSetCell(designer, airTicketFeeSheet, airTicketFeeDt, style, "IsPay", 6, "A", "M"); //机票
|
|
|
+ StatementExportExcelSetCell(designer, insureFeeSheet, insureFeeDt, style, "IsPay", 6, "A", "I"); //保险
|
|
|
+ StatementExportExcelSetCell(designer, otherFeeSheet, otherFeeDt, style, "IsPay", 6, "A", "J"); //其他
|
|
|
+ StatementExportExcelSetCell(designer, SKTHFeeSheet, SKTHFeeDt, style, "IsPayLable", 6, "A", "K"); //首款退还
|
|
|
#endregion
|
|
|
|
|
|
- #region 机票费用单元格
|
|
|
- for (int i = 0; i < airTicketFeeDt.Rows.Count; i++)
|
|
|
- {
|
|
|
- var isPayStr = airTicketFeeDt.Rows[i]["IsPay"].ToString();
|
|
|
- if (string.IsNullOrEmpty(isPayStr)) continue;
|
|
|
-
|
|
|
- if (isPayStr.Equals("未付款"))
|
|
|
- {
|
|
|
- var excelIndex = 6 + i;
|
|
|
- if (airTicketFeeSheet != null)
|
|
|
- {
|
|
|
- Aspose.Cells.Range range = airTicketFeeSheet.Cells.CreateRange($"A{excelIndex}", $"M{excelIndex}");
|
|
|
- range.ApplyStyle(style, new StyleFlag() { CellShading = true, Font = true });
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
- #endregion
|
|
|
-
|
|
|
- #region 保险费用单元格
|
|
|
- for (int i = 0; i < insureFeeDt.Rows.Count; i++)
|
|
|
- {
|
|
|
- var isPayStr = insureFeeDt.Rows[i]["IsPay"].ToString();
|
|
|
- if (string.IsNullOrEmpty(isPayStr)) continue;
|
|
|
+ //文件名
|
|
|
+ string fileName = $"{groupName}[{groupNo}]_团组费用清单{DateTime.Now.ToString("yyyyMMddHHmmss")}.xls";
|
|
|
+ designer.Workbook.Save(AppSettingsHelper.Get("ExcelBasePath") + "GroupStatement/" + fileName);
|
|
|
+ string url = AppSettingsHelper.Get("ExcelBaseUrl") + "Office/Excel/GroupStatement/" + fileName;
|
|
|
+ return Ok(JsonView(true, "成功", url));
|
|
|
+ }
|
|
|
|
|
|
- if (isPayStr.Equals("未付款"))
|
|
|
- {
|
|
|
- var excelIndex = 6 + i;
|
|
|
- if (insureFeeSheet != null)
|
|
|
- {
|
|
|
- Aspose.Cells.Range range = insureFeeSheet.Cells.CreateRange($"A{excelIndex}", $"I{excelIndex}");
|
|
|
- range.ApplyStyle(style, new StyleFlag() { CellShading = true, Font = true });
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
- #endregion
|
|
|
|
|
|
- #region 其他费用单元格
|
|
|
- for (int i = 0; i < otherFeeDt.Rows.Count; i++)
|
|
|
+ private void StatementExportExcelSetCell(WorkbookDesigner designer, Worksheet sheet,DataTable dt, Style style,string judgeLable, int startIndex, string startRange,string endRange)
|
|
|
+ {
|
|
|
+ if (designer == null) return;
|
|
|
+ if (sheet == null) return;
|
|
|
+ if (style == null) return;
|
|
|
+ if (dt == null) return;
|
|
|
+ if (string.IsNullOrEmpty(startRange)) return;
|
|
|
+ if (string.IsNullOrEmpty(endRange)) return;
|
|
|
+
|
|
|
+ for (int i = 0; i < dt.Rows.Count; i++)
|
|
|
{
|
|
|
- var isPayStr = otherFeeDt.Rows[i]["IsPay"].ToString();
|
|
|
+ var isPayStr = dt.Rows[i][$"{judgeLable}"].ToString();
|
|
|
if (string.IsNullOrEmpty(isPayStr)) continue;
|
|
|
|
|
|
- if (isPayStr.Equals("未付款"))
|
|
|
+ if (isPayStr.Contains("未付款"))
|
|
|
{
|
|
|
- var excelIndex = 6 + i;
|
|
|
- if (otherFeeSheet != null)
|
|
|
- {
|
|
|
- Aspose.Cells.Range range = otherFeeSheet.Cells.CreateRange($"A{excelIndex}", $"J{excelIndex}");
|
|
|
- range.ApplyStyle(style, new StyleFlag() { CellShading = true, Font = true });
|
|
|
- }
|
|
|
+ var excelIndex = startIndex + i;
|
|
|
+ Aspose.Cells.Range range = sheet.Cells.CreateRange($"{startRange}{excelIndex}", $"{endRange}{excelIndex}");
|
|
|
+ range.ApplyStyle(style, new StyleFlag() { CellShading = true, Font = true });
|
|
|
}
|
|
|
}
|
|
|
- #endregion
|
|
|
-
|
|
|
- #endregion
|
|
|
|
|
|
- //文件名
|
|
|
- string fileName = $"{groupName}[{groupNo}]_团组费用清单{DateTime.Now.ToString("yyyyMMddHHmmss")}.xls";
|
|
|
- designer.Workbook.Save(AppSettingsHelper.Get("ExcelBasePath") + "GroupStatement/" + fileName);
|
|
|
- string url = AppSettingsHelper.Get("ExcelBaseUrl") + "Office/Excel/GroupStatement/" + fileName;
|
|
|
- return Ok(JsonView(true, "成功", url));
|
|
|
}
|
|
|
|
|
|
#endregion
|