Compare commits
	
		
			No commits in common. "5ffd0e1c930b61b0f8335f9b5c61f9ebde4d265b" and "ec33bcd1ce36939a8967344510b62be2cac92eb9" have entirely different histories.
		
	
	
		
			5ffd0e1c93
			...
			ec33bcd1ce
		
	
		
| @ -29,14 +29,4 @@ public class DictBaseConstants { | |||||||
|     public static final String CYCLE_DICT = "cycle_dict"; |     public static final String CYCLE_DICT = "cycle_dict"; | ||||||
|     /** 企业资产临期判定时间 */ |     /** 企业资产临期判定时间 */ | ||||||
|     public static final String COMPANY_PROPERTY_EXPIRED = "company_property_expired"; |     public static final String COMPANY_PROPERTY_EXPIRED = "company_property_expired"; | ||||||
|     /** 客户状态 */ |  | ||||||
|     public static final String DICT_CUS_INFO_STATUS = "cus_info_status"; |  | ||||||
|     /** 卡券类型 */ |  | ||||||
|     public static final String MEMBER_COUPON_TYPE = "member_coupon_type"; |  | ||||||
|     /** 核销规则 */ |  | ||||||
|     public static final String MEMBER_COUPON_OUT_RULE = "member_coupon_out_rule"; |  | ||||||
|     /** 适用车型 */ |  | ||||||
|     public static final String MEMBER_CAR = "member_car"; |  | ||||||
|     /** 活动类型 */ |  | ||||||
|     public static final String MEMBER_ACTIVE = "member_active"; |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -1,15 +1,10 @@ | |||||||
| package cn.iocoder.yudao.module.custom.controller.admin; | package cn.iocoder.yudao.module.custom.controller.admin; | ||||||
| 
 | 
 | ||||||
| import cn.hutool.core.collection.CollUtil; |  | ||||||
| import cn.hutool.core.collection.CollectionUtil; | import cn.hutool.core.collection.CollectionUtil; | ||||||
| import cn.hutool.core.util.ObjectUtil; |  | ||||||
| import cn.iocoder.yudao.framework.common.pojo.CommonResult; | import cn.iocoder.yudao.framework.common.pojo.CommonResult; | ||||||
| import cn.iocoder.yudao.framework.common.util.object.BeanUtils; |  | ||||||
| import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils; |  | ||||||
| import cn.iocoder.yudao.module.custom.entity.CustomerMain; | import cn.iocoder.yudao.module.custom.entity.CustomerMain; | ||||||
| import cn.iocoder.yudao.module.custom.service.CustomerCarService; | import cn.iocoder.yudao.module.custom.service.CustomerCarService; | ||||||
| import cn.iocoder.yudao.module.custom.service.CustomerMainService; | import cn.iocoder.yudao.module.custom.service.CustomerMainService; | ||||||
| import cn.iocoder.yudao.module.custom.vo.CustomerExportVO; |  | ||||||
| import cn.iocoder.yudao.module.custom.vo.CustomerMainPageReqVO; | import cn.iocoder.yudao.module.custom.vo.CustomerMainPageReqVO; | ||||||
| import cn.iocoder.yudao.module.custom.vo.CustomerMainRespVO; | import cn.iocoder.yudao.module.custom.vo.CustomerMainRespVO; | ||||||
| import cn.iocoder.yudao.module.custom.vo.CustomerMainSaveReqVO; | import cn.iocoder.yudao.module.custom.vo.CustomerMainSaveReqVO; | ||||||
| @ -25,12 +20,8 @@ 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.ArrayList; |  | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.stream.Collectors; |  | ||||||
| 
 | 
 | ||||||
| import static cn.iocoder.yudao.common.BaseConstants.*; | import static cn.iocoder.yudao.common.BaseConstants.*; | ||||||
| import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception0; | import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception0; | ||||||
| @ -53,7 +44,6 @@ public class CustomerMainController { | |||||||
|     private BusiLabelService busiLabelService; |     private BusiLabelService busiLabelService; | ||||||
|     @Resource |     @Resource | ||||||
|     private CustomerCarService customerCarService; |     private CustomerCarService customerCarService; | ||||||
| 
 |  | ||||||
|     /** |     /** | ||||||
|      * 客户管理分页列表查询 |      * 客户管理分页列表查询 | ||||||
|      * |      * | ||||||
| @ -195,9 +185,9 @@ public class CustomerMainController { | |||||||
|     /** |     /** | ||||||
|      * 根据姓名和电话查询单条记录 |      * 根据姓名和电话查询单条记录 | ||||||
|      * |      * | ||||||
|      * @param customerMain 查询对象 |  | ||||||
|      * @author 小李 |      * @author 小李 | ||||||
|      * @date 11:19 2024/10/8 |      * @date 11:19 2024/10/8 | ||||||
|  |      * @param customerMain 查询对象 | ||||||
|     **/ |     **/ | ||||||
|     @PostMapping("/getByNameAndMobile") |     @PostMapping("/getByNameAndMobile") | ||||||
|     @Operation(summary = "根据姓名和电话查询单条记录") |     @Operation(summary = "根据姓名和电话查询单条记录") | ||||||
| @ -211,39 +201,4 @@ public class CustomerMainController { | |||||||
|         } |         } | ||||||
|         throw exception0(500, "系统异常"); |         throw exception0(500, "系统异常"); | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * 导出数据 |  | ||||||
|      * |  | ||||||
|      * @author 小李 |  | ||||||
|      * @date 19:33 2024/12/2 |  | ||||||
|      * @param pageReqVO 请求对象 |  | ||||||
|     **/ |  | ||||||
|     @GetMapping("/export") |  | ||||||
|     @Operation(summary = "导出数据") |  | ||||||
|     public void exportData(CustomerMainPageReqVO pageReqVO, HttpServletResponse response) throws IOException { |  | ||||||
|         int pageNo = 1, pageSize = 1000; |  | ||||||
|         List<CustomerExportVO> list = new ArrayList<>(); |  | ||||||
|         Page<CustomerMainRespVO> page = new Page<>(pageNo, pageSize); |  | ||||||
|         do { |  | ||||||
|             IPage<CustomerMainRespVO> customerMainRespVOIPage = customerMainService.queryListPage(pageReqVO, page); |  | ||||||
|             List<CustomerMainRespVO> records = customerMainRespVOIPage.getRecords(); |  | ||||||
|             if (CollUtil.isEmpty(records)){ |  | ||||||
|                 break; |  | ||||||
|             } |  | ||||||
|             List<CustomerExportVO> convertedRecords = records.stream().map(item -> BeanUtils.toBean(item, CustomerExportVO.class)).collect(Collectors.toList()); |  | ||||||
|             list.addAll(convertedRecords); |  | ||||||
|             pageNo++; |  | ||||||
|             page.setCurrent(pageNo); |  | ||||||
|         }while (true); |  | ||||||
|         if (CollUtil.isEmpty(list)){ |  | ||||||
|             throw exception0(500, "没有数据可以导出"); |  | ||||||
|         } |  | ||||||
|         list.forEach(item -> { |  | ||||||
|             if (ObjectUtil.isNotEmpty(item.getIsHangAccount())){ |  | ||||||
|                 item.setIsHangAccount(item.getIsHangAccount().equals("0") ? "否" : "是"); |  | ||||||
|             } |  | ||||||
|         }); |  | ||||||
|         ExcelUtils.write(response, "客户数据.xls", "数据", CustomerExportVO.class, list); |  | ||||||
|     } |  | ||||||
| } | } | ||||||
| @ -1,66 +0,0 @@ | |||||||
| package cn.iocoder.yudao.module.custom.vo; |  | ||||||
| 
 |  | ||||||
| import cn.iocoder.yudao.framework.excel.core.annotations.DictFormat; |  | ||||||
| import cn.iocoder.yudao.framework.excel.core.convert.DictConvert; |  | ||||||
| import com.alibaba.excel.annotation.ExcelIgnoreUnannotated; |  | ||||||
| import com.alibaba.excel.annotation.ExcelProperty; |  | ||||||
| import com.fasterxml.jackson.annotation.JsonFormat; |  | ||||||
| import lombok.Data; |  | ||||||
| import org.springframework.format.annotation.DateTimeFormat; |  | ||||||
| 
 |  | ||||||
