|  |  | @ -17,21 +17,45 @@ | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | package com.epmet.controller; | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | import com.alibaba.excel.EasyExcel; | 
			
		
	
		
			
				
					|  |  |  | import com.alibaba.excel.ExcelWriter; | 
			
		
	
		
			
				
					|  |  |  | import com.alibaba.excel.write.metadata.WriteSheet; | 
			
		
	
		
			
				
					|  |  |  | import com.alibaba.excel.write.metadata.style.WriteCellStyle; | 
			
		
	
		
			
				
					|  |  |  | import com.alibaba.excel.write.style.HorizontalCellStyleStrategy; | 
			
		
	
		
			
				
					|  |  |  | import com.alibaba.excel.write.style.column.LongestMatchColumnWidthStyleStrategy; | 
			
		
	
		
			
				
					|  |  |  | import com.alibaba.fastjson.JSON; | 
			
		
	
		
			
				
					|  |  |  | import com.epmet.commons.tools.annotation.LoginUser; | 
			
		
	
		
			
				
					|  |  |  | import com.epmet.commons.tools.constant.NumConstant; | 
			
		
	
		
			
				
					|  |  |  | import com.epmet.commons.tools.exception.EpmetErrorCode; | 
			
		
	
		
			
				
					|  |  |  | import com.epmet.commons.tools.exception.EpmetException; | 
			
		
	
		
			
				
					|  |  |  | import com.epmet.commons.tools.page.PageData; | 
			
		
	
		
			
				
					|  |  |  | import com.epmet.commons.tools.security.dto.TokenDto; | 
			
		
	
		
			
				
					|  |  |  | import com.epmet.commons.tools.utils.DateUtils; | 
			
		
	
		
			
				
					|  |  |  | import com.epmet.commons.tools.utils.ExcelUtils; | 
			
		
	
		
			
				
					|  |  |  | import com.epmet.commons.tools.utils.Result; | 
			
		
	
		
			
				
					|  |  |  | import com.epmet.commons.tools.utils.poi.excel.handler.FreezeAndFilter; | 
			
		
	
		
			
				
					|  |  |  | import com.epmet.commons.tools.validator.ValidatorUtils; | 
			
		
	
		
			
				
					|  |  |  | import com.epmet.dto.IcPropertyManagementDTO; | 
			
		
	
		
			
				
					|  |  |  | import com.epmet.dto.form.IcPropertyManagementFormDTO; | 
			
		
	
		
			
				
					|  |  |  | import com.epmet.dto.result.IcPropertyManagementResultDTO; | 
			
		
	
		
			
				
					|  |  |  | import com.epmet.service.PropertyManagementService; | 
			
		
	
		
			
				
					|  |  |  | import lombok.extern.slf4j.Slf4j; | 
			
		
	
		
			
				
					|  |  |  | import org.apache.commons.collections4.CollectionUtils; | 
			
		
	
		
			
				
					|  |  |  | import org.apache.commons.io.IOUtils; | 
			
		
	
		
			
				
					|  |  |  | import org.apache.commons.lang3.StringUtils; | 
			
		
	
		
			
				
					|  |  |  | import org.apache.poi.ss.usermodel.IndexedColors; | 
			
		
	
		
			
				
					|  |  |  | import org.apache.poi.ss.usermodel.VerticalAlignment; | 
			
		
	
		
			
				
					|  |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
			
		
	
		
			
				
					|  |  |  | import org.springframework.web.bind.annotation.PostMapping; | 
			
		
	
		
			
				
					|  |  |  | import org.springframework.web.bind.annotation.RequestBody; | 
			
		
	
		
			
				
					|  |  |  | import org.springframework.web.bind.annotation.RequestMapping; | 
			
		
	
		
			
				
					|  |  |  | import org.springframework.web.bind.annotation.RestController; | 
			
		
	
		
			
				
					|  |  |  | import org.springframework.http.HttpHeaders; | 
			
		
	
		
			
				
					|  |  |  | import org.springframework.web.bind.annotation.*; | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | import javax.servlet.ServletOutputStream; | 
			
		
	
		
			
				
					|  |  |  | import javax.servlet.http.HttpServletResponse; | 
			
		
	
		
			
				
					|  |  |  | import java.io.IOException; | 
			
		
	
		
			
				
					|  |  |  | import java.io.InputStream; | 
			
		
	
		
			
				
					|  |  |  | import java.io.PrintWriter; | 
			
		
	
		
			
				
					|  |  |  | import java.net.URLEncoder; | 
			
		
	
		
			
				
					|  |  |  | import java.util.Date; | 
			
		
	
		
			
				
					|  |  |  | import java.util.HashMap; | 
			
		
	
		
			
				
					|  |  |  | import java.util.List; | 
			
		
	
		
			
				
					|  |  |  | import java.util.Map; | 
			
		
	
	
		
			
				
					|  |  | @ -43,6 +67,7 @@ import java.util.Map; | 
			
		
	
		
			
				
					|  |  |  |  * @author generator generator@elink-cn.com | 
			
		
	
		
			
				
					|  |  |  |  * @since v1.0.0 2021-10-25 | 
			
		
	
		
			
				
					|  |  |  |  */ | 
			
		
	
		
			
				
					|  |  |  | @Slf4j | 
			
		
	
		
			
				
					|  |  |  | @RestController | 
			
		
	
		
			
				
					|  |  |  | @RequestMapping("propertymanagement") | 
			
		
	
		
			
				
					|  |  |  | public class PropertyManagementController { | 
			
		
	
	
		
			
				
					|  |  | @ -55,9 +80,8 @@ public class PropertyManagementController { | 
			
		
	
		
			
				
					|  |  |  |      */ | 
			
		
	
		
			
				
					|  |  |  |     @PostMapping("page") | 
			
		
	
		
			
				
					|  |  |  |     public Result<PageData<IcPropertyManagementDTO>> page(@RequestBody IcPropertyManagementFormDTO formDTO){ | 
			
		
	
		
			
				
					|  |  |  |         ValidatorUtils.validateEntity(formDTO,IcPropertyManagementFormDTO.PageGroup.class); | 
			
		
	
		
			
				
					|  |  |  |        return  new Result<PageData<IcPropertyManagementDTO>>().ok(propertyManagementService.page(formDTO.getPageNo(),formDTO.getPageSize(),formDTO.getName(), | 
			
		
	
		
			
				
					|  |  |  |                formDTO.getContactName(),formDTO.getContactMobile())); | 
			
		
	
		
			
				
					|  |  |  |                formDTO.getContactName(),formDTO.getContactMobile(),"page-query")); | 
			
		
	
		
			
				
					|  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     /** | 
			
		
	
	
		
			
				
					|  |  | @ -112,4 +136,96 @@ public class PropertyManagementController { | 
			
		
	
		
			
				
					|  |  |  |         return new Result(); | 
			
		
	
		
			
				
					|  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     /** | 
			
		
	
		
			
				
					|  |  |  |      * 物业管理-下载导入模板 | 
			
		
	
		
			
				
					|  |  |  |      * @param response | 
			
		
	
		
			
				
					|  |  |  |      * @throws IOException | 
			
		
	
		
			
				
					|  |  |  |      */ | 
			
		
	
		
			
				
					|  |  |  |     @RequestMapping(value = "download-tem", method = {RequestMethod.GET, RequestMethod.POST}) | 
			
		
	
		
			
				
					|  |  |  |     public void downloadTemplate(HttpServletResponse response) throws IOException { | 
			
		
	
		
			
				
					|  |  |  |         response.setCharacterEncoding("UTF-8"); | 
			
		
	
		
			
				
					|  |  |  |         response.addHeader(HttpHeaders.ACCESS_CONTROL_EXPOSE_HEADERS, "Content-Disposition"); | 
			
		
	
		
			
				
					|  |  |  |         //response.setHeader(HttpHeaders.CONTENT_TYPE, "application/vnd.ms-excel");
 | 
			
		
	
		
			
				
					|  |  |  |         response.setHeader(HttpHeaders.CONTENT_TYPE, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"); | 
			
		
	
		
			
				
					|  |  |  |         response.setHeader(HttpHeaders.CONTENT_DISPOSITION, "attachment;filename=" + URLEncoder.encode("物业管理导入模版", "UTF-8") + ".xlsx"); | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |         InputStream is = this.getClass().getClassLoader().getResourceAsStream("excel/ic_property_management_temp.xlsx"); | 
			
		
	
		
			
				
					|  |  |  |         try { | 
			
		
	
		
			
				
					|  |  |  |             ServletOutputStream os = response.getOutputStream(); | 
			
		
	
		
			
				
					|  |  |  |             IOUtils.copy(is, os); | 
			
		
	
		
			
				
					|  |  |  |         } finally { | 
			
		
	
		
			
				
					|  |  |  |             if (is != null) { | 
			
		
	
		
			
				
					|  |  |  |                 is.close(); | 
			
		
	
		
			
				
					|  |  |  |             } | 
			
		
	
		
			
				
					|  |  |  |         } | 
			
		
	
		
			
				
					|  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     /** | 
			
		
	
		
			
				
					|  |  |  |      * 物业管理-列表导出 | 
			
		
	
		
			
				
					|  |  |  |      * | 
			
		
	
		
			
				
					|  |  |  |      * @param tokenDto | 
			
		
	
		
			
				
					|  |  |  |      * @param formDTO | 
			
		
	
		
			
				
					|  |  |  |      * @param response | 
			
		
	
		
			
				
					|  |  |  |      * @return | 
			
		
	
		
			
				
					|  |  |  |      * @throws IOException | 
			
		
	
		
			
				
					|  |  |  |      */ | 
			
		
	
		
			
				
					|  |  |  |     @PostMapping("export") | 
			
		
	
		
			
				
					|  |  |  |     public void exportEnterprise(@LoginUser TokenDto tokenDto, @RequestBody IcPropertyManagementFormDTO formDTO, HttpServletResponse response) throws IOException { | 
			
		
	
		
			
				
					|  |  |  |         formDTO.setCustomerId(tokenDto.getCustomerId()); | 
			
		
	
		
			
				
					|  |  |  |         ExcelWriter excelWriter = null; | 
			
		
	
		
			
				
					|  |  |  |         formDTO.setPageNo(NumConstant.ONE); | 
			
		
	
		
			
				
					|  |  |  |         formDTO.setPageSize(NumConstant.TEN_THOUSAND); | 
			
		
	
		
			
				
					|  |  |  |         try { | 
			
		
	
		
			
				
					|  |  |  |             String fileName = "物业管理" + DateUtils.format(new Date()) + ".xlsx"; | 
			
		
	
		
			
				
					|  |  |  |             WriteCellStyle headWriteCellStyle = new WriteCellStyle(); | 
			
		
	
		
			
				
					|  |  |  |             headWriteCellStyle.setFillForegroundColor(IndexedColors.PALE_BLUE.getIndex()); | 
			
		
	
		
			
				
					|  |  |  |             WriteCellStyle contentWriteCellStyle = new WriteCellStyle(); | 
			
		
	
		
			
				
					|  |  |  |             contentWriteCellStyle.setVerticalAlignment(VerticalAlignment.CENTER); | 
			
		
	
		
			
				
					|  |  |  |             HorizontalCellStyleStrategy horizontalCellStyleStrategy = new HorizontalCellStyleStrategy(headWriteCellStyle, contentWriteCellStyle); | 
			
		
	
		
			
				
					|  |  |  |             FreezeAndFilter writeHandler = new FreezeAndFilter(); | 
			
		
	
		
			
				
					|  |  |  |             excelWriter = EasyExcel.write(ExcelUtils.getOutputStreamForExcel(fileName, response), IcPropertyManagementDTO.class) | 
			
		
	
		
			
				
					|  |  |  |                     .registerWriteHandler(horizontalCellStyleStrategy) | 
			
		
	
		
			
				
					|  |  |  |                     .registerWriteHandler(new LongestMatchColumnWidthStyleStrategy()) | 
			
		
	
		
			
				
					|  |  |  |                     .registerWriteHandler(writeHandler).build(); | 
			
		
	
		
			
				
					|  |  |  |             WriteSheet writeSheet = EasyExcel.writerSheet("Sheet1").registerWriteHandler(new FreezeAndFilter()).build(); | 
			
		
	
		
			
				
					|  |  |  |             PageData<IcPropertyManagementDTO> data = null; | 
			
		
	
		
			
				
					|  |  |  |             do { | 
			
		
	
		
			
				
					|  |  |  |                 data = propertyManagementService.page(formDTO.getPageNo(), formDTO.getPageSize(), formDTO.getName(), formDTO.getContactName(), formDTO.getContactMobile(),"export"); | 
			
		
	
		
			
				
					|  |  |  |                 formDTO.setPageNo(formDTO.getPageNo() + NumConstant.ONE); | 
			
		
	
		
			
				
					|  |  |  |                 excelWriter.write(data.getList(), writeSheet); | 
			
		
	
		
			
				
					|  |  |  |             } while (CollectionUtils.isNotEmpty(data.getList()) && data.getList().size() == formDTO.getPageSize()); | 
			
		
	
		
			
				
					|  |  |  |         } catch (EpmetException e) { | 
			
		
	
		
			
				
					|  |  |  |             response.reset(); | 
			
		
	
		
			
				
					|  |  |  |             response.setCharacterEncoding("UTF-8"); | 
			
		
	
		
			
				
					|  |  |  |             response.setHeader("content-type", "application/json; charset=UTF-8"); | 
			
		
	
		
			
				
					|  |  |  |             PrintWriter printWriter = response.getWriter(); | 
			
		
	
		
			
				
					|  |  |  |             Result<Object> result = new Result<>().error(EpmetErrorCode.EPMET_COMMON_OPERATION_FAIL.getCode(), e.getMsg()); | 
			
		
	
		
			
				
					|  |  |  |             printWriter.write(JSON.toJSONString(result)); | 
			
		
	
		
			
				
					|  |  |  |             printWriter.close(); | 
			
		
	
		
			
				
					|  |  |  |         } catch (Exception e) { | 
			
		
	
		
			
				
					|  |  |  |             log.error("物业管理导出异常export exception", e); | 
			
		
	
		
			
				
					|  |  |  |         } finally { | 
			
		
	
		
			
				
					|  |  |  |             if (excelWriter != null) { | 
			
		
	
		
			
				
					|  |  |  |                 excelWriter.finish(); | 
			
		
	
		
			
				
					|  |  |  |             } | 
			
		
	
		
			
				
					|  |  |  |         } | 
			
		
	
		
			
				
					|  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     /** | 
			
		
	
		
			
				
					|  |  |  |      * 获取物业详情 | 
			
		
	
		
			
				
					|  |  |  |      * | 
			
		
	
		
			
				
					|  |  |  |      * @param id | 
			
		
	
		
			
				
					|  |  |  |      * @return | 
			
		
	
		
			
				
					|  |  |  |      */ | 
			
		
	
		
			
				
					|  |  |  |     @PostMapping("detail/{id}") | 
			
		
	
		
			
				
					|  |  |  |     public Result<IcPropertyManagementDTO> getDetail(@PathVariable("id") String id) { | 
			
		
	
		
			
				
					|  |  |  |         if (StringUtils.isBlank(id)) { | 
			
		
	
		
			
				
					|  |  |  |             return new Result<>(); | 
			
		
	
		
			
				
					|  |  |  |         } | 
			
		
	
		
			
				
					|  |  |  |         return new Result<IcPropertyManagementDTO>().ok(propertyManagementService.getDetail(id)); | 
			
		
	
		
			
				
					|  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | } |