Compare commits

..

No commits in common. "1ebd9cea070d23938101500454f1f16c5f1f29e5" and "411812d35b7a3afddff6afe06b843fc4a1d67afa" have entirely different histories.

4 changed files with 6 additions and 121 deletions

View File

@ -1,11 +1,8 @@
package cn.iocoder.yudao.module.bpm.controller.admin.oa; package cn.iocoder.yudao.module.bpm.controller.admin.oa;
import cn.iocoder.yudao.framework.common.pojo.CommonResult; import cn.iocoder.yudao.framework.common.pojo.CommonResult;
import cn.iocoder.yudao.framework.common.pojo.PageParam;
import cn.iocoder.yudao.framework.common.pojo.PageResult; import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.datapermission.core.annotation.DataPermission; import cn.iocoder.yudao.framework.datapermission.core.annotation.DataPermission;
import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils;
import cn.iocoder.yudao.framework.operatelog.core.annotations.OperateLog;
import cn.iocoder.yudao.module.bpm.controller.admin.oa.vo.expenses.*; import cn.iocoder.yudao.module.bpm.controller.admin.oa.vo.expenses.*;
import cn.iocoder.yudao.module.bpm.dal.dataobject.oa.BpmOAExpensesDO; import cn.iocoder.yudao.module.bpm.dal.dataobject.oa.BpmOAExpensesDO;
import cn.iocoder.yudao.module.bpm.service.oa.BpmOAExpensesService; import cn.iocoder.yudao.module.bpm.service.oa.BpmOAExpensesService;
@ -16,13 +13,9 @@ import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*; import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource; import javax.annotation.Resource;
import javax.servlet.http.HttpServletResponse;
import javax.validation.Valid; import javax.validation.Valid;
import java.io.IOException;
import java.util.List;
import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
import static cn.iocoder.yudao.framework.operatelog.core.enums.OperateTypeEnum.EXPORT;
import static cn.iocoder.yudao.framework.security.core.util.SecurityFrameworkUtils.getLoginUserId; import static cn.iocoder.yudao.framework.security.core.util.SecurityFrameworkUtils.getLoginUserId;
/** /**
@ -113,19 +106,4 @@ public class BpmOAExpensesController {
expensesService.oneClickPayment(month); expensesService.oneClickPayment(month);
return success(true); return success(true);
} }
@GetMapping("/export-excel")
@Operation(summary = "导出开支日报申请 Excel")
@DataPermission(enable = false)
@OperateLog(type = EXPORT)
public void exportExpensesExcel(@Valid BpmOAExpensesPageReqVO pageReqVO,
HttpServletResponse response) throws IOException {
pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE);
PageResult<BpmOAExpensesPageRespVO> pageResult = expensesService.getExpensesPage(pageReqVO);
//转换
List<BpmOAExpensesExportVO> list = expensesService.convertExpensesList(pageResult.getList());
// 导出 Excel
ExcelUtils.write(response, "开支日报申请.xls", "数据", BpmOAExpensesExportVO.class, list);
}
} }

View File

@ -1,58 +0,0 @@
package cn.iocoder.yudao.module.bpm.controller.admin.oa.vo.expenses;
import com.alibaba.excel.annotation.ExcelProperty;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.Accessors;
import java.math.BigDecimal;
/**
* 生产开支 Excel 导出 VO
*
* @author 符溶馨
*/
@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
@Accessors(chain = false)
public class BpmOAExpensesExportVO {
@ExcelProperty("申请用户")
private String userName;
@ExcelProperty("费用类型")
private String typeName;
@ExcelProperty("费用板块")
private String costSectionName;
@ExcelProperty("费用产生部门")
private String deptName;
@ExcelProperty("支出金额(元)")
private BigDecimal amount;
@ExcelProperty("费用明细")
private String detail;
@ExcelProperty("报销总金额(元)")
private BigDecimal totalMoney;
@ExcelProperty("收款人")
private String payeeName;
@ExcelProperty("开户行")
private String bankName;
@ExcelProperty("银行卡号")
private String bankNo;
@ExcelProperty("支付状态")
private String statusName;
}

View File

@ -97,11 +97,4 @@ public interface BpmOAExpensesService {
* @param month 月份 * @param month 月份
*/ */
void oneClickPayment(String month); void oneClickPayment(String month);
/**
* 转换
* @param list
* @return
*/
List<BpmOAExpensesExportVO> convertExpensesList(List<BpmOAExpensesPageRespVO> list);
} }

View File