| import java.time.LocalDateTime; |  | ||||||
| import java.util.Date; |  | ||||||
| 
 |  | ||||||
| import static cn.iocoder.yudao.common.DictBaseConstants.*; |  | ||||||
| 
 |  | ||||||
| /** |  | ||||||
|  * 用于导出客户数据VO |  | ||||||
|  * |  | ||||||
|  * @author 小李 |  | ||||||
|  * @date 19:20 2024/12/2 |  | ||||||
| **/ |  | ||||||
| @Data |  | ||||||
| @ExcelIgnoreUnannotated |  | ||||||
| public class CustomerExportVO { |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("客户名称") |  | ||||||
|     private String cusName; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty(value = "性别", converter = DictConvert.class) |  | ||||||
|     @DictFormat(DICT_SYS_USER_SEX) |  | ||||||
|     private String sex; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("会员等级") |  | ||||||
|     private String levelName; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("联系方式") |  | ||||||
|     private String phoneNumber; |  | ||||||
| 
 |  | ||||||
|     @JsonFormat(timezone = "GMT+8",pattern = "yyyy-MM-dd") |  | ||||||
|     @DateTimeFormat(pattern="yyyy-MM-dd") |  | ||||||
|     @ExcelProperty("生日") |  | ||||||
|     private LocalDateTime birthday; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("住址") |  | ||||||
|     private String address; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("是否挂账") |  | ||||||
|     private String isHangAccount; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty(value = "客户来源", converter = DictConvert.class) |  | ||||||
|     @DictFormat(DICT_CUS_DATA_FROM) |  | ||||||
|     private String dataFrom; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty(value = "最近办理业务", converter = DictConvert.class) |  | ||||||
|     @DictFormat(DICT_CUS_BUSI_TYPE) |  | ||||||
|     private String nearDoContent; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("最近业务办理时间") |  | ||||||
|     @JsonFormat(timezone = "GMT+8",pattern = "yyyy-MM-dd") |  | ||||||
|     @DateTimeFormat(pattern="yyyy-MM-dd") |  | ||||||
|     private LocalDateTime nearDoTime; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty(value = "客户状态", converter = DictConvert.class) |  | ||||||
|     @DictFormat(DICT_CUS_INFO_STATUS) |  | ||||||
|     private String status; |  | ||||||
| } |  | ||||||
| @ -1,13 +1,9 @@ | |||||||
| package cn.iocoder.yudao.module.member.controller.admin; | package cn.iocoder.yudao.module.member.controller.admin; | ||||||
| 
 | 
 | ||||||
| import cn.hutool.core.collection.CollUtil; |  | ||||||
| import cn.hutool.core.util.ObjectUtil; |  | ||||||
| import cn.iocoder.yudao.framework.common.pojo.CommonResult; | import cn.iocoder.yudao.framework.common.pojo.CommonResult; | ||||||
| import cn.iocoder.yudao.framework.common.util.object.BeanUtils; | import cn.iocoder.yudao.framework.common.util.object.BeanUtils; | ||||||
| import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils; |  | ||||||
| import cn.iocoder.yudao.module.member.entity.ActiveMain; | import cn.iocoder.yudao.module.member.entity.ActiveMain; | ||||||
| import cn.iocoder.yudao.module.member.service.ActiveMainService; | import cn.iocoder.yudao.module.member.service.ActiveMainService; | ||||||
| import cn.iocoder.yudao.module.member.vo.ActiveMainExportVO; |  | ||||||
| import cn.iocoder.yudao.module.member.vo.ActiveMainPageReqVO; | import cn.iocoder.yudao.module.member.vo.ActiveMainPageReqVO; | ||||||
| import cn.iocoder.yudao.module.member.vo.ActiveMainRespVO; | import cn.iocoder.yudao.module.member.vo.ActiveMainRespVO; | ||||||
| import cn.iocoder.yudao.module.member.vo.ActiveMainSaveReqVO; | import cn.iocoder.yudao.module.member.vo.ActiveMainSaveReqVO; | ||||||
| @ -21,15 +17,10 @@ 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.ArrayList; |  | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.stream.Collectors; |  | ||||||
| 
 | 
 | ||||||
| import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception0; |  | ||||||
| import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | ||||||
| 
 | 
 | ||||||
| @Tag(name = "管理后台 - 营销活动") | @Tag(name = "管理后台 - 营销活动") | ||||||
| @ -120,38 +111,4 @@ public class ActiveMainController { | |||||||
|         return success(activeMainService.queryListPage(pageReqVO, page)); |         return success(activeMainService.queryListPage(pageReqVO, page)); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |  | ||||||
|      * 导出数据 |  | ||||||
|      * |  | ||||||
|      * @author 小李 |  | ||||||
|      * @date 20:25 2024/12/2 |  | ||||||
|      * @param pageReqVO 请求对象 |  | ||||||
|     **/ |  | ||||||
|     @GetMapping("/export") |  | ||||||
|     @Operation(summary = "导出数据") |  | ||||||
|     public void exportData(ActiveMainPageReqVO pageReqVO, HttpServletResponse response)throws IOException { |  | ||||||
|         int pageNo = 1, pageSize = 1000; |  | ||||||
|         List<ActiveMainExportVO> list = new ArrayList<>(); |  | ||||||
|         Page<ActiveMainRespVO> page = new Page<>(pageNo, pageSize); |  | ||||||
|         do { |  | ||||||
|             IPage<ActiveMainRespVO> activeMainRespVOIPage = activeMainService.queryListPage(pageReqVO, page); |  | ||||||
|             List<ActiveMainRespVO> records = activeMainRespVOIPage.getRecords(); |  | ||||||
|             if (CollUtil.isEmpty(records)){ |  | ||||||
|                 break; |  | ||||||
|             } |  | ||||||
|             List<ActiveMainExportVO> convertedRecords = records.stream().map(item -> BeanUtils.toBean(item, ActiveMainExportVO.class)).collect(Collectors.toList()); |  | ||||||
|             list.addAll(convertedRecords); |  | ||||||
|             pageNo++; |  | ||||||
|             page.setCurrent(pageNo); |  | ||||||
|         }while (true); |  | ||||||
|         if (CollUtil.isEmpty(list)){ |  | ||||||
|             throw exception0(500, "没有数据可以导出"); |  | ||||||
|         } |  | ||||||
|         list.forEach(item -> { |  | ||||||
|             if (ObjectUtil.isNotEmpty(item.getStatus())){ |  | ||||||
|                 item.setStatus(item.getStatus().equals("01") ? "启用" : "停用"); |  | ||||||
|             } |  | ||||||
|         }); |  | ||||||
|         ExcelUtils.write(response, "营销活动数据.xls", "数据", ActiveMainExportVO.class, list); |  | ||||||
|     } |  | ||||||
| } | } | ||||||
| @ -1,7 +1,5 @@ | |||||||
| package cn.iocoder.yudao.module.member.controller.admin; | package cn.iocoder.yudao.module.member.controller.admin; | ||||||
| 
 | 
 | ||||||
| import cn.hutool.core.collection.CollUtil; |  | ||||||
| import cn.hutool.core.util.ObjectUtil; |  | ||||||
| import cn.iocoder.yudao.framework.apilog.core.annotation.ApiAccessLog; | import cn.iocoder.yudao.framework.apilog.core.annotation.ApiAccessLog; | ||||||
| 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.PageParam; | ||||||
| @ -10,7 +8,10 @@ import cn.iocoder.yudao.framework.common.util.object.BeanUtils; | |||||||
| import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils; | import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils; | ||||||
| import cn.iocoder.yudao.module.member.entity.MemberCoupon; | import cn.iocoder.yudao.module.member.entity.MemberCoupon; | ||||||
| import cn.iocoder.yudao.module.member.service.MemberCouponService; | import cn.iocoder.yudao.module.member.service.MemberCouponService; | ||||||
| import cn.iocoder.yudao.module.member.vo.*; | import cn.iocoder.yudao.module.member.vo.MemberCouponPageReqVO; | ||||||
|  | import cn.iocoder.yudao.module.member.vo.MemberCouponRespVO; | ||||||
|  | import cn.iocoder.yudao.module.member.vo.MemberCouponSaveReqVO; | ||||||
|  | import cn.iocoder.yudao.module.member.vo.MemberLevelRespVO; | ||||||
| import com.baomidou.mybatisplus.core.metadata.IPage; | import com.baomidou.mybatisplus.core.metadata.IPage; | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import io.swagger.v3.oas.annotations.Operation; | import io.swagger.v3.oas.annotations.Operation; | ||||||
| @ -24,12 +25,9 @@ import javax.annotation.Resource; | |||||||
| import javax.servlet.http.HttpServletResponse; | import javax.servlet.http.HttpServletResponse; | ||||||
| import javax.validation.Valid; | import javax.validation.Valid; | ||||||
| import java.io.IOException; | import java.io.IOException; | ||||||
| import java.util.ArrayList; |  | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.stream.Collectors; |  | ||||||
| 
 | 
 | ||||||
