|
|
@@ -60,6 +60,7 @@ import org.springblade.system.feign.ISysClient;
|
|
|
import org.springframework.stereotype.Service;
|
|
|
|
|
|
import java.math.BigDecimal;
|
|
|
+import java.math.RoundingMode;
|
|
|
import java.util.*;
|
|
|
import java.util.concurrent.ConcurrentHashMap;
|
|
|
import java.util.function.Function;
|
|
|
@@ -1192,47 +1193,6 @@ public class ReportsServiceImpl extends ServiceImpl<ReportsMapper, Reports> impl
|
|
|
bills.setRate(new BigDecimal(MagicValues.ZERO));
|
|
|
}
|
|
|
if (MagicValues.MM.equals(bills.getBillType()) || MagicValues.DD.equals(bills.getBillType())) {
|
|
|
- BigDecimal amountDr = new BigDecimal(MagicValues.ZERO);
|
|
|
- BigDecimal amountCr = new BigDecimal(MagicValues.ZERO);
|
|
|
- BigDecimal amountDrUsd = new BigDecimal(MagicValues.ZERO);
|
|
|
- BigDecimal amountCrUsd = new BigDecimal(MagicValues.ZERO);
|
|
|
- if (amendFeeCenterList.size() > 0) {
|
|
|
- amountDr = amendFeeCenterList.stream().filter(e -> MagicValues.D.equals(e.getDc()) && MagicValues.CNY.equals(e.getCurCode()))
|
|
|
- .map(FeeCenter::getAmount).reduce(BigDecimal.ZERO, BigDecimal::add);
|
|
|
- amountCr = amendFeeCenterList.stream().filter(e -> MagicValues.C.equals(e.getDc()) && MagicValues.CNY.equals(e.getCurCode()))
|
|
|
- .map(FeeCenter::getAmount).reduce(BigDecimal.ZERO, BigDecimal::add);
|
|
|
- amountDrUsd = amendFeeCenterList.stream().filter(e -> MagicValues.D.equals(e.getDc()) && MagicValues.USD.equals(e.getCurCode()))
|
|
|
- .map(FeeCenter::getAmount).reduce(BigDecimal.ZERO, BigDecimal::add);
|
|
|
- amountCrUsd = amendFeeCenterList.stream().filter(e -> MagicValues.C.equals(e.getDc()) && MagicValues.USD.equals(e.getCurCode()))
|
|
|
- .map(FeeCenter::getAmount).reduce(BigDecimal.ZERO, BigDecimal::add);
|
|
|
- }
|
|
|
- bills.setAmountProfitUpdate(bills.getAmountProfit().add(amountDr.subtract(amountCr)));
|
|
|
- bills.setAmountProfitUsdUpdate(bills.getAmountProfitUsd().add(amountDrUsd.subtract(amountCrUsd)));
|
|
|
- BigDecimal amountDrCny = ibCurrencyService.converterCny(MagicValues.USD, amountDrUsd, MagicValues.D);
|
|
|
- BigDecimal amountCrCny = ibCurrencyService.converterCny(MagicValues.USD, amountCrUsd, MagicValues.C);
|
|
|
- bills.setAmountProfitLocUpdate(bills.getAmountProfitLoc().add(amountDr.subtract(amountCr)).add(amountDrCny.subtract(amountCrCny)));
|
|
|
- bills.setResponsibleParty(amends.getResponsibleParty());
|
|
|
- bills.setAmountDrLoc(bills.getAmountDrLoc().add(amountDr).add(ibCurrencyService.converterCny(MagicValues.USD, amountDrUsd, MagicValues.D)));
|
|
|
- if (ObjectUtils.isNotNull(bills.getAmountProfitLocUpdate()) && ObjectUtils.isNotNull(bills.getAmountDrLoc())) {
|
|
|
- if (bills.getAmountProfitLocUpdate().compareTo(new BigDecimal(MagicValues.ZERO)) == 0 ||
|
|
|
- bills.getAmountDrLoc().compareTo(new BigDecimal(MagicValues.ZERO)) == 0) {
|
|
|
- bills.setGrossMargin(new BigDecimal(MagicValues.ZERO));
|
|
|
- } else {
|
|
|
- bills.setGrossMargin(bills.getAmountProfitLocUpdate().divide(bills.getAmountDrLoc(), 4, BigDecimal.ROUND_HALF_UP));
|
|
|
- }
|
|
|
- } else {
|
|
|
- bills.setGrossMargin(new BigDecimal(MagicValues.ZERO));
|
|
|
- }
|
|
|
- if (ObjectUtils.isNotNull(profitMargin)) {
|
|
|
- BigDecimal margin = new BigDecimal(profitMargin).divide(new BigDecimal(MagicValues.HUNDRED), 2);
|
|
|
- if (margin.compareTo(bills.getGrossMargin()) > 0) {
|
|
|
- bills.setProfitMargin("Profit was low!");
|
|
|
- } else {
|
|
|
- bills.setProfitMargin("");
|
|
|
- }
|
|
|
- } else {
|
|
|
- bills.setProfitMargin("");
|
|
|
- }
|
|
|
List<Bills> billsList = billsService.list(new LambdaQueryWrapper<Bills>()
|
|
|
.eq(Bills::getMasterId, bills.getId())
|
|
|
.eq(Bills::getTenantId, AuthUtil.getTenantId())
|
|
|
@@ -1246,18 +1206,14 @@ public class ReportsServiceImpl extends ServiceImpl<ReportsMapper, Reports> impl
|
|
|
.eq(FeeCenter::getIsDeleted, 0));
|
|
|
feeCenterListMh.stream().filter(e -> ObjectUtils.isNull(e.getReportType())).forEach(e -> e.setReportType("0"));
|
|
|
for (Bills item : billsList) {
|
|
|
- if (ids.contains(amends.getOrigId())) {
|
|
|
- List<FeeCenter> amendFeeCenterMm = amendFeeCenterList.stream().filter(e -> e.getPid().equals(amends.getId())).collect(Collectors.toList());
|
|
|
- for (FeeCenter feeCenter : amendFeeCenterMm) {
|
|
|
+ for (FeeCenter feeCenter : amendFeeCenterList) {
|
|
|
+ if (feeCenter.getPid().equals(amends.getId())) {
|
|
|
feeCenter.setReportType(MagicValues.ONE);
|
|
|
+ } else {
|
|
|
+ feeCenter.setReportType(MagicValues.TWO);
|
|
|
}
|
|
|
- feeCenterListMh.addAll(amendFeeCenterMm);
|
|
|
- } else {
|
|
|
- List<Amends> amend = amendsList.stream().filter(e -> e.getOrigId().equals(item.getId())).collect(Collectors.toList());
|
|
|
- List<Long> amendIds = amend.stream().map(Amends::getId).collect(Collectors.toList());
|
|
|
- List<FeeCenter> amendFeeCenterMh = amendFeeCenterList.stream().filter(e -> amendIds.contains(e.getPid())).collect(Collectors.toList());
|
|
|
- feeCenterListMh.addAll(amendFeeCenterMh);
|
|
|
}
|
|
|
+ feeCenterListMh.addAll(amendFeeCenterList);
|
|
|
List<FeeCenter> feeCenterList = feeCenterListMh.stream()
|
|
|
.collect(Collectors.collectingAndThen(Collectors.toCollection(() -> new TreeSet<>(
|
|
|
Comparator.comparing(f -> f.getFeeId() + f.getCorpId() + f.getCurCode() + f.getReportType()))), ArrayList::new));
|
|
|
@@ -1292,6 +1248,27 @@ public class ReportsServiceImpl extends ServiceImpl<ReportsMapper, Reports> impl
|
|
|
e.getFeeId().equals(fee.getFeeId()) && MagicValues.USD.equals(e.getCurCode()) && fee.getCurCode().equals(e.getCurCode()) &&
|
|
|
e.getCorpId().equals(fee.getCorpId()) && e.getReportType().equals(fee.getReportType()))
|
|
|
.collect(Collectors.toList());
|
|
|
+ } else if (MagicValues.TWO.equals(fee.getReportType())) {
|
|
|
+ feeCenterListD = feeCenterList.stream()
|
|
|
+ .filter(e -> MagicValues.D.equals(e.getDc()) && !e.getPid().equals(amends.getId()) && !e.getPid().equals(item.getId()) &&
|
|
|
+ e.getFeeId().equals(fee.getFeeId()) && MagicValues.CNY.equals(e.getCurCode()) && fee.getCurCode().equals(e.getCurCode()) &&
|
|
|
+ e.getCorpId().equals(fee.getCorpId()) && e.getReportType().equals(fee.getReportType()))
|
|
|
+ .collect(Collectors.toList());
|
|
|
+ feeCenterListUsdD = feeCenterList.stream()
|
|
|
+ .filter(e -> MagicValues.D.equals(e.getDc()) && !e.getPid().equals(amends.getId()) && !e.getPid().equals(item.getId()) &&
|
|
|
+ e.getFeeId().equals(fee.getFeeId()) && MagicValues.USD.equals(e.getCurCode()) && fee.getCurCode().equals(e.getCurCode()) &&
|
|
|
+ e.getCorpId().equals(fee.getCorpId()) && e.getReportType().equals(fee.getReportType()))
|
|
|
+ .collect(Collectors.toList());
|
|
|
+ feeCenterListC = feeCenterList.stream()
|
|
|
+ .filter(e -> MagicValues.C.equals(e.getDc()) && !e.getPid().equals(amends.getId()) && !e.getPid().equals(item.getId()) &&
|
|
|
+ e.getFeeId().equals(fee.getFeeId()) && MagicValues.CNY.equals(e.getCurCode()) && fee.getCurCode().equals(e.getCurCode()) &&
|
|
|
+ e.getCorpId().equals(fee.getCorpId()) && e.getReportType().equals(fee.getReportType()))
|
|
|
+ .collect(Collectors.toList());
|
|
|
+ feeCenterListUsdC = feeCenterList.stream()
|
|
|
+ .filter(e -> MagicValues.C.equals(e.getDc()) && !e.getPid().equals(amends.getId()) && !e.getPid().equals(item.getId()) &&
|
|
|
+ e.getFeeId().equals(fee.getFeeId()) && MagicValues.USD.equals(e.getCurCode()) && fee.getCurCode().equals(e.getCurCode()) &&
|
|
|
+ e.getCorpId().equals(fee.getCorpId()) && e.getReportType().equals(fee.getReportType()))
|
|
|
+ .collect(Collectors.toList());
|
|
|
} else {
|
|
|
feeCenterListD = feeCenterListMh.stream()
|
|
|
.filter(e -> MagicValues.D.equals(e.getDc()) && e.getPid().equals(item.getId()) &&
|
|
|
@@ -1377,18 +1354,14 @@ public class ReportsServiceImpl extends ServiceImpl<ReportsMapper, Reports> impl
|
|
|
.eq(FeeCenter::getPid, bills.getId())
|
|
|
.eq(FeeCenter::getTenantId, AuthUtil.getTenantId())
|
|
|
.eq(FeeCenter::getIsDeleted, 0));
|
|
|
- if (bills.getId().equals(amends.getOrigId())) {
|
|
|
- List<FeeCenter> amendFeeCenterMm = amendFeeCenterList.stream().filter(e -> e.getPid().equals(amends.getId())).collect(Collectors.toList());
|
|
|
- for (FeeCenter feeCenter : amendFeeCenterMm) {
|
|
|
+ for (FeeCenter feeCenter : amendFeeCenterList) {
|
|
|
+ if (feeCenter.getPid().equals(amends.getId())) {
|
|
|
feeCenter.setReportType(MagicValues.ONE);
|
|
|
+ } else {
|
|
|
+ feeCenter.setReportType(MagicValues.TWO);
|
|
|
}
|
|
|
- feeCenterList.addAll(amendFeeCenterMm);
|
|
|
- } else {
|
|
|
- List<Amends> amend = amendsList.stream().filter(e -> e.getOrigId().equals(bills.getId())).collect(Collectors.toList());
|
|
|
- List<Long> amendIds = amend.stream().map(Amends::getId).collect(Collectors.toList());
|
|
|
- List<FeeCenter> amendFeeCenterMh = amendFeeCenterList.stream().filter(e -> amendIds.contains(e.getPid())).collect(Collectors.toList());
|
|
|
- feeCenterList.addAll(amendFeeCenterMh);
|
|
|
}
|
|
|
+ feeCenterList.addAll(amendFeeCenterList);
|
|
|
if (feeCenterList.size() > 0) {
|
|
|
feeCenterList.stream().filter(e -> ObjectUtils.isNull(e.getReportType())).forEach(e -> e.setReportType("0"));
|
|
|
List<FeeCenter> feeCenters = feeCenterList.stream()
|
|
|
@@ -1399,7 +1372,6 @@ public class ReportsServiceImpl extends ServiceImpl<ReportsMapper, Reports> impl
|
|
|
FeeCenterReports feeCenterReports = new FeeCenterReports();
|
|
|
feeCenterReports.setPid(bills.getId());
|
|
|
feeCenterReports.setFeeCnName(fee.getFeeCnName());
|
|
|
- feeCenterReports.setDc(fee.getDc());
|
|
|
feeCenterReports.setReportType(fee.getReportType());
|
|
|
List<FeeCenter> feeCenterListD;
|
|
|
List<FeeCenter> feeCenterListUsdD;
|
|
|
@@ -1426,6 +1398,27 @@ public class ReportsServiceImpl extends ServiceImpl<ReportsMapper, Reports> impl
|
|
|
e.getFeeId().equals(fee.getFeeId()) && MagicValues.USD.equals(e.getCurCode()) && fee.getCurCode().equals(e.getCurCode()) &&
|
|
|
e.getCorpId().equals(fee.getCorpId()) && e.getReportType().equals(fee.getReportType()))
|
|
|
.collect(Collectors.toList());
|
|
|
+ } else if (MagicValues.TWO.equals(fee.getReportType())) {
|
|
|
+ feeCenterListD = feeCenterList.stream()
|
|
|
+ .filter(e -> MagicValues.D.equals(e.getDc()) && !e.getPid().equals(amends.getId()) && !e.getPid().equals(bills.getId()) &&
|
|
|
+ e.getFeeId().equals(fee.getFeeId()) && MagicValues.CNY.equals(e.getCurCode()) && fee.getCurCode().equals(e.getCurCode()) &&
|
|
|
+ e.getCorpId().equals(fee.getCorpId()) && e.getReportType().equals(fee.getReportType()))
|
|
|
+ .collect(Collectors.toList());
|
|
|
+ feeCenterListUsdD = feeCenterList.stream()
|
|
|
+ .filter(e -> MagicValues.D.equals(e.getDc()) && !e.getPid().equals(amends.getId()) && !e.getPid().equals(bills.getId()) &&
|
|
|
+ e.getFeeId().equals(fee.getFeeId()) && MagicValues.USD.equals(e.getCurCode()) && fee.getCurCode().equals(e.getCurCode()) &&
|
|
|
+ e.getCorpId().equals(fee.getCorpId()) && e.getReportType().equals(fee.getReportType()))
|
|
|
+ .collect(Collectors.toList());
|
|
|
+ feeCenterListC = feeCenterList.stream()
|
|
|
+ .filter(e -> MagicValues.C.equals(e.getDc()) && !e.getPid().equals(amends.getId()) && !e.getPid().equals(bills.getId()) &&
|
|
|
+ e.getFeeId().equals(fee.getFeeId()) && MagicValues.CNY.equals(e.getCurCode()) && fee.getCurCode().equals(e.getCurCode()) &&
|
|
|
+ e.getCorpId().equals(fee.getCorpId()) && e.getReportType().equals(fee.getReportType()))
|
|
|
+ .collect(Collectors.toList());
|
|
|
+ feeCenterListUsdC = feeCenterList.stream()
|
|
|
+ .filter(e -> MagicValues.C.equals(e.getDc()) && !e.getPid().equals(amends.getId()) && !e.getPid().equals(bills.getId()) &&
|
|
|
+ e.getFeeId().equals(fee.getFeeId()) && MagicValues.USD.equals(e.getCurCode()) && fee.getCurCode().equals(e.getCurCode()) &&
|
|
|
+ e.getCorpId().equals(fee.getCorpId()) && e.getReportType().equals(fee.getReportType()))
|
|
|
+ .collect(Collectors.toList());
|
|
|
} else {
|
|
|
feeCenterListD = feeCenterList.stream()
|
|
|
.filter(e -> MagicValues.D.equals(e.getDc()) && e.getPid().equals(bills.getId()) &&
|
|
|
@@ -1448,6 +1441,8 @@ public class ReportsServiceImpl extends ServiceImpl<ReportsMapper, Reports> impl
|
|
|
e.getCorpId().equals(fee.getCorpId()) && e.getReportType().equals(fee.getReportType()))
|
|
|
.collect(Collectors.toList());
|
|
|
}
|
|
|
+ feeCenterReports.setDc(fee.getDc());
|
|
|
+
|
|
|
if (feeCenterListD.size() > 0) {
|
|
|
BCorps bCorps = bCorpsList.stream().filter(e -> e.getId().equals(fee.getCorpId())).findFirst().orElse(null);
|
|
|
if (bCorps != null && ObjectUtils.isNotNull(bCorps.getShortName())) {
|
|
|
@@ -1507,63 +1502,18 @@ public class ReportsServiceImpl extends ServiceImpl<ReportsMapper, Reports> impl
|
|
|
.eq(Bills::getTenantId, AuthUtil.getTenantId())
|
|
|
.eq(Bills::getIsDeleted, 0));
|
|
|
if (details != null) {
|
|
|
- BigDecimal amountDr = new BigDecimal(MagicValues.ZERO);
|
|
|
- BigDecimal amountCr = new BigDecimal(MagicValues.ZERO);
|
|
|
- BigDecimal amountDrUsd = new BigDecimal(MagicValues.ZERO);
|
|
|
- BigDecimal amountCrUsd = new BigDecimal(MagicValues.ZERO);
|
|
|
- if (amendFeeCenterList.size() > 0) {
|
|
|
- amountDr = amendFeeCenterList.stream().filter(e -> MagicValues.D.equals(e.getDc()) && MagicValues.CNY.equals(e.getCurCode()))
|
|
|
- .map(FeeCenter::getAmount).reduce(BigDecimal.ZERO, BigDecimal::add);
|
|
|
- amountCr = amendFeeCenterList.stream().filter(e -> MagicValues.C.equals(e.getDc()) && MagicValues.CNY.equals(e.getCurCode()))
|
|
|
- .map(FeeCenter::getAmount).reduce(BigDecimal.ZERO, BigDecimal::add);
|
|
|
- amountDrUsd = amendFeeCenterList.stream().filter(e -> MagicValues.D.equals(e.getDc()) && MagicValues.USD.equals(e.getCurCode()))
|
|
|
- .map(FeeCenter::getAmount).reduce(BigDecimal.ZERO, BigDecimal::add);
|
|
|
- amountCrUsd = amendFeeCenterList.stream().filter(e -> MagicValues.C.equals(e.getDc()) && MagicValues.USD.equals(e.getCurCode()))
|
|
|
- .map(FeeCenter::getAmount).reduce(BigDecimal.ZERO, BigDecimal::add);
|
|
|
- }
|
|
|
- details.setAmountProfitUpdate(details.getAmountProfit().add(amountDr.subtract(amountCr)));
|
|
|
- details.setAmountProfitUsdUpdate(details.getAmountProfitUsd().add(amountDrUsd.subtract(amountCrUsd)));
|
|
|
- BigDecimal amountDrCny = ibCurrencyService.converterCny(MagicValues.USD, amountDrUsd, MagicValues.D);
|
|
|
- BigDecimal amountCrCny = ibCurrencyService.converterCny(MagicValues.USD, amountCrUsd, MagicValues.C);
|
|
|
- details.setAmountProfitLocUpdate(details.getAmountProfitLoc().add(amountDr.subtract(amountCr)).add(amountDrCny.subtract(amountCrCny)));
|
|
|
- details.setResponsibleParty(amends.getResponsibleParty());
|
|
|
- details.setAmountDrLoc(details.getAmountDrLoc().add(amountDr).add(ibCurrencyService.converterCny(MagicValues.USD, amountDrUsd, MagicValues.D)));
|
|
|
- if (ObjectUtils.isNotNull(details.getAmountProfitLocUpdate()) && ObjectUtils.isNotNull(details.getAmountDrLoc())) {
|
|
|
- if (details.getAmountProfitLocUpdate().compareTo(new BigDecimal(MagicValues.ZERO)) == 0 ||
|
|
|
- details.getAmountDrLoc().compareTo(new BigDecimal(MagicValues.ZERO)) == 0) {
|
|
|
- details.setGrossMargin(new BigDecimal(MagicValues.ZERO));
|
|
|
- } else {
|
|
|
- details.setGrossMargin(details.getAmountProfitLocUpdate().divide(details.getAmountDrLoc(), 4, BigDecimal.ROUND_HALF_UP));
|
|
|
- }
|
|
|
- } else {
|
|
|
- details.setGrossMargin(new BigDecimal(MagicValues.ZERO));
|
|
|
- }
|
|
|
- if (ObjectUtils.isNotNull(profitMargin)) {
|
|
|
- BigDecimal margin = new BigDecimal(profitMargin).divide(new BigDecimal(MagicValues.HUNDRED), 2);
|
|
|
- if (margin.compareTo(details.getGrossMargin()) > 0) {
|
|
|
- details.setProfitMargin("Profit was low!");
|
|
|
- } else {
|
|
|
- details.setProfitMargin("");
|
|
|
- }
|
|
|
- } else {
|
|
|
- details.setProfitMargin("");
|
|
|
- }
|
|
|
List<FeeCenter> feeCenterList = feeCenterService.list(new LambdaQueryWrapper<FeeCenter>()
|
|
|
.eq(FeeCenter::getPid, bills.getId())
|
|
|
.eq(FeeCenter::getTenantId, AuthUtil.getTenantId())
|
|
|
.eq(FeeCenter::getIsDeleted, 0));
|
|
|
- if (bills.getId().equals(amends.getOrigId())) {
|
|
|
- List<FeeCenter> amendFeeCenterMm = amendFeeCenterList.stream().filter(e -> e.getPid().equals(amends.getId())).collect(Collectors.toList());
|
|
|
- for (FeeCenter feeCenter : amendFeeCenterMm) {
|
|
|
+ for (FeeCenter feeCenter : amendFeeCenterList) {
|
|
|
+ if (feeCenter.getPid().equals(amends.getId())) {
|
|
|
feeCenter.setReportType(MagicValues.ONE);
|
|
|
+ } else {
|
|
|
+ feeCenter.setReportType(MagicValues.TWO);
|
|
|
}
|
|
|
- feeCenterList.addAll(amendFeeCenterMm);
|
|
|
- } else {
|
|
|
- List<Amends> amend = amendsList.stream().filter(e -> e.getOrigId().equals(bills.getId())).collect(Collectors.toList());
|
|
|
- List<Long> amendIds = amend.stream().map(Amends::getId).collect(Collectors.toList());
|
|
|
- List<FeeCenter> amendFeeCenterMh = amendFeeCenterList.stream().filter(e -> amendIds.contains(e.getPid())).collect(Collectors.toList());
|
|
|
- feeCenterList.addAll(amendFeeCenterMh);
|
|
|
}
|
|
|
+ feeCenterList.addAll(amendFeeCenterList);
|
|
|
if (feeCenterList.size() > 0) {
|
|
|
feeCenterList.stream().filter(e -> ObjectUtils.isNull(e.getReportType())).forEach(e -> e.setReportType("0"));
|
|
|
List<FeeCenter> feeCenters = feeCenterList.stream()
|
|
|
@@ -1601,6 +1551,27 @@ public class ReportsServiceImpl extends ServiceImpl<ReportsMapper, Reports> impl
|
|
|
e.getFeeId().equals(fee.getFeeId()) && MagicValues.USD.equals(e.getCurCode()) && fee.getCurCode().equals(e.getCurCode()) &&
|
|
|
e.getCorpId().equals(fee.getCorpId()) && e.getReportType().equals(fee.getReportType()))
|
|
|
.collect(Collectors.toList());
|
|
|
+ } else if (MagicValues.TWO.equals(fee.getReportType())) {
|
|
|
+ feeCenterListD = feeCenterList.stream()
|
|
|
+ .filter(e -> MagicValues.D.equals(e.getDc()) && !e.getPid().equals(amends.getId()) && !e.getPid().equals(bills.getId()) &&
|
|
|
+ e.getFeeId().equals(fee.getFeeId()) && MagicValues.CNY.equals(e.getCurCode()) && fee.getCurCode().equals(e.getCurCode()) &&
|
|
|
+ e.getCorpId().equals(fee.getCorpId()) && e.getReportType().equals(fee.getReportType()))
|
|
|
+ .collect(Collectors.toList());
|
|
|
+ feeCenterListUsdD = feeCenterList.stream()
|
|
|
+ .filter(e -> MagicValues.D.equals(e.getDc()) && !e.getPid().equals(amends.getId()) && !e.getPid().equals(bills.getId()) &&
|
|
|
+ e.getFeeId().equals(fee.getFeeId()) && MagicValues.USD.equals(e.getCurCode()) && fee.getCurCode().equals(e.getCurCode()) &&
|
|
|
+ e.getCorpId().equals(fee.getCorpId()) && e.getReportType().equals(fee.getReportType()))
|
|
|
+ .collect(Collectors.toList());
|
|
|
+ feeCenterListC = feeCenterList.stream()
|
|
|
+ .filter(e -> MagicValues.C.equals(e.getDc()) && !e.getPid().equals(amends.getId()) && !e.getPid().equals(bills.getId()) &&
|
|
|
+ e.getFeeId().equals(fee.getFeeId()) && MagicValues.CNY.equals(e.getCurCode()) && fee.getCurCode().equals(e.getCurCode()) &&
|
|
|
+ e.getCorpId().equals(fee.getCorpId()) && e.getReportType().equals(fee.getReportType()))
|
|
|
+ .collect(Collectors.toList());
|
|
|
+ feeCenterListUsdC = feeCenterList.stream()
|
|
|
+ .filter(e -> MagicValues.C.equals(e.getDc()) && !e.getPid().equals(amends.getId()) && !e.getPid().equals(bills.getId()) &&
|
|
|
+ e.getFeeId().equals(fee.getFeeId()) && MagicValues.USD.equals(e.getCurCode()) && fee.getCurCode().equals(e.getCurCode()) &&
|
|
|
+ e.getCorpId().equals(fee.getCorpId()) && e.getReportType().equals(fee.getReportType()))
|
|
|
+ .collect(Collectors.toList());
|
|
|
} else {
|
|
|
feeCenterListD = feeCenterList.stream()
|
|
|
.filter(e -> MagicValues.D.equals(e.getDc()) && e.getPid().equals(bills.getId()) &&
|
|
|
@@ -1685,18 +1656,14 @@ public class ReportsServiceImpl extends ServiceImpl<ReportsMapper, Reports> impl
|
|
|
.eq(FeeCenter::getTenantId, AuthUtil.getTenantId())
|
|
|
.eq(FeeCenter::getIsDeleted, 0));
|
|
|
feeCenterListMh.stream().filter(e -> ObjectUtils.isNull(e.getReportType())).forEach(e -> e.setReportType("0"));
|
|
|
- if (details.getId().equals(amends.getOrigId())) {
|
|
|
- List<FeeCenter> amendFeeCenterMm = amendFeeCenterList.stream().filter(e -> e.getPid().equals(amends.getId())).collect(Collectors.toList());
|
|
|
- for (FeeCenter feeCenter : amendFeeCenterMm) {
|
|
|
+ for (FeeCenter feeCenter : amendFeeCenterList) {
|
|
|
+ if (feeCenter.getPid().equals(amends.getId())) {
|
|
|
feeCenter.setReportType(MagicValues.ONE);
|
|
|
+ } else {
|
|
|
+ feeCenter.setReportType(MagicValues.TWO);
|
|
|
}
|
|
|
- feeCenterListMh.addAll(amendFeeCenterMm);
|
|
|
- } else {
|
|
|
- List<Amends> amend = amendsList.stream().filter(e -> e.getOrigId().equals(details.getId())).collect(Collectors.toList());
|
|
|
- List<Long> amendIds = amend.stream().map(Amends::getId).collect(Collectors.toList());
|
|
|
- List<FeeCenter> amendFeeCenterMh = amendFeeCenterList.stream().filter(e -> amendIds.contains(e.getPid())).collect(Collectors.toList());
|
|
|
- feeCenterListMh.addAll(amendFeeCenterMh);
|
|
|
}
|
|
|
+ feeCenterListMh.addAll(amendFeeCenterList);
|
|
|
List<FeeCenter> feeCenterList1 = feeCenterListMh.stream()
|
|
|
.collect(Collectors.collectingAndThen(Collectors.toCollection(() -> new TreeSet<>(
|
|
|
Comparator.comparing(f -> f.getFeeId() + f.getCorpId() + f.getCurCode() + f.getReportType()))), ArrayList::new));
|
|
|
@@ -1732,6 +1699,27 @@ public class ReportsServiceImpl extends ServiceImpl<ReportsMapper, Reports> impl
|
|
|
e.getFeeId().equals(fee.getFeeId()) && MagicValues.USD.equals(e.getCurCode()) && fee.getCurCode().equals(e.getCurCode()) &&
|
|
|
e.getCorpId().equals(fee.getCorpId()) && e.getReportType().equals(fee.getReportType()))
|
|
|
.collect(Collectors.toList());
|
|
|
+ } else if (MagicValues.TWO.equals(fee.getReportType())) {
|
|
|
+ feeCenterListD = feeCenterList.stream()
|
|
|
+ .filter(e -> MagicValues.D.equals(e.getDc()) && !e.getPid().equals(amends.getId()) && !e.getPid().equals(details.getId()) &&
|
|
|
+ e.getFeeId().equals(fee.getFeeId()) && MagicValues.CNY.equals(e.getCurCode()) && fee.getCurCode().equals(e.getCurCode()) &&
|
|
|
+ e.getCorpId().equals(fee.getCorpId()) && e.getReportType().equals(fee.getReportType()))
|
|
|
+ .collect(Collectors.toList());
|
|
|
+ feeCenterListUsdD = feeCenterList.stream()
|
|
|
+ .filter(e -> MagicValues.D.equals(e.getDc()) && !e.getPid().equals(amends.getId()) && !e.getPid().equals(details.getId()) &&
|
|
|
+ e.getFeeId().equals(fee.getFeeId()) && MagicValues.USD.equals(e.getCurCode()) && fee.getCurCode().equals(e.getCurCode()) &&
|
|
|
+ e.getCorpId().equals(fee.getCorpId()) && e.getReportType().equals(fee.getReportType()))
|
|
|
+ .collect(Collectors.toList());
|
|
|
+ feeCenterListC = feeCenterList.stream()
|
|
|
+ .filter(e -> MagicValues.C.equals(e.getDc()) && !e.getPid().equals(amends.getId()) && !e.getPid().equals(details.getId()) &&
|
|
|
+ e.getFeeId().equals(fee.getFeeId()) && MagicValues.CNY.equals(e.getCurCode()) && fee.getCurCode().equals(e.getCurCode()) &&
|
|
|
+ e.getCorpId().equals(fee.getCorpId()) && e.getReportType().equals(fee.getReportType()))
|
|
|
+ .collect(Collectors.toList());
|
|
|
+ feeCenterListUsdC = feeCenterList.stream()
|
|
|
+ .filter(e -> MagicValues.C.equals(e.getDc()) && !e.getPid().equals(amends.getId()) && !e.getPid().equals(details.getId()) &&
|
|
|
+ e.getFeeId().equals(fee.getFeeId()) && MagicValues.USD.equals(e.getCurCode()) && fee.getCurCode().equals(e.getCurCode()) &&
|
|
|
+ e.getCorpId().equals(fee.getCorpId()) && e.getReportType().equals(fee.getReportType()))
|
|
|
+ .collect(Collectors.toList());
|
|
|
} else {
|
|
|
feeCenterListD = feeCenterListMh.stream()
|
|
|
.filter(e -> MagicValues.D.equals(e.getDc()) && e.getPid().equals(details.getId()) &&
|
|
|
@@ -1815,17 +1803,29 @@ public class ReportsServiceImpl extends ServiceImpl<ReportsMapper, Reports> impl
|
|
|
if (list.size() > 0) {
|
|
|
for (Bills item : list) {
|
|
|
List<FeeCenterReports> feeCenterReports = new ArrayList<>();
|
|
|
- List<FeeCenterReports> feeCenterReportsList = item.getFeeCenterList().stream().filter(e -> !MagicValues.ONE.equals(e.getReportType())).collect(Collectors.toList());
|
|
|
+ List<FeeCenterReports> feeCenterReportsList = item.getFeeCenterList().stream().filter(e -> !MagicValues.ONE.equals(e.getReportType()) && !MagicValues.TWO.equals(e.getReportType())).collect(Collectors.toList());
|
|
|
List<FeeCenterReports> feeCenterReportsList1 = item.getFeeCenterList().stream().filter(e -> MagicValues.ONE.equals(e.getReportType())).collect(Collectors.toList());
|
|
|
+ List<FeeCenterReports> feeCenterReportsList2 = item.getFeeCenterList().stream().filter(e -> MagicValues.TWO.equals(e.getReportType())).collect(Collectors.toList());
|
|
|
List<FeeCenterReports> feeCenters = feeCenterReportsList.stream()
|
|
|
.collect(Collectors.collectingAndThen(Collectors.toCollection(() -> new TreeSet<>(
|
|
|
Comparator.comparing(FeeCenterReports::getFeeCnName))), ArrayList::new));
|
|
|
+ List<FeeCenterReports> feeCenters1 = feeCenterReportsList1.stream()
|
|
|
+ .collect(Collectors.collectingAndThen(Collectors.toCollection(() -> new TreeSet<>(
|
|
|
+ Comparator.comparing(FeeCenterReports::getFeeCnName))), ArrayList::new));
|
|
|
+ List<FeeCenterReports> feeCenters2 = feeCenterReportsList2.stream()
|
|
|
+ .collect(Collectors.collectingAndThen(Collectors.toCollection(() -> new TreeSet<>(
|
|
|
+ Comparator.comparing(FeeCenterReports::getFeeCnName))), ArrayList::new));
|
|
|
+ BigDecimal amountDr = new BigDecimal("0.00");
|
|
|
+ BigDecimal amountCr = new BigDecimal("0.00");
|
|
|
+ BigDecimal amountDrUsd = new BigDecimal("0.00");
|
|
|
+ BigDecimal amountCrUsd = new BigDecimal("0.00");
|
|
|
+ BigDecimal amountDrUpdate = new BigDecimal("0.00");
|
|
|
+ BigDecimal amountCrUpdate = new BigDecimal("0.00");
|
|
|
+ BigDecimal amountDrUsdUpdate = new BigDecimal("0.00");
|
|
|
+ BigDecimal amountCrUsdUpdate = new BigDecimal("0.00");
|
|
|
for (FeeCenterReports fee : feeCenters) {
|
|
|
- FeeCenterReports feeCenterReportsD = item.getFeeCenterList().stream()
|
|
|
- .filter(e -> e.getFeeCnName().equals(fee.getFeeCnName()) && MagicValues.D.equals(e.getDc()))
|
|
|
- .findFirst().orElse(null);
|
|
|
- FeeCenterReports feeCenterReportsC = item.getFeeCenterList().stream()
|
|
|
- .filter(e -> e.getFeeCnName().equals(fee.getFeeCnName()) && MagicValues.C.equals(e.getDc()))
|
|
|
+ FeeCenterReports feeReports = item.getFeeCenterList().stream()
|
|
|
+ .filter(e -> e.getFeeCnName().equals(fee.getFeeCnName()))
|
|
|
.findFirst().orElse(null);
|
|
|
FeeCenterReports feeCenterReports1 = new FeeCenterReports();
|
|
|
feeCenterReports1.setFeeCnName(fee.getFeeCnName());
|
|
|
@@ -1833,41 +1833,139 @@ public class ReportsServiceImpl extends ServiceImpl<ReportsMapper, Reports> impl
|
|
|
feeCenterReports1.setPid(fee.getPid());
|
|
|
feeCenterReports1.setReportType(fee.getReportType());
|
|
|
feeCenterReports1.setDc(fee.getDc());
|
|
|
- if (feeCenterReportsD != null) {
|
|
|
- feeCenterReports1.setBillCorpCnName(feeCenterReportsD.getBillCorpCnName());
|
|
|
- feeCenterReports1.setAmountD(feeCenterReportsD.getAmountD());
|
|
|
- feeCenterReports1.setAmountLocD(feeCenterReportsD.getAmountLocD());
|
|
|
- feeCenterReports1.setAmountUsdD(feeCenterReportsD.getAmountUsdD());
|
|
|
- }
|
|
|
- if (feeCenterReportsC != null) {
|
|
|
- feeCenterReports1.setCorpCnName(feeCenterReportsC.getCorpCnName());
|
|
|
- feeCenterReports1.setAmountC(feeCenterReportsC.getAmountC());
|
|
|
- feeCenterReports1.setAmountLocC(feeCenterReportsC.getAmountLocC());
|
|
|
- feeCenterReports1.setAmountUsdC(feeCenterReportsC.getAmountUsdC());
|
|
|
+ if (feeReports != null) {
|
|
|
+ if ((ObjectUtils.isNotNull(feeReports.getAmountD()) && feeReports.getAmountD().compareTo(new BigDecimal("0.00")) != 0)
|
|
|
+ || (ObjectUtils.isNotNull(feeReports.getAmountUsdD()) && feeReports.getAmountUsdD().compareTo(new BigDecimal("0.00")) != 0)
|
|
|
+ ) {
|
|
|
+ feeCenterReports1.setBillCorpCnName(feeReports.getBillCorpCnName());
|
|
|
+ feeCenterReports1.setAmountD(feeReports.getAmountD());
|
|
|
+ feeCenterReports1.setAmountLocD(feeReports.getAmountLocD());
|
|
|
+ feeCenterReports1.setAmountUsdD(feeReports.getAmountUsdD());
|
|
|
+ amountDr = amountDr.add(ObjectUtils.isNotNull(feeReports.getAmountD()) ? feeReports.getAmountD() : new BigDecimal("0.00"));
|
|
|
+ amountDrUsd = amountDrUsd.add(ObjectUtils.isNotNull(feeReports.getAmountUsdD()) ? feeReports.getAmountUsdD() : new BigDecimal("0.00"));
|
|
|
+ }
|
|
|
+ if ((ObjectUtils.isNotNull(feeReports.getAmountC()) && feeReports.getAmountC().compareTo(new BigDecimal("0.00")) != 0)
|
|
|
+ || (ObjectUtils.isNotNull(feeReports.getAmountUsdC()) && feeReports.getAmountUsdC().compareTo(new BigDecimal("0.00")) != 0)
|
|
|
+ ) {
|
|
|
+ feeCenterReports1.setCorpCnName(feeReports.getCorpCnName());
|
|
|
+ feeCenterReports1.setAmountC(feeReports.getAmountC());
|
|
|
+ feeCenterReports1.setAmountLocC(feeReports.getAmountLocC());
|
|
|
+ feeCenterReports1.setAmountUsdC(feeReports.getAmountUsdC());
|
|
|
+ amountCr = amountCr.add(ObjectUtils.isNotNull(feeReports.getAmountC()) ? feeReports.getAmountC() : new BigDecimal("0.00"));
|
|
|
+ amountCrUsd = amountCrUsd.add(ObjectUtils.isNotNull(feeReports.getAmountUsdC()) ? feeReports.getAmountUsdC() : new BigDecimal("0.00"));
|
|
|
+ }
|
|
|
}
|
|
|
feeCenterReports.add(feeCenterReports1);
|
|
|
}
|
|
|
- for (FeeCenterReports fee : feeCenterReportsList1) {
|
|
|
+ for (FeeCenterReports fee : feeCenters2) {
|
|
|
+ FeeCenterReports feeReports = feeCenterReportsList2.stream()
|
|
|
+ .filter(e -> e.getFeeCnName().equals(fee.getFeeCnName()))
|
|
|
+ .findFirst().orElse(null);
|
|
|
FeeCenterReports feeCenterReports1 = new FeeCenterReports();
|
|
|
feeCenterReports1.setFeeCnName(fee.getFeeCnName());
|
|
|
feeCenterReports1.setHblno(fee.getHblno());
|
|
|
feeCenterReports1.setPid(fee.getPid());
|
|
|
feeCenterReports1.setReportType(fee.getReportType());
|
|
|
feeCenterReports1.setDc(fee.getDc());
|
|
|
- if (MagicValues.D.equals(fee.getDc())) {
|
|
|
- feeCenterReports1.setBillCorpCnName(fee.getBillCorpCnName());
|
|
|
- feeCenterReports1.setAmountD(fee.getAmountD());
|
|
|
- feeCenterReports1.setAmountLocD(fee.getAmountLocD());
|
|
|
- feeCenterReports1.setAmountUsdD(fee.getAmountUsdD());
|
|
|
+ if (feeReports != null) {
|
|
|
+ if ((ObjectUtils.isNotNull(feeReports.getAmountD()) && feeReports.getAmountD().compareTo(new BigDecimal("0.00")) != 0)
|
|
|
+ || (ObjectUtils.isNotNull(feeReports.getAmountUsdD()) && feeReports.getAmountUsdD().compareTo(new BigDecimal("0.00")) != 0)
|
|
|
+ ) {
|
|
|
+ feeCenterReports1.setBillCorpCnName(feeReports.getBillCorpCnName());
|
|
|
+ feeCenterReports1.setAmountD(feeReports.getAmountD());
|
|
|
+ feeCenterReports1.setAmountLocD(feeReports.getAmountLocD());
|
|
|
+ feeCenterReports1.setAmountUsdD(feeReports.getAmountUsdD());
|
|
|
+ amountDr = amountDr.add(ObjectUtils.isNotNull(feeReports.getAmountD()) ? feeReports.getAmountD() : new BigDecimal("0.00"));
|
|
|
+ amountDrUsd = amountDrUsd.add(ObjectUtils.isNotNull(feeReports.getAmountUsdD()) ? feeReports.getAmountUsdD() : new BigDecimal("0.00"));
|
|
|
+ }
|
|
|
+ if ((ObjectUtils.isNotNull(feeReports.getAmountC()) && feeReports.getAmountC().compareTo(new BigDecimal("0.00")) != 0)
|
|
|
+ || (ObjectUtils.isNotNull(feeReports.getAmountUsdC()) && feeReports.getAmountUsdC().compareTo(new BigDecimal("0.00")) != 0)
|
|
|
+ ) {
|
|
|
+ feeCenterReports1.setCorpCnName(feeReports.getCorpCnName());
|
|
|
+ feeCenterReports1.setAmountC(feeReports.getAmountC());
|
|
|
+ feeCenterReports1.setAmountLocC(feeReports.getAmountLocC());
|
|
|
+ feeCenterReports1.setAmountUsdC(feeReports.getAmountUsdC());
|
|
|
+ amountCr = amountCr.add(ObjectUtils.isNotNull(feeReports.getAmountC()) ? feeReports.getAmountC() : new BigDecimal("0.00"));
|
|
|
+ amountCrUsd = amountCrUsd.add(ObjectUtils.isNotNull(feeReports.getAmountUsdC()) ? feeReports.getAmountUsdC() : new BigDecimal("0.00"));
|
|
|
+ }
|
|
|
}
|
|
|
- if (MagicValues.C.equals(fee.getDc())) {
|
|
|
- feeCenterReports1.setCorpCnName(fee.getCorpCnName());
|
|
|
- feeCenterReports1.setAmountC(fee.getAmountC());
|
|
|
- feeCenterReports1.setAmountLocC(fee.getAmountLocC());
|
|
|
- feeCenterReports1.setAmountUsdC(fee.getAmountUsdC());
|
|
|
+ feeCenterReports.add(feeCenterReports1);
|
|
|
+ }
|
|
|
+ item.setAmountProfit(amountDr.subtract(amountCr));
|
|
|
+ item.setAmountProfitUsd(amountDrUsd.subtract(amountCrUsd));
|
|
|
+ BigDecimal amountDrCny = ibCurrencyService.converterCny(MagicValues.USD, amountDrUsd, MagicValues.D);
|
|
|
+ BigDecimal amountCrCny = ibCurrencyService.converterCny(MagicValues.USD, amountCrUsd, MagicValues.C);
|
|
|
+ item.setAmountProfitLoc(amountDr.subtract(amountCr).add(amountDrCny.subtract(amountCrCny)));
|
|
|
+ for (FeeCenterReports fee : feeCenters1) {
|
|
|
+ FeeCenterReports feeReports = feeCenterReportsList1.stream()
|
|
|
+ .filter(e -> e.getFeeCnName().equals(fee.getFeeCnName()))
|
|
|
+ .findFirst().orElse(null);
|
|
|
+ FeeCenterReports feeCenterReports1 = new FeeCenterReports();
|
|
|
+ feeCenterReports1.setFeeCnName(fee.getFeeCnName());
|
|
|
+ feeCenterReports1.setHblno(fee.getHblno());
|
|
|
+ feeCenterReports1.setPid(fee.getPid());
|
|
|
+ feeCenterReports1.setReportType(fee.getReportType());
|
|
|
+ feeCenterReports1.setDc(fee.getDc());
|
|
|
+ if (feeReports != null) {
|
|
|
+ if ((ObjectUtils.isNotNull(feeReports.getAmountD()) && feeReports.getAmountD().compareTo(new BigDecimal("0.00")) != 0)
|
|
|
+ || (ObjectUtils.isNotNull(feeReports.getAmountUsdD()) && feeReports.getAmountUsdD().compareTo(new BigDecimal("0.00")) != 0)
|
|
|
+ ) {
|
|
|
+ feeCenterReports1.setBillCorpCnName(feeReports.getBillCorpCnName());
|
|
|
+ feeCenterReports1.setAmountD(feeReports.getAmountD());
|
|
|
+ feeCenterReports1.setAmountLocD(feeReports.getAmountLocD());
|
|
|
+ feeCenterReports1.setAmountUsdD(feeReports.getAmountUsdD());
|
|
|
+ amountDr = amountDr.add(ObjectUtils.isNotNull(feeReports.getAmountD()) ? feeReports.getAmountD() : new BigDecimal("0.00"));
|
|
|
+ amountDrUsd = amountDrUsd.add(ObjectUtils.isNotNull(feeReports.getAmountUsdD()) ? feeReports.getAmountUsdD() : new BigDecimal("0.00"));
|
|
|
+ }
|
|
|
+
|
|
|
+ if ((ObjectUtils.isNotNull(feeReports.getAmountC()) && feeReports.getAmountC().compareTo(new BigDecimal("0.00")) != 0)
|
|
|
+ || (ObjectUtils.isNotNull(feeReports.getAmountUsdC()) && feeReports.getAmountUsdC().compareTo(new BigDecimal("0.00")) != 0)
|
|
|
+ ) {
|
|
|
+ feeCenterReports1.setCorpCnName(feeReports.getCorpCnName());
|
|
|
+ feeCenterReports1.setAmountC(feeReports.getAmountC());
|
|
|
+ feeCenterReports1.setAmountLocC(feeReports.getAmountLocC());
|
|
|
+ feeCenterReports1.setAmountUsdC(feeReports.getAmountUsdC());
|
|
|
+ amountCr = amountCr.add(ObjectUtils.isNotNull(feeReports.getAmountC()) ? feeReports.getAmountC() : new BigDecimal("0.00"));
|
|
|
+ amountCrUsd = amountCrUsd.add(ObjectUtils.isNotNull(feeReports.getAmountUsdC()) ? feeReports.getAmountUsdC() : new BigDecimal("0.00"));
|
|
|
+ }
|
|
|
}
|
|
|
feeCenterReports.add(feeCenterReports1);
|
|
|
}
|
|
|
+
|
|
|
+ item.setAmountDr(amountDr);
|
|
|
+ item.setAmountCr(amountCr);
|
|
|
+ item.setAmountDrUsd(amountDrUsd);
|
|
|
+ item.setAmountDrUsd(amountCrUsd);
|
|
|
+ item.setAmountDrLoc(amountDr.add(ibCurrencyService.converterCny(MagicValues.USD, amountDrUsd, MagicValues.D)));
|
|
|
+ item.setAmountCrLoc(amountCr.add(ibCurrencyService.converterCny(MagicValues.USD, amountCrUsd, MagicValues.C)));
|
|
|
+ item.setAmountProfitUpdate(amountDr.subtract(amountCr));
|
|
|
+ item.setAmountProfitUsdUpdate(amountDrUsd.subtract(amountCrUsd));
|
|
|
+ BigDecimal amountDrCnyUpdate = ibCurrencyService.converterCny(MagicValues.USD, amountDrUsd, MagicValues.D);
|
|
|
+ BigDecimal amountCrCnyUpdate = ibCurrencyService.converterCny(MagicValues.USD, amountCrUsd, MagicValues.C);
|
|
|
+ item.setAmountProfitLocUpdate(amountDr.subtract(amountCr).add(amountDrCnyUpdate.subtract(amountCrCnyUpdate)));
|
|
|
+ item.setAmountProfitLocUpdate(item.getAmountProfitLocUpdate().setScale(2,BigDecimal.ROUND_HALF_UP));
|
|
|
+ item.setAmountProfitLoc(item.getAmountProfitLoc().setScale(2,BigDecimal.ROUND_HALF_UP));
|
|
|
+ item.setResponsibleParty(amends.getResponsibleParty());
|
|
|
+ if (ObjectUtils.isNotNull(item.getAmountProfitLocUpdate()) && ObjectUtils.isNotNull(item.getAmountDrLoc())) {
|
|
|
+ if (item.getAmountProfitLocUpdate().compareTo(new BigDecimal(MagicValues.ZERO)) == 0 ||
|
|
|
+ item.getAmountDrLoc().compareTo(new BigDecimal(MagicValues.ZERO)) == 0) {
|
|
|
+ item.setGrossMargin(new BigDecimal(MagicValues.ZERO));
|
|
|
+ } else {
|
|
|
+ item.setGrossMargin(item.getAmountProfitLocUpdate().divide(item.getAmountDrLoc(), 4, BigDecimal.ROUND_HALF_UP));
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ item.setGrossMargin(new BigDecimal(MagicValues.ZERO));
|
|
|
+ }
|
|
|
+ if (ObjectUtils.isNotNull(profitMargin)) {
|
|
|
+ BigDecimal margin = new BigDecimal(profitMargin).divide(new BigDecimal(MagicValues.HUNDRED), 2, RoundingMode.HALF_UP);
|
|
|
+ if (margin.compareTo(item.getGrossMargin()) > 0) {
|
|
|
+ item.setProfitMargin("Profit was low!");
|
|
|
+ } else {
|
|
|
+ item.setProfitMargin("");
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ item.setProfitMargin("");
|
|
|
+ }
|
|
|
item.setFeeCenterList(feeCenterReports);
|
|
|
}
|
|
|
}
|