| | |
| | | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; |
| | | import com.ruoyi.account.dto.AccountDto; |
| | | import com.ruoyi.account.dto.AccountDto2; |
| | | import com.ruoyi.account.dto.AccountDto3; |
| | | import com.ruoyi.account.mapper.AccountExpenseMapper; |
| | | import com.ruoyi.account.mapper.AccountFileMapper; |
| | | import com.ruoyi.account.mapper.AccountIncomeMapper; |
| | |
| | | |
| | | import javax.servlet.http.HttpServletResponse; |
| | | import java.math.BigDecimal; |
| | | import java.time.LocalDate; |
| | | import java.time.format.DateTimeFormatter; |
| | | import java.util.ArrayList; |
| | | import java.util.HashMap; |
| | | import java.util.List; |
| | | import java.util.Map; |
| | | |
| | |
| | | AccountDto accountDto = new AccountDto(); |
| | | //获取该段时间内的所有收入 |
| | | List<AccountDto2> accountIncomes =accountIncomeMapper.report(dateQueryDto); |
| | | accountDto.setIncomeType(accountIncomes); |
| | | |
| | | Long incomeNumber = accountIncomeMapper.selectCount(Wrappers.<AccountIncome>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); |
| | | accountIncomes.stream().forEach(accountDto2 -> { |
| | | accountDto2.setProportion(accountDto2.getAccount().divide(totalIncome,2,BigDecimal.ROUND_HALF_UP)); |
| | | }); |
| | | accountDto.setIncomeType(accountIncomes); |
| | | //获取该段时间内的所有支出 |
| | | List<AccountDto2> accountExpenses =accountExpenseMapper.report(dateQueryDto); |
| | | accountDto.setExpenseType(accountExpenses); |
| | |
| | | accountDto.setExpenseNumber(expenseNumber); |
| | | BigDecimal totalExpense = accountExpenses.stream().map(AccountDto2::getAccount).reduce(BigDecimal.ZERO, BigDecimal::add); |
| | | accountDto.setTotalExpense(totalExpense); |
| | | accountExpenses.stream().forEach(accountDto2 -> { |
| | | accountDto2.setProportion(accountDto2.getAccount().divide(totalExpense,2,BigDecimal.ROUND_HALF_UP)); |
| | | }); |
| | | accountDto.setExpenseType(accountExpenses); |
| | | //净收入 |
| | | BigDecimal netRevenue = totalIncome.subtract(totalExpense); |
| | | accountDto.setNetRevenue(netRevenue); |
| | | return accountDto; |
| | | } |
| | | |
| | | //财务报表年查询 |
| | | @Override |
| | | public AccountDto3 reportExpense() { |
| | | AccountDto3 accountDto3 = new AccountDto3(); |
| | | DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd"); |
| | | int currentYear = LocalDate.now().getYear(); // 获取当前年份(如2025) |
| | | List<String> months = new ArrayList<>(); |
| | | Map<String, List<AccountDto2>> map = new HashMap<>(); |
| | | for (int i = 1; i <= 12; i++) { |
| | | months.add(i + "月"); |
| | | // 当月第一天:年份为当前年,月份为i,日期为1 |
| | | LocalDate firstDay = LocalDate.of(currentYear, i, 1); |
| | | DateQueryDto dateQueryDto = new DateQueryDto(); |
| | | dateQueryDto.setEntryDateStart(firstDay.format(formatter)); |
| | | // 当月最后一天:第一天的月份的最后一天 |
| | | dateQueryDto.setEntryDateEnd(firstDay.plusMonths(1).minusDays(1).format(formatter)); |
| | | List<AccountDto2> report = accountExpenseMapper.report(dateQueryDto); |
| | | map.put(i + "月",report); |
| | | } |
| | | accountDto3.setMonth(months); |
| | | accountDto3.setAccountType(map); |
| | | return accountDto3; |
| | | } |
| | | |
| | | |
| | | } |