| import static cn.iocoder.yudao.framework.apilog.core.enums.OperateTypeEnum.EXPORT; | import static cn.iocoder.yudao.framework.apilog.core.enums.OperateTypeEnum.EXPORT; | ||||||
| import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception0; |  | ||||||
| import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | ||||||
| 
 | 
 | ||||||
| @Tag(name = "管理后台 - 基础卡券") | @Tag(name = "管理后台 - 基础卡券") | ||||||
| @ -140,34 +138,5 @@ public class MemberCouponController { | |||||||
|         return success(couponService.queryListPage(pageReqVO, page)); |         return success(couponService.queryListPage(pageReqVO, page)); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |  | ||||||
|      * 导出数据 |  | ||||||
|      * |  | ||||||
|      * @author 小李 |  | ||||||
|      * @date 19:53 2024/12/2 |  | ||||||
|      * @param pageReqVO 请求数据 |  | ||||||
|     **/ |  | ||||||
|     @GetMapping("/export") |  | ||||||
|     @Operation(summary = "导出数据") |  | ||||||
|     public void exportData(MemberCouponPageReqVO pageReqVO, HttpServletResponse response)throws IOException{ |  | ||||||
|         int pageNo = 1, pageSize = 1000; |  | ||||||
|         List<MemberCouponExportVO> list = new ArrayList<>(); |  | ||||||
|         Page<MemberCouponRespVO> page = new Page<>(pageNo, pageSize); |  | ||||||
|         do { |  | ||||||
|             IPage<MemberCouponRespVO> memberCouponRespVOIPage = couponService.queryListPage(pageReqVO, page); |  | ||||||
|             List<MemberCouponRespVO> records = memberCouponRespVOIPage.getRecords(); |  | ||||||
|             if (CollUtil.isEmpty(records)){ |  | ||||||
|                 break; |  | ||||||
|             } |  | ||||||
|             List<MemberCouponExportVO> convertedRecords = records.stream().map(item -> BeanUtils.toBean(item, MemberCouponExportVO.class)).collect(Collectors.toList()); |  | ||||||
|             list.addAll(convertedRecords); |  | ||||||
|             pageNo++; |  | ||||||
|             page.setCurrent(pageNo); |  | ||||||
|         }while (true); |  | ||||||
|         if (CollUtil.isEmpty(list)){ |  | ||||||
|             throw exception0(500, "没有数据可以导出"); |  | ||||||
|         } |  | ||||||
|         ExcelUtils.write(response, "基础卡券数据.xls", "数据", MemberCouponExportVO.class, list); |  | ||||||
|     } |  | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
| @ -1,13 +1,9 @@ | |||||||
| package cn.iocoder.yudao.module.member.controller.admin; | package cn.iocoder.yudao.module.member.controller.admin; | ||||||
| 
 | 
 | ||||||
| import cn.hutool.core.collection.CollUtil; |  | ||||||
| import cn.hutool.core.util.ObjectUtil; |  | ||||||
| import cn.iocoder.yudao.framework.common.pojo.CommonResult; | import cn.iocoder.yudao.framework.common.pojo.CommonResult; | ||||||
| import cn.iocoder.yudao.framework.common.util.object.BeanUtils; | import cn.iocoder.yudao.framework.common.util.object.BeanUtils; | ||||||
| import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils; |  | ||||||
| import cn.iocoder.yudao.module.member.entity.MemberLevel; | import cn.iocoder.yudao.module.member.entity.MemberLevel; | ||||||
| import cn.iocoder.yudao.module.member.service.MemberLevelService; | import cn.iocoder.yudao.module.member.service.MemberLevelService; | ||||||
| import cn.iocoder.yudao.module.member.vo.MemberLevelExportVO; |  | ||||||
| import cn.iocoder.yudao.module.member.vo.MemberLevelPageReqVO; | import cn.iocoder.yudao.module.member.vo.MemberLevelPageReqVO; | ||||||
| import cn.iocoder.yudao.module.member.vo.MemberLevelRespVO; | import cn.iocoder.yudao.module.member.vo.MemberLevelRespVO; | ||||||
| import cn.iocoder.yudao.module.member.vo.MemberLevelSaveReqVO; | import cn.iocoder.yudao.module.member.vo.MemberLevelSaveReqVO; | ||||||
| @ -21,15 +17,10 @@ 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.ArrayList; |  | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.stream.Collectors; |  | ||||||
| 
 | 
 | ||||||
| import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception0; |  | ||||||
| import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -136,39 +127,4 @@ public class MemberLevelController { | |||||||
|         return success(levelService.queryListAll(pageReqVO)); |         return success(levelService.queryListAll(pageReqVO)); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * 导出数据 |  | ||||||
|      * |  | ||||||
|      * @author 小李 |  | ||||||
|      * @date 19:41 2024/12/2 |  | ||||||
|      * @param pageReqVO 请求对象 |  | ||||||
|     **/ |  | ||||||
|     @GetMapping("/export") |  | ||||||
|     @Operation(summary = "导出数据") |  | ||||||
|     public void exportData(MemberLevelPageReqVO pageReqVO, HttpServletResponse response)throws IOException { |  | ||||||
|         int pageNo = 1, pageSize = 1000; |  | ||||||
|         List<MemberLevelExportVO> list = new ArrayList<>(); |  | ||||||
|         Page<MemberLevelRespVO> page = new Page<>(pageNo, pageSize); |  | ||||||
|         do { |  | ||||||
|             IPage<MemberLevelRespVO> memberLevelRespVOIPage = levelService.queryListPage(pageReqVO, page); |  | ||||||
|             List<MemberLevelRespVO> records = memberLevelRespVOIPage.getRecords(); |  | ||||||
|             if (CollUtil.isEmpty(records)){ |  | ||||||
|                 break; |  | ||||||
|             } |  | ||||||
|             List<MemberLevelExportVO> convertedRecords = records.stream().map(item -> BeanUtils.toBean(item, MemberLevelExportVO.class)).collect(Collectors.toList()); |  | ||||||
|             list.addAll(convertedRecords); |  | ||||||
|             pageNo++; |  | ||||||
|             page.setCurrent(pageNo); |  | ||||||
|         }while (true); |  | ||||||
|         if (CollUtil.isEmpty(list)){ |  | ||||||
|             throw exception0(500, "没有数据可以导出"); |  | ||||||
|         } |  | ||||||
|         list.forEach(item -> { |  | ||||||
|             if (ObjectUtil.isNotEmpty(item.getStatus())){ |  | ||||||
|                 item.setStatus(item.getStatus().equals("01") ? "启用" : "停用"); |  | ||||||
|             } |  | ||||||
|         }); |  | ||||||
|         ExcelUtils.write(response, "会员等级数据.xls", "数据", MemberLevelExportVO.class, list); |  | ||||||
|     } |  | ||||||
| } | } | ||||||
| @ -1,47 +0,0 @@ | |||||||
| package cn.iocoder.yudao.module.member.vo; |  | ||||||
| 
 |  | ||||||