@ -1,7 +1,5 @@
package cn.iocoder.yudao.module.bpm.service.oa; package cn.iocoder.yudao.module.bpm.service.oa;
import cn.hutool.core.bean.BeanUtil;
import cn.hutool.core.collection.CollUtil;
import cn.hutool.core.util.StrUtil; import cn.hutool.core.util.StrUtil;
import cn.iocoder.yudao.framework.common.pojo.CommonResult; import cn.iocoder.yudao.framework.common.pojo.CommonResult;
import cn.iocoder.yudao.framework.common.pojo.PageResult; import cn.iocoder.yudao.framework.common.pojo.PageResult;
@ -27,8 +25,6 @@ import cn.iocoder.yudao.module.smartfactory.api.staff.StaffApi;
import cn.iocoder.yudao.module.smartfactory.api.staff.dto.StaffDTO; import cn.iocoder.yudao.module.smartfactory.api.staff.dto.StaffDTO;
import cn.iocoder.yudao.module.system.api.bank.BankApi; import cn.iocoder.yudao.module.system.api.bank.BankApi;
import cn.iocoder.yudao.module.system.api.bank.dto.BankRespDTO; import cn.iocoder.yudao.module.system.api.bank.dto.BankRespDTO;
import cn.iocoder.yudao.module.system.api.dict.DictDataApi;
import cn.iocoder.yudao.module.system.api.dict.dto.DictDataRespDTO;
import cn.iocoder.yudao.module.system.api.loan.LoanApi; import cn.iocoder.yudao.module.system.api.loan.LoanApi;
import cn.iocoder.yudao.module.system.api.loan.dto.LoanDTO; import cn.iocoder.yudao.module.system.api.loan.dto.LoanDTO;
import cn.iocoder.yudao.module.system.api.user.AdminUserApi; import cn.iocoder.yudao.module.system.api.user.AdminUserApi;
@ -43,7 +39,9 @@ import org.springframework.validation.annotation.Validated;
import javax.annotation.Resource; import javax.annotation.Resource;
import java.math.BigDecimal; import java.math.BigDecimal;
import java.util.*; import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors; import java.util.stream.Collectors;
import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception; import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception;
@ -94,8 +92,6 @@ public class BpmOAExpensesServiceImpl extends BpmOABaseService implements BpmOAE
@Resource @Resource
private StaffApi staffApi; private StaffApi staffApi;
@Resource
private DictDataApi dictDataApi;
@Override @Override
public Long createExpenses(Long userId, BpmOAExpensesCreateReqVO createReqVO) { public Long createExpenses(Long userId, BpmOAExpensesCreateReqVO createReqVO) {
@ -164,7 +160,7 @@ public class BpmOAExpensesServiceImpl extends BpmOABaseService implements BpmOAE
// 设置开支日报支付状态为 已抵扣 // 设置开支日报支付状态为 已抵扣
expenses.setStatus(2).setAmountPaid(expenses.getTotalMoney()); expenses.setStatus(2).setAmountPaid(expenses.getTotalMoney());
} else { }else {
// 设置开支日报支付状态为 未抵扣完毕 // 设置开支日报支付状态为 未抵扣完毕
expenses.setStatus(3).setAmountPaid(loanDTO.getRemainingAmount()); expenses.setStatus(3).setAmountPaid(loanDTO.getRemainingAmount());
@ -241,7 +237,7 @@ public class BpmOAExpensesServiceImpl extends BpmOABaseService implements BpmOAE
@Override @Override
public PageResult<BpmOAExpensesPageRespVO> getExpensesPage(BpmOAExpensesPageReqVO pageReqVO) { public PageResult<BpmOAExpensesPageRespVO> getExpensesPage(BpmOAExpensesPageReqVO pageReqVO) {
IPage<BpmOAExpensesPageRespVO> page = expensesMapper.selectExpensesPage(MyBatisUtils.buildPage(pageReqVO), pageReqVO); IPage<BpmOAExpensesPageRespVO> page = expensesMapper.selectExpensesPage(MyBatisUtils.buildPage(pageReqVO) ,pageReqVO);
return new PageResult<>(page.getRecords(), page.getTotal()); return new PageResult<>(page.getRecords(), page.getTotal());
} }
@ -299,7 +295,7 @@ public class BpmOAExpensesServiceImpl extends BpmOABaseService implements BpmOAE
} }
@Override @Override
public void updateExpenses(Long id, Integer status, BigDecimal amountPaid) { public void updateExpenses(Long id ,Integer status, BigDecimal amountPaid) {
expensesMapper.updateById(new BpmOAExpensesDO() expensesMapper.updateById(new BpmOAExpensesDO()
.setId(id) .setId(id)
@ -324,28 +320,4 @@ public class BpmOAExpensesServiceImpl extends BpmOABaseService implements BpmOAE
expensesMapper.oneClickPayment(month); expensesMapper.oneClickPayment(month);
} }
@Override
public List<BpmOAExpensesExportVO> convertExpensesList(List<BpmOAExpensesPageRespVO> list) {
if (CollUtil.isEmpty(list)) {
return Collections.emptyList();
}
Map<Integer, String> costSectionMap = new HashMap<>();
costSectionMap.put(1, "叉车");
costSectionMap.put(2, "打包");
costSectionMap.put(3, "搬运");
costSectionMap.put(4, "运输");
List<DictDataRespDTO> bpmOaExpensesType = dictDataApi.getDictDataList("bpm_oa_expenses_type").getCheckedData();
Map<String, String> typeMap = bpmOaExpensesType.stream().collect(Collectors.toMap(DictDataRespDTO::getValue, DictDataRespDTO::getLabel));
List<BpmOAExpensesExportVO> vos = new ArrayList<>();
for (BpmOAExpensesPageRespVO bpmOAExpensesPageRespVO : list) {
BpmOAExpensesExportVO vo = BeanUtil.copyProperties(bpmOAExpensesPageRespVO, BpmOAExpensesExportVO.class);
vo.setTypeName(typeMap.get(String.valueOf(bpmOAExpensesPageRespVO.getType())));
vo.setStatusName(bpmOAExpensesPageRespVO.getStatus() == 0 ? "未支付" : "已支付");
// 费用板块 费用板块 | 1叉车 2打包 3搬运 4运输
vo.setCostSectionName(costSectionMap.get(bpmOAExpensesPageRespVO.getCostSection()));
vos.add(vo);
}
return vos;
}
} }