package com.ruoyi.account.service.impl; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.ruoyi.account.dto.AccountDto; import com.ruoyi.account.dto.AccountDto2; import com.ruoyi.account.mapper.AccountExpenseMapper; import com.ruoyi.account.mapper.AccountFileMapper; import com.ruoyi.account.mapper.AccountIncomeMapper; import com.ruoyi.account.pojo.AccountExpense; import com.ruoyi.account.pojo.AccountIncome; import com.ruoyi.account.service.AccountExpenseService; import com.ruoyi.account.service.AccountIncomeService; import com.ruoyi.common.utils.poi.ExcelUtil; import com.ruoyi.dto.DateQueryDto; import lombok.AllArgsConstructor; import org.springframework.stereotype.Service; import javax.servlet.http.HttpServletResponse; import java.math.BigDecimal; import java.util.List; import java.util.Map; @AllArgsConstructor @Service public class AccountExpenseServiceImpl extends ServiceImpl implements AccountExpenseService { private AccountExpenseMapper accountExpenseMapper; private AccountIncomeMapper accountIncomeMapper; //分页查询 @Override public IPage accountExpenseListPage(Page page, AccountExpense accountExpense) { return accountExpenseMapper.accountExpenseListPage(page,accountExpense); } //导出 @Override public void accountExpenseExport(HttpServletResponse response, AccountExpense accountExpense) { List accountExpenses =accountExpenseMapper.accountExpenseExport(accountExpense); ExcelUtil util = new ExcelUtil(AccountExpense.class); util.exportExcel(response, accountExpenses, "支出管理导出"); } //财务报表图表 @Override public AccountDto report(DateQueryDto dateQueryDto) { AccountDto accountDto = new AccountDto(); //获取该段时间内的所有收入 List accountIncomes =accountIncomeMapper.report(dateQueryDto); accountDto.setIncomeType(accountIncomes); Long incomeNumber = accountIncomeMapper.selectCount(Wrappers.lambdaQuery() .between(AccountIncome::getIncomeDate, dateQueryDto.getEntryDateStart(), dateQueryDto.getEntryDateEnd())); accountDto.setIncomeNumber(incomeNumber); BigDecimal totalIncome = accountIncomes.stream().map(AccountDto2::getAccount).reduce(BigDecimal.ZERO, BigDecimal::add); accountDto.setTotalIncome(totalIncome); //获取该段时间内的所有支出 List accountExpenses =accountExpenseMapper.report(dateQueryDto); accountDto.setExpenseType(accountExpenses); Long expenseNumber = accountExpenseMapper.selectCount(Wrappers.lambdaQuery() .between(AccountExpense::getExpenseDate, dateQueryDto.getEntryDateStart(), dateQueryDto.getEntryDateEnd())); accountDto.setExpenseNumber(expenseNumber); BigDecimal totalExpense = accountExpenses.stream().map(AccountDto2::getAccount).reduce(BigDecimal.ZERO, BigDecimal::add); accountDto.setTotalExpense(totalExpense); //净收入 BigDecimal netRevenue = totalIncome.subtract(totalExpense); accountDto.setNetRevenue(netRevenue); return accountDto; } }