| import cn.iocoder.yudao.framework.excel.core.annotations.DictFormat; |  | ||||||
| import cn.iocoder.yudao.framework.excel.core.convert.DictConvert; |  | ||||||
| import com.alibaba.excel.annotation.ExcelIgnoreUnannotated; |  | ||||||
| import com.alibaba.excel.annotation.ExcelProperty; |  | ||||||
| import com.fasterxml.jackson.annotation.JsonFormat; |  | ||||||
| import lombok.Data; |  | ||||||
| import org.springframework.format.annotation.DateTimeFormat; |  | ||||||
| 
 |  | ||||||
| import java.time.LocalDateTime; |  | ||||||
| 
 |  | ||||||
| import static cn.iocoder.yudao.common.DictBaseConstants.MEMBER_ACTIVE; |  | ||||||
| 
 |  | ||||||
| /** |  | ||||||
|  * 用于导出营销活动VO |  | ||||||
|  * |  | ||||||
|  * @author 小李 |  | ||||||
|  * @date 20:26 2024/12/2 |  | ||||||
| **/ |  | ||||||
| @Data |  | ||||||
| @ExcelIgnoreUnannotated |  | ||||||
| public class ActiveMainExportVO { |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("活动名称") |  | ||||||
|     private String name; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty(value = "活动类型", converter = DictConvert.class) |  | ||||||
|     @DictFormat(MEMBER_ACTIVE) |  | ||||||
|     private String type; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("活动开始时间") |  | ||||||
|     @JsonFormat(timezone = "GMT+8",pattern = "yyyy-MM-dd HH:mm:ss") |  | ||||||
|     @DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss") |  | ||||||
|     private LocalDateTime beginTime; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("活动结束时间") |  | ||||||
|     @JsonFormat(timezone = "GMT+8",pattern = "yyyy-MM-dd HH:mm:ss") |  | ||||||
|     @DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss") |  | ||||||
|     private LocalDateTime endTime; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("活动状态") |  | ||||||
|     private String status; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("活动描述") |  | ||||||
|     private String remark; |  | ||||||
| } |  | ||||||
| @ -1,56 +0,0 @@ | |||||||
| package cn.iocoder.yudao.module.member.vo; |  | ||||||
| 
 |  | ||||||
| import cn.iocoder.yudao.framework.excel.core.annotations.DictFormat; |  | ||||||
| import cn.iocoder.yudao.framework.excel.core.convert.DictConvert; |  | ||||||
| import com.alibaba.excel.annotation.ExcelIgnoreUnannotated; |  | ||||||
| import com.alibaba.excel.annotation.ExcelProperty; |  | ||||||
| import com.fasterxml.jackson.annotation.JsonFormat; |  | ||||||
| import lombok.Data; |  | ||||||
| import org.springframework.format.annotation.DateTimeFormat; |  | ||||||
| 
 |  | ||||||
| import java.math.BigDecimal; |  | ||||||
| import java.time.LocalDateTime; |  | ||||||
| 
 |  | ||||||
| import static cn.iocoder.yudao.common.DictBaseConstants.*; |  | ||||||
| 
 |  | ||||||
| /** |  | ||||||
|  * 用于基础卡券导出VO |  | ||||||
|  * |  | ||||||
|  * @author 小李 |  | ||||||
|  * @date 19:55 2024/12/2 |  | ||||||
| **/ |  | ||||||
| @Data |  | ||||||
| @ExcelIgnoreUnannotated |  | ||||||
| public class MemberCouponExportVO { |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("卡券名称") |  | ||||||
|     private String name; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty(value = "卡券类型", converter = DictConvert.class) |  | ||||||
|     @DictFormat(MEMBER_COUPON_TYPE) |  | ||||||
|     private String type; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty(value = "适用车型", converter = DictConvert.class) |  | ||||||
|     @DictFormat(MEMBER_CAR) |  | ||||||
|     private String carModel; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty(value = "核销规则", converter = DictConvert.class) |  | ||||||
|     @DictFormat(MEMBER_COUPON_OUT_RULE) |  | ||||||
|     private String outRule; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("开始有效期") |  | ||||||
|     @JsonFormat(timezone = "GMT+8",pattern = "yyyy-MM-dd HH:mm:ss") |  | ||||||
|     @DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss") |  | ||||||
|     private LocalDateTime beginTime; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("结束有效期") |  | ||||||
|     @JsonFormat(timezone = "GMT+8",pattern = "yyyy-MM-dd HH:mm:ss") |  | ||||||
|     @DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss") |  | ||||||
|     private LocalDateTime endTime; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("面额") |  | ||||||
|     private BigDecimal amount; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("备注") |  | ||||||
|     private String remark; |  | ||||||
| } |  | ||||||
| @ -1,36 +0,0 @@ | |||||||
| package cn.iocoder.yudao.module.member.vo; |  | ||||||
| 
 |  | ||||||
| import com.alibaba.excel.annotation.ExcelIgnoreUnannotated; |  | ||||||
| import com.alibaba.excel.annotation.ExcelProperty; |  | ||||||
| import lombok.Data; |  | ||||||
| 
 |  | ||||||
| import java.math.BigDecimal; |  | ||||||
| 
 |  | ||||||
| /** |  | ||||||
|  * 用于会员等级导出VO |  | ||||||
|  * |  | ||||||
|  * @author 小李 |  | ||||||
|  * @date 19:42 2024/12/2 |  | ||||||
| **/ |  | ||||||
| @Data |  | ||||||
| @ExcelIgnoreUnannotated |  | ||||||
| public class MemberLevelExportVO { |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("等级名称") |  | ||||||
|     private String name; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("状态") |  | ||||||
|     private String status; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("升级所需积分") |  | ||||||
|     private String growthValue; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("会员折扣") |  | ||||||
|     private BigDecimal discount; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("等级说明") |  | ||||||
|     private String remark; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("等级权益") |  | ||||||
|     private String userEquity; |  | ||||||
| } |  | ||||||
| @ -1,16 +1,12 @@ | |||||||
| package cn.iocoder.yudao.module.supplier.controller.admin; | package cn.iocoder.yudao.module.supplier.controller.admin; | ||||||
| 
 | 
 | ||||||
| import cn.hutool.core.collection.CollUtil; |  | ||||||
| import cn.hutool.core.util.ObjectUtil; |  | ||||||
| import cn.iocoder.yudao.framework.common.pojo.CommonResult; | import cn.iocoder.yudao.framework.common.pojo.CommonResult; | ||||||
| import cn.iocoder.yudao.framework.common.util.object.BeanUtils; | import cn.iocoder.yudao.framework.common.util.object.BeanUtils; | ||||||
| import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils; |  | ||||||
| import cn.iocoder.yudao.module.supplier.entity.BaseSupplier; | import cn.iocoder.yudao.module.supplier.entity.BaseSupplier; | ||||||
| import cn.iocoder.yudao.module.supplier.service.BaseSupplierService; | import cn.iocoder.yudao.module.supplier.service.BaseSupplierService; | ||||||
| import cn.iocoder.yudao.module.supplier.vo.BaseSupplierPageReqVO; | import cn.iocoder.yudao.module.supplier.vo.BaseSupplierPageReqVO; | ||||||
| import cn.iocoder.yudao.module.supplier.vo.BaseSupplierRespVO; | import cn.iocoder.yudao.module.supplier.vo.BaseSupplierRespVO; | ||||||
| import cn.iocoder.yudao.module.supplier.vo.BaseSupplierSaveReqVO; | import cn.iocoder.yudao.module.supplier.vo.BaseSupplierSaveReqVO; | ||||||
| import cn.iocoder.yudao.module.supplier.vo.SupplierExportVO; |  | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||||
| import com.baomidou.mybatisplus.core.metadata.IPage; | import com.baomidou.mybatisplus.core.metadata.IPage; | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| @ -22,15 +18,8 @@ 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.ArrayList; |  | ||||||
| import java.util.List; |  | ||||||
| import java.util.stream.Collectors; |  | ||||||
| 
 |  | ||||||
| import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception0; |  | ||||||
| import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | ||||||
| 
 | 
 | ||||||
| @Tag(name = "管理后台 - 供应商") | @Tag(name = "管理后台 - 供应商") | ||||||
| @ -148,40 +137,4 @@ public class BaseSupplierController { | |||||||
|                 .like(BaseSupplier::getName,name); |                 .like(BaseSupplier::getName,name); | ||||||
|         return success(baseSupplierService.list(queryWrapper)); |         return success(baseSupplierService.list(queryWrapper)); | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * 导出数据 |  | ||||||
|      * |  | ||||||
|      * @author 小李 |  | ||||||
|      * @date 17:30 2024/12/2 |  | ||||||
|      * @param pageReqVO 请求对象 |  | ||||||
|     **/ |  | ||||||
|     @GetMapping("/export") |  | ||||||
|     @Operation(summary = "导出数据") |  | ||||||
|     public void exportData(BaseSupplierPageReqVO pageReqVO, HttpServletResponse response)throws IOException { |  | ||||||
|         int pageNo = 1, pageSize = 1000; |  | ||||||
|         List<SupplierExportVO> list = new ArrayList<>(); |  | ||||||
|         Page<BaseSupplierRespVO> page = new Page<>(pageNo, pageSize); |  | ||||||
|         do { |  | ||||||
|             IPage<BaseSupplierRespVO> baseSupplierRespVOIPage = baseSupplierService.queryListPage(pageReqVO, page); |  | ||||||
|             List<BaseSupplierRespVO> records = baseSupplierRespVOIPage.getRecords(); |  | ||||||
|             if (CollUtil.isEmpty(records)){ |  | ||||||
|                 break; |  | ||||||
|             } |  | ||||||
|             List<SupplierExportVO> convertedRecords = records.stream().map(item -> BeanUtils.toBean(item, SupplierExportVO.class)).collect(Collectors.toList()); |  | ||||||
|             list.addAll(convertedRecords); |  | ||||||
|             pageNo++; |  | ||||||
|             page.setCurrent(pageNo); |  | ||||||
|         }while (true); |  | ||||||
|         if (CollUtil.isEmpty(list)){ |  | ||||||
|             throw exception0(500, "没有数据可以导出"); |  | ||||||
|         } |  | ||||||
|         list.forEach(item -> { |  | ||||||
|             if (ObjectUtil.isNotEmpty(item.getStatus())){ |  | ||||||
|                 item.setStatus(item.getStatus().equals("01") ? "启用" : "禁用"); |  | ||||||
|             } |  | ||||||
|             item.setCorpId(ObjectUtil.isEmpty(item.getCorpId()) ? "未绑定": "已绑定"); |  | ||||||
|         }); |  | ||||||
|         ExcelUtils.write(response, "供应商数据.xls", "数据", SupplierExportVO.class, list); |  | ||||||
|     } |  | ||||||
| } | } | ||||||
| @ -1,43 +0,0 @@ | |||||||
| package cn.iocoder.yudao.module.supplier.vo; |  | ||||||
| 
 |  | ||||||
| import com.alibaba.excel.annotation.ExcelIgnoreUnannotated; |  | ||||||
| import com.alibaba.excel.annotation.ExcelProperty; |  | ||||||
| import lombok.Data; |  | ||||||
| 
 |  | ||||||
| /** |  | ||||||
|  * 用于导出供应商VO |  | ||||||
|  * |  | ||||||
|  * @author 小李 |  | ||||||
|  * @date 17:30 2024/12/2 |  | ||||||
| **/ |  | ||||||
| @Data |  | ||||||
| @ExcelIgnoreUnannotated |  | ||||||
| public class SupplierExportVO { |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("供应商名称") |  | ||||||
|     private String name; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("联系人") |  | ||||||
|     private String linkName; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("联系电话") |  | ||||||
|     private String linkPhone; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("手机号码") |  | ||||||
|     private String phone; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("传真") |  | ||||||
|     private String fax; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("地址") |  | ||||||
|     private String address; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("状态") |  | ||||||
|     private String status; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("备注") |  | ||||||
|     private String remark; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("绑定状态") |  | ||||||
|     private String corpId; |  | ||||||
| } |  | ||||||
| @ -19,7 +19,4 @@ public interface RepairDictConstants { | |||||||
| 
 | 
 | ||||||
|     /** 配件相关提醒配置 */ |     /** 配件相关提醒配置 */ | ||||||
|     String REPAIR_WARES_NOTICE = "repair_wares_notice"; |     String REPAIR_WARES_NOTICE = "repair_wares_notice"; | ||||||
| 
 |  | ||||||
|     /** 维修工人工种 */ |  | ||||||
|     String REPAIR_WORK_TYPE = "repair_work_type"; |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -1,19 +1,15 @@ | |||||||
| package cn.iocoder.yudao.module.base.controller.admin; | package cn.iocoder.yudao.module.base.controller.admin; | ||||||
| 
 | 
 | ||||||
| import cn.hutool.core.collection.CollUtil; |  | ||||||
| import cn.hutool.core.util.ObjectUtil; |  | ||||||
| import cn.iocoder.yudao.common.MessageSend; | import cn.iocoder.yudao.common.MessageSend; | ||||||
| import cn.iocoder.yudao.common.dto.MessageDTO; | import cn.iocoder.yudao.common.dto.MessageDTO; | ||||||
| import cn.iocoder.yudao.framework.common.pojo.CommonResult; | import cn.iocoder.yudao.framework.common.pojo.CommonResult; | ||||||
| import cn.iocoder.yudao.framework.common.util.object.BeanUtils; | import cn.iocoder.yudao.framework.common.util.object.BeanUtils; | ||||||
| import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils; |  | ||||||
| import cn.iocoder.yudao.module.app.controller.admin.NotifyMessageSocket; | import cn.iocoder.yudao.module.app.controller.admin.NotifyMessageSocket; | ||||||
| import cn.iocoder.yudao.module.base.entity.RepairWorker; | import cn.iocoder.yudao.module.base.entity.RepairWorker; | ||||||
| import cn.iocoder.yudao.module.base.service.RepairWorkerService; | import cn.iocoder.yudao.module.base.service.RepairWorkerService; | ||||||
| import cn.iocoder.yudao.module.base.vo.RepairWorkerPageReqVO; | import cn.iocoder.yudao.module.base.vo.RepairWorkerPageReqVO; | ||||||
| import cn.iocoder.yudao.module.base.vo.RepairWorkerRespVO; | import cn.iocoder.yudao.module.base.vo.RepairWorkerRespVO; | ||||||
| import cn.iocoder.yudao.module.base.vo.RepairWorkerSaveReqVO; | import cn.iocoder.yudao.module.base.vo.RepairWorkerSaveReqVO; | ||||||
| import cn.iocoder.yudao.module.base.vo.WorkerExportVO; |  | ||||||
| import cn.iocoder.yudao.module.system.api.user.dto.UserDTO; | import cn.iocoder.yudao.module.system.api.user.dto.UserDTO; | ||||||
| import com.baomidou.mybatisplus.core.metadata.IPage; | import com.baomidou.mybatisplus.core.metadata.IPage; | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| @ -25,14 +21,11 @@ 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 java.io.IOException; | import java.io.IOException; | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.stream.Collectors; |  | ||||||
| 
 | 
 | ||||||
| import static cn.iocoder.yudao.common.BaseConstants.QUALS_INTERIM_PERIOD; | import static cn.iocoder.yudao.common.BaseConstants.QUALS_INTERIM_PERIOD; | ||||||
| import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception0; |  | ||||||
| import static cn.iocoder.yudao.framework.common.pojo.CommonResult.ok; | import static cn.iocoder.yudao.framework.common.pojo.CommonResult.ok; | ||||||
| import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | ||||||
| 
 | 
 | ||||||
| @ -175,41 +168,4 @@ public class RepairWorkerController { | |||||||
|         } |         } | ||||||
|         return ok(); |         return ok(); | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * 导出数据 |  | ||||||
|      * |  | ||||||
|      * @author 小李 |  | ||||||
|      * @date 17:50 2024/12/2 |  | ||||||
|      * @param pageReqVO 请求对象 |  | ||||||
|     **/ |  | ||||||
|     @GetMapping("/export") |  | ||||||
|     @Operation(summary = "导出数据") |  | ||||||
|     public void exportData(RepairWorkerPageReqVO pageReqVO, HttpServletResponse response)throws IOException{ |  | ||||||
|         int pageNo = 1, pageSize = 1000; |  | ||||||
|         List<WorkerExportVO> list = new ArrayList<>(); |  | ||||||
|         Page<RepairWorkerRespVO> page = new Page<>(pageNo,pageSize); |  | ||||||
|         do { |  | ||||||
|             IPage<RepairWorkerRespVO> repairWorkerRespVOIPage = workerService.queryListPage(pageReqVO, page); |  | ||||||
|             List<RepairWorkerRespVO> records = repairWorkerRespVOIPage.getRecords(); |  | ||||||
|             if (CollUtil.isEmpty(records)){ |  | ||||||
|                 break; |  | ||||||
|             } |  | ||||||
|             List<WorkerExportVO> convertedRecords = records.stream().map(item -> BeanUtils.toBean(item, WorkerExportVO.class)).collect(Collectors.toList()); |  | ||||||
|             list.addAll(convertedRecords); |  | ||||||
|             pageNo++; |  | ||||||
|             page.setCurrent(pageNo); |  | ||||||
|         }while (true); |  | ||||||
| 
 |  | ||||||
|         if (CollUtil.isEmpty(list)){ |  | ||||||
|             throw exception0(500, "没有数据可以导出"); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         list.forEach(item -> { |  | ||||||
|             if (ObjectUtil.isNotEmpty(item.getIsLeads())){ |  | ||||||
|                 item.setIsLeads(item.getIsLeads().equals("1") ? "班组长" : "维修工"); |  | ||||||
|             } |  | ||||||
|         }); |  | ||||||
|         ExcelUtils.write(response, "维修工人数据.xls", "数据", WorkerExportVO.class, list); |  | ||||||
|     } |  | ||||||
| } | } | ||||||
| @ -1,32 +0,0 @@ | |||||||
| package cn.iocoder.yudao.module.base.vo; |  | ||||||
| 
 |  | ||||||
| import cn.iocoder.yudao.common.RepairDictConstants; |  | ||||||
| import cn.iocoder.yudao.framework.excel.core.annotations.DictFormat; |  | ||||||
| import cn.iocoder.yudao.framework.excel.core.convert.DictConvert; |  | ||||||
| import com.alibaba.excel.annotation.ExcelIgnoreUnannotated; |  | ||||||
| import com.alibaba.excel.annotation.ExcelProperty; |  | ||||||
| import lombok.Data; |  | ||||||
| 
 |  | ||||||
| /** |  | ||||||
|  * 用于导出维修工人VO |  | ||||||
|  * |  | ||||||
|  * @author 小李 |  | ||||||
|  * @date 17:45 2024/12/2 |  | ||||||
| **/ |  | ||||||
| @Data |  | ||||||
| @ExcelIgnoreUnannotated |  | ||||||
| public class WorkerExportVO { |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("姓名") |  | ||||||
|     private String userName; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty(value = "工种", converter = DictConvert.class) |  | ||||||
|     @DictFormat(RepairDictConstants.REPAIR_WORK_TYPE) |  | ||||||
|     private String workType; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("角色") |  | ||||||
|     private String isLeads; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("备注") |  | ||||||
|     private String remark; |  | ||||||
| } |  | ||||||
| @ -1,30 +1,20 @@ | |||||||
| package cn.iocoder.yudao.module.other.controller.admin; | package cn.iocoder.yudao.module.other.controller.admin; | ||||||
| 
 | 
 | ||||||
| import cn.hutool.core.collection.CollUtil; |  | ||||||
| import cn.iocoder.yudao.framework.common.pojo.CommonResult; | import cn.iocoder.yudao.framework.common.pojo.CommonResult; | ||||||
| import cn.iocoder.yudao.framework.common.util.object.BeanUtils; |  | ||||||
| import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils; |  | ||||||
| import cn.iocoder.yudao.module.other.entity.DlRepairOther; | import cn.iocoder.yudao.module.other.entity.DlRepairOther; | ||||||
| import cn.iocoder.yudao.module.other.service.DlRepairOtherService; | import cn.iocoder.yudao.module.other.service.DlRepairOtherService; | ||||||
| import cn.iocoder.yudao.module.other.vo.DlRepairOtherReqVO; | import cn.iocoder.yudao.module.other.vo.DlRepairOtherReqVO; | ||||||
| import cn.iocoder.yudao.module.other.vo.DlRepairOtherRespVO; | import cn.iocoder.yudao.module.other.vo.DlRepairOtherRespVO; | ||||||
| import cn.iocoder.yudao.module.other.vo.OtherExportVO; |  | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||||
| import com.baomidou.mybatisplus.core.metadata.IPage; |  | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import io.swagger.v3.oas.annotations.Operation; | import io.swagger.v3.oas.annotations.Operation; | ||||||
| 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 java.io.IOException; |  | ||||||
| import java.util.ArrayList; |  | ||||||
| import java.util.Comparator; | import java.util.Comparator; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.stream.Collectors; |  | ||||||
| 
 | 
 | ||||||
| import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception0; |  | ||||||
| import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
| @ -94,42 +84,5 @@ public class DlRepairOtherController { | |||||||
|         List<DlRepairOther> list = dlRepairOtherService.list(new LambdaQueryWrapper<DlRepairOther>().eq(DlRepairOther::getName, name)); |         List<DlRepairOther> list = dlRepairOtherService.list(new LambdaQueryWrapper<DlRepairOther>().eq(DlRepairOther::getName, name)); | ||||||
|         return success(list.stream().max(Comparator.comparing(DlRepairOther::getCreateTime)).orElse(null)); |         return success(list.stream().max(Comparator.comparing(DlRepairOther::getCreateTime)).orElse(null)); | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * 导出数据 |  | ||||||
|      * |  | ||||||
|      * @author 小李 |  | ||||||
|      * @date 16:39 2024/12/2 |  | ||||||
|      * @param repairOtherReqVO 请求对象 |  | ||||||
|     **/ |  | ||||||
|     @GetMapping("/export") |  | ||||||
|     @Operation(summary = "导出数据") |  | ||||||
|     public void exportData(DlRepairOtherReqVO repairOtherReqVO, HttpServletResponse response) throws IOException { |  | ||||||
|         int pageNo = 1, pageSize = 1000; |  | ||||||
|         List<OtherExportVO> list = new ArrayList<>(); |  | ||||||
|         Page<DlRepairOther> page = new Page<>(pageNo, pageSize); |  | ||||||
|         do { |  | ||||||
|             IPage<DlRepairOther> otherPage = dlRepairOtherService.getOtherPage(repairOtherReqVO, page); |  | ||||||
|             List<DlRepairOther> records = otherPage.getRecords(); |  | ||||||
| 
 |  | ||||||
|             if (CollUtil.isEmpty(records)){ |  | ||||||
|                 break; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             List<OtherExportVO> convertedRecords = records.stream() |  | ||||||
|                     .map(item -> BeanUtils.toBean(item, OtherExportVO.class)) |  | ||||||
|                     .collect(Collectors.toList()); |  | ||||||
|             list.addAll(convertedRecords); |  | ||||||
| 
 |  | ||||||
|             pageNo++; |  | ||||||
|             page.setCurrent(pageNo); |  | ||||||
|         } while (true); |  | ||||||
| 
 |  | ||||||
|         if (CollUtil.isEmpty(list)){ |  | ||||||
|             throw exception0(500, "没有数据可以导出"); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         ExcelUtils.write(response, "附加数据.xls", "数据", OtherExportVO.class, list); |  | ||||||
|     } |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1,24 +0,0 @@ | |||||||
| package cn.iocoder.yudao.module.other.vo; |  | ||||||
| 
 |  | ||||||
| import com.alibaba.excel.annotation.ExcelIgnoreUnannotated; |  | ||||||
| import com.alibaba.excel.annotation.ExcelProperty; |  | ||||||
| import lombok.Data; |  | ||||||
| 
 |  | ||||||
| import java.math.BigDecimal; |  | ||||||
| 
 |  | ||||||
| /** |  | ||||||
|  * 用于导出维修附加内容的VO |  | ||||||
|  * |  | ||||||
|  * @author 小李 |  | ||||||
|  * @date 16:20 2024/12/2 |  | ||||||
| **/ |  | ||||||
| @Data |  | ||||||
| @ExcelIgnoreUnannotated |  | ||||||
| public class OtherExportVO { |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("名称") |  | ||||||
|     private String name; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("价格") |  | ||||||
|     private BigDecimal price; |  | ||||||
| } |  | ||||||
| @ -1,38 +1,28 @@ | |||||||
| package cn.iocoder.yudao.module.project.controller.admin; | package cn.iocoder.yudao.module.project.controller.admin; | ||||||
| 
 | 
 | ||||||
| import cn.hutool.core.collection.CollUtil; |  | ||||||
| import cn.hutool.core.util.ObjectUtil; |  | ||||||
| import cn.iocoder.yudao.framework.common.pojo.CommonResult; | import cn.iocoder.yudao.framework.common.pojo.CommonResult; | ||||||
| import cn.iocoder.yudao.framework.common.util.object.BeanUtils; | import cn.iocoder.yudao.framework.common.util.object.BeanUtils; | ||||||
| import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils; |  | ||||||
| import cn.iocoder.yudao.module.conf.entity.BaseType; |  | ||||||
| import cn.iocoder.yudao.module.conf.entity.BaseWarehouse; |  | ||||||
| import cn.iocoder.yudao.module.conf.service.BaseTypeService; |  | ||||||
| import cn.iocoder.yudao.module.conf.service.BaseWarehouseService; |  | ||||||
| import cn.iocoder.yudao.module.project.entity.RepairProject; | import cn.iocoder.yudao.module.project.entity.RepairProject; | ||||||
| import cn.iocoder.yudao.module.project.service.RepairProjectService; | import cn.iocoder.yudao.module.project.service.RepairProjectService; | ||||||
| import cn.iocoder.yudao.module.project.vo.*; | import cn.iocoder.yudao.module.project.vo.RepairProjectPageReqVO; | ||||||
|  | import cn.iocoder.yudao.module.project.vo.RepairProjectRespVO; | ||||||
|  | import cn.iocoder.yudao.module.project.vo.RepairProjectSaveReqVO; | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||||
| import com.baomidou.mybatisplus.core.metadata.IPage; | import com.baomidou.mybatisplus.core.metadata.IPage; | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import io.swagger.v3.oas.annotations.Operation; | import io.swagger.v3.oas.annotations.Operation; | ||||||
| import io.swagger.v3.oas.annotations.Parameter; | import io.swagger.v3.oas.annotations.Parameter; | ||||||
| import io.swagger.v3.oas.annotations.tags.Tag; | import io.swagger.v3.oas.annotations.tags.Tag; | ||||||
| import org.springframework.context.annotation.Lazy; | import org.springframework.security.access.prepost.PreAuthorize; | ||||||
| import org.springframework.validation.annotation.Validated; | 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.ArrayList; |  | ||||||
| import java.util.Comparator; | import java.util.Comparator; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Map; |  | ||||||
| import java.util.stream.Collectors; |  | ||||||
| 
 | 
 | ||||||
| import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception0; |  | ||||||
| import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | ||||||
| 
 | 
 | ||||||
| @Tag(name = "管理后台 - 维修项目") | @Tag(name = "管理后台 - 维修项目") | ||||||
| @ -44,14 +34,6 @@ public class RepairProjectController { | |||||||
|     @Resource |     @Resource | ||||||
|     private RepairProjectService repairProjectService; |     private RepairProjectService repairProjectService; | ||||||
| 
 | 
 | ||||||
|     @Resource |  | ||||||
|     @Lazy |  | ||||||
|     private BaseWarehouseService warehouseService; |  | ||||||
| 
 |  | ||||||
|     @Resource |  | ||||||
|     @Lazy |  | ||||||
|     private BaseTypeService typeService; |  | ||||||
| 
 |  | ||||||
|     /** |     /** | ||||||
|      * 创建维修项目 |      * 创建维修项目 | ||||||
|      * |      * | ||||||
| @ -155,46 +137,4 @@ public class RepairProjectController { | |||||||
|     public CommonResult getRepairProjectAndCateGory(){ |     public CommonResult getRepairProjectAndCateGory(){ | ||||||
|         return success(repairProjectService.getRepairProjectAndCateGory()); |         return success(repairProjectService.getRepairProjectAndCateGory()); | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * 导出数据 |  | ||||||
|      * |  | ||||||
|      * @author 小李 |  | ||||||
|      * @date 17:09 2024/12/2 |  | ||||||
|      * @param pageReqVO 请求对象 |  | ||||||
|     **/ |  | ||||||
|     @GetMapping("/export") |  | ||||||
|     @Operation(summary = "导出数据") |  | ||||||
|     public void exportData(RepairProjectPageReqVO pageReqVO, HttpServletResponse response)throws IOException { |  | ||||||
|         int pageNo = 1, pageSize = 1000; |  | ||||||
|         List<ProjectExportVO> list = new ArrayList<>(); |  | ||||||
|         Page<RepairProjectRespVO> page = new Page<>(pageNo, pageSize); |  | ||||||
|         do { |  | ||||||
|             IPage<RepairProjectRespVO> repairProjectRespVOIPage = repairProjectService.queryListPage(pageReqVO, page); |  | ||||||
|             List<RepairProjectRespVO> records = repairProjectRespVOIPage.getRecords(); |  | ||||||
| 
 |  | ||||||
|             if (CollUtil.isEmpty(records)){ |  | ||||||
|                 break; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             records.forEach(item -> { |  | ||||||
|                 if (ObjectUtil.isNotEmpty(item.getTypeName())){ |  | ||||||
|                     item.setType(item.getTypeName()); |  | ||||||
|                 } |  | ||||||
|             }); |  | ||||||
| 
 |  | ||||||
|             List<ProjectExportVO> convertedRecords = records.stream().map(item -> BeanUtils.toBean(item, ProjectExportVO.class)).collect(Collectors.toList()); |  | ||||||
|             list.addAll(convertedRecords); |  | ||||||
| 
 |  | ||||||
|             pageNo++; |  | ||||||
|             page.setCurrent(pageNo); |  | ||||||
|         }while (true); |  | ||||||
| 
 |  | ||||||
|         if (CollUtil.isEmpty(list)){ |  | ||||||
|             throw exception0(500, "没有数据可以导出"); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         ExcelUtils.write(response, "维修项目数据.xls", "数据", ProjectExportVO.class, list); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } | } | ||||||
| @ -1,25 +1,16 @@ | |||||||
| package cn.iocoder.yudao.module.project.controller.admin; | package cn.iocoder.yudao.module.project.controller.admin; | ||||||
| 
 | 
 | ||||||
| import cn.hutool.core.collection.CollUtil; |  | ||||||
| import cn.hutool.core.util.ObjectUtil; |  | ||||||
| import cn.iocoder.yudao.framework.common.pojo.CommonResult; | import cn.iocoder.yudao.framework.common.pojo.CommonResult; | ||||||
| import cn.iocoder.yudao.framework.common.util.object.BeanUtils; |  | ||||||
| import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils; | import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils; | ||||||
| import cn.iocoder.yudao.module.conf.entity.BaseType; |  | ||||||
| import cn.iocoder.yudao.module.conf.entity.BaseWarehouse; |  | ||||||
| import cn.iocoder.yudao.module.conf.service.BaseTypeService; |  | ||||||
| import cn.iocoder.yudao.module.conf.service.BaseWarehouseService; |  | ||||||
| import cn.iocoder.yudao.module.project.entity.RepairWares; | import cn.iocoder.yudao.module.project.entity.RepairWares; | ||||||
| import cn.iocoder.yudao.module.project.service.RepairWaresService; | import cn.iocoder.yudao.module.project.service.RepairWaresService; | ||||||
| import cn.iocoder.yudao.module.project.vo.*; | import cn.iocoder.yudao.module.project.vo.*; | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |  | ||||||
| import com.baomidou.mybatisplus.core.metadata.IPage; | import com.baomidou.mybatisplus.core.metadata.IPage; | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import io.swagger.v3.oas.annotations.Operation; | import io.swagger.v3.oas.annotations.Operation; | ||||||
| import io.swagger.v3.oas.annotations.Parameter; | import io.swagger.v3.oas.annotations.Parameter; | ||||||
| import io.swagger.v3.oas.annotations.Parameters; | import io.swagger.v3.oas.annotations.Parameters; | ||||||
| import io.swagger.v3.oas.annotations.tags.Tag; | import io.swagger.v3.oas.annotations.tags.Tag; | ||||||
| import org.springframework.context.annotation.Lazy; |  | ||||||
| import org.springframework.validation.annotation.Validated; | import org.springframework.validation.annotation.Validated; | ||||||
| import org.springframework.web.bind.annotation.*; | import org.springframework.web.bind.annotation.*; | ||||||
| import org.springframework.web.multipart.MultipartFile; | import org.springframework.web.multipart.MultipartFile; | ||||||
| @ -28,15 +19,10 @@ import javax.annotation.Resource; | |||||||
| import javax.servlet.http.HttpServletResponse; | import javax.servlet.http.HttpServletResponse; | ||||||
| import javax.validation.Valid; | import javax.validation.Valid; | ||||||
| 
 | 
 | ||||||
| import java.io.IOException; |  | ||||||
| import java.math.BigDecimal; | import java.math.BigDecimal; | ||||||
| import java.util.ArrayList; |  | ||||||
| import java.util.Collections; | import java.util.Collections; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Map; |  | ||||||
| import java.util.stream.Collectors; |  | ||||||
| 
 | 
 | ||||||
| import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception0; |  | ||||||
| import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | ||||||
| 
 | 
 | ||||||
| @Tag(name = "管理后台 - 配件库") | @Tag(name = "管理后台 - 配件库") | ||||||
| @ -48,14 +34,6 @@ public class RepairWaresController { | |||||||
|     @Resource |     @Resource | ||||||
|     private RepairWaresService waresService; |     private RepairWaresService waresService; | ||||||
| 
 | 
 | ||||||
|     @Resource |  | ||||||
|     @Lazy |  | ||||||
|     private BaseWarehouseService warehouseService; |  | ||||||
| 
 |  | ||||||
|     @Resource |  | ||||||
|     @Lazy |  | ||||||
|     private BaseTypeService typeService; |  | ||||||
| 
 |  | ||||||
|     /** |     /** | ||||||
|      * 创建配件库 |      * 创建配件库 | ||||||
|      * |      * | ||||||
| @ -215,54 +193,4 @@ public class RepairWaresController { | |||||||
|         List<RepairWaresExcelVO> list = ExcelUtils.read(file, RepairWaresExcelVO.class); |         List<RepairWaresExcelVO> list = ExcelUtils.read(file, RepairWaresExcelVO.class); | ||||||
|         return success(waresService.importData(list, updateSupport)); |         return success(waresService.importData(list, updateSupport)); | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * 导出数据 |  | ||||||
|      * |  | ||||||
|      * @author 小李 |  | ||||||
|      * @date 17:20 2024/12/2 |  | ||||||
|      * @param pageReqVO 请求对象 |  | ||||||
|     **/ |  | ||||||
|     @GetMapping("/export") |  | ||||||
|     @Operation(summary = "导出数据") |  | ||||||
|     public void exportData(RepairWaresPageReqVO pageReqVO, HttpServletResponse response)throws IOException { |  | ||||||
|         int pageNo = 1, pageSize = 1000; |  | ||||||
|         List<RepairWaresExcelVO> list = new ArrayList<>(); |  | ||||||
|         Page<RepairWaresRespVO> page = new Page<>(pageNo, pageSize); |  | ||||||
|         do { |  | ||||||
|             IPage<RepairWaresRespVO> waresPage = waresService.getWaresPage(pageReqVO, page); |  | ||||||
|             List<RepairWaresRespVO> records = waresPage.getRecords(); |  | ||||||
|              |  | ||||||
|             if (CollUtil.isEmpty(records)){ |  | ||||||
|                 break; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             List<RepairWaresExcelVO> convertedRecords = records.stream().map(item -> BeanUtils.toBean(item, RepairWaresExcelVO.class)).collect(Collectors.toList()); |  | ||||||
|             list.addAll(convertedRecords); |  | ||||||
| 
 |  | ||||||
|             pageNo++; |  | ||||||
|             page.setCurrent(pageNo); |  | ||||||
|         }while (true); |  | ||||||
| 
 |  | ||||||
|         if (CollUtil.isEmpty(list)){ |  | ||||||
|             throw exception0(500, "没有数据可以导出"); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         List<BaseWarehouse> warehouses = warehouseService.list(); |  | ||||||
|         Map<String, String> warehousesMap = warehouses.stream().collect(Collectors.toMap(BaseWarehouse::getId, BaseWarehouse::getName)); |  | ||||||
| 
 |  | ||||||
|         List<BaseType> types = typeService.list(new LambdaQueryWrapper<BaseType>().eq(BaseType::getType, "02")); |  | ||||||
|         Map<String, String> typesMap = types.stream().collect(Collectors.toMap(BaseType::getId, BaseType::getName)); |  | ||||||
| 
 |  | ||||||
|         list.forEach(item -> { |  | ||||||
|             if (ObjectUtil.isNotEmpty(item.getWarehouse()) && ObjectUtil.isNotEmpty(warehousesMap.get(item.getWarehouse()))){ |  | ||||||
|                 item.setWarehouse(warehousesMap.get(item.getWarehouse())); |  | ||||||
|             } |  | ||||||
|             if (ObjectUtil.isNotEmpty(item.getType()) && ObjectUtil.isNotEmpty(typesMap.get(item.getType()))){ |  | ||||||
|                 item.setType(typesMap.get(item.getType())); |  | ||||||
|             } |  | ||||||
|         }); |  | ||||||
| 
 |  | ||||||
|         ExcelUtils.write(response, "维修配件数据.xls", "数据", RepairWaresExcelVO.class, list); |  | ||||||
|     } |  | ||||||
| } | } | ||||||
| @ -1,57 +0,0 @@ | |||||||
| package cn.iocoder.yudao.module.project.vo; |  | ||||||
| 
 |  | ||||||
| import cn.iocoder.yudao.common.RepairDictConstants; |  | ||||||
| import cn.iocoder.yudao.framework.excel.core.annotations.DictFormat; |  | ||||||
| import cn.iocoder.yudao.framework.excel.core.convert.DictConvert; |  | ||||||
| import com.alibaba.excel.annotation.ExcelIgnoreUnannotated; |  | ||||||
| import com.alibaba.excel.annotation.ExcelProperty; |  | ||||||
| import com.fasterxml.jackson.annotation.JsonFormat; |  | ||||||
| import lombok.Data; |  | ||||||
| import org.springframework.format.annotation.DateTimeFormat; |  | ||||||
| 
 |  | ||||||
| import java.math.BigDecimal; |  | ||||||
| import java.time.LocalDateTime; |  | ||||||
| 
 |  | ||||||
| /** |  | ||||||
|  * 用于导出维修项目的VO |  | ||||||
|  * |  | ||||||
|  * @author 小李 |  | ||||||
|  * @date 17:03 2024/12/2 |  | ||||||
| **/ |  | ||||||
| @Data |  | ||||||
| @ExcelIgnoreUnannotated |  | ||||||
| public class ProjectExportVO { |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("名称") |  | ||||||
|     private String name; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("成本") |  | ||||||
|     private Long cost; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("规格") |  | ||||||
|     private String spec; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("售价") |  | ||||||
|     private BigDecimal price; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("编码") |  | ||||||
|     private String code; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty(value = "单位", converter = DictConvert.class) |  | ||||||
|     @DictFormat(RepairDictConstants.REPAIR_UNIT) |  | ||||||
|     private String unit; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("分类") |  | ||||||
|     private String type; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("工时") |  | ||||||
|     private String manHour; |  | ||||||
| 
 |  | ||||||
|     @ExcelProperty("备注") |  | ||||||
|     private String remark; |  | ||||||
| 
 |  | ||||||
|     @JsonFormat(timezone = "GMT+8",pattern = "yyyy-MM-dd HH:mm:ss") |  | ||||||
|     @DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss") |  | ||||||
|     @ExcelProperty("创建时间") |  | ||||||
|     private LocalDateTime createTime; |  | ||||||
| } |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user