From ebcd55bbbeeabdcf775cb6f3a37e8255fcb2870a Mon Sep 17 00:00:00 2001 From: luyie Date: Fri, 23 Aug 2024 17:08:23 +0800 Subject: [PATCH 1/2] =?UTF-8?q?add:=E5=A4=A7=E6=A8=A1=E5=9E=8B=E5=A4=B1?= =?UTF-8?q?=E8=B4=A5=EF=BC=8C=E5=BC=82=E5=B8=B8=E4=BB=A3=E7=A0=81?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../bigmodel/zhipuai/constants/ErrorCode.java | 57 ++++++++++++++++++++++ .../zhipuai/handler/ResultBooleanStrategy.java | 16 ++++-- .../zhipuai/handler/ZhipuAnalysisHandlerGlm4v.java | 8 +-- .../service/impl/ZhipuAnalysisServiceImpl.java | 55 +++++++++++---------- 4 files changed, 100 insertions(+), 36 deletions(-) create mode 100644 hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/zhipuai/constants/ErrorCode.java diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/zhipuai/constants/ErrorCode.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/zhipuai/constants/ErrorCode.java new file mode 100644 index 0000000..c6f5d74 --- /dev/null +++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/zhipuai/constants/ErrorCode.java @@ -0,0 +1,57 @@ +package com.hnac.hzims.bigmodel.zhipuai.constants; + +import com.hnac.hzinfo.exception.HzServiceException; +import lombok.Getter; +import org.springblade.core.tool.api.IResultCode; +import org.springblade.core.tool.api.ResultCode; + +/** + * @Author: ypj + * @Date: 2024/8/22 11:17 + */ +@Getter +public enum ErrorCode implements IResultCode { + + GET_DATA_FAILURE(1888000001, "获取数据失败"), + ANALYSIS_FAILURE(1888000002, "分析失败"), + STRATEGY_NOT_FOUND(1888000003, "策略未找到"), + GET_FILE_CONTENT_FAILURE(1888000004, "获取文件内容失败"), + REQUEST_TEXT_IS_EMPTY(1888000005, "交互文字内容不能为空"), + EMPTY_ANALYSIS_TYPE(1888000006, "识别类型为空"), + UNKNOWN_ANALYSIS_TYPE(1888000007, "未知的识别类型"), + NO_COMPARATOR(1888000008, "未获取到对比对象"), + NO_COMPARISON_TYPE(1888000009, "未获取到对比类型"), + GET_RESULT_FAIL(1888000010, "获取结果失败"),; + + private final int code; + private final String msg; + + ErrorCode(int code, String msg) { + this.code = code; + this.msg = msg; + } + + + @Override + public String getMessage() { + return this.msg; + } + + public HzServiceException throwException() { + return new HzServiceException(this); + } + + public static HzServiceException throwCommonException(String msg) { + return new HzServiceException(new IResultCode() { + @Override + public String getMessage() { + return msg; + } + + @Override + public int getCode() { + return ResultCode.FAILURE.getCode(); + } + }); + } +} diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/zhipuai/handler/ResultBooleanStrategy.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/zhipuai/handler/ResultBooleanStrategy.java index e2a85bd..477c3a8 100644 --- a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/zhipuai/handler/ResultBooleanStrategy.java +++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/zhipuai/handler/ResultBooleanStrategy.java @@ -2,9 +2,9 @@ package com.hnac.hzims.bigmodel.zhipuai.handler; import com.hnac.hzims.bigmodel.zhipuai.constants.BaseEnum; import com.hnac.hzims.bigmodel.zhipuai.constants.ComparisonType; +import com.hnac.hzims.bigmodel.zhipuai.constants.ErrorCode; import com.hnac.hzims.bigmodel.zhipuai.constants.ResultStrategyType; import com.hnac.hzims.bigmodel.zhipuai.entity.ZhipuAnalysisInfoEntity; -import com.hnac.hzinfo.exception.HzServiceException; import org.springframework.util.Assert; import java.util.Objects; @@ -23,18 +23,24 @@ public class ResultBooleanStrategy implements ResultStrategy { public Boolean getResult(ZhipuAnalysisInfoEntity info, Object resultData) { Object comparator = convertOriginalData(info.getResultCondition(), info.getResultType()); Assert.isTrue(Objects.nonNull(comparator), () -> { - throw new HzServiceException("没有获取到对比对象"); + throw ErrorCode.NO_COMPARATOR.throwException(); }); ComparisonType comparisonType = BaseEnum.getInstance(info.getResultJudgeModel(), ComparisonType.class); - switch (comparisonType) { + Assert.isTrue(Objects.nonNull(comparisonType), () -> { + throw ErrorCode.NO_COMPARISON_TYPE.throwException(); + }); + switch (Objects.requireNonNull(comparisonType)) { case EQUAL: return comparator.equals(resultData); case GREATER: - return ((Comparable) comparator).compareTo(resultData) < 0; + if (comparator instanceof Comparable && resultData instanceof Comparable) { + return ((Comparable) comparator).compareTo((Comparable)resultData) < 0; + } + break; case LESS: return ((Comparable) comparator).compareTo(resultData) > 0; } - return null; + throw ErrorCode.GET_RESULT_FAIL.throwException(); } } diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/zhipuai/handler/ZhipuAnalysisHandlerGlm4v.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/zhipuai/handler/ZhipuAnalysisHandlerGlm4v.java index 0f0925a..6e98f7b 100644 --- a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/zhipuai/handler/ZhipuAnalysisHandlerGlm4v.java +++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/zhipuai/handler/ZhipuAnalysisHandlerGlm4v.java @@ -1,6 +1,7 @@ package com.hnac.hzims.bigmodel.zhipuai.handler; import cn.hutool.core.lang.Assert; +import com.hnac.hzims.bigmodel.zhipuai.constants.ErrorCode; import com.hnac.hzinfo.exception.HzServiceException; import com.zhipu.oapi.Constants; import com.zhipu.oapi.service.v4.model.ChatCompletionRequest; @@ -58,14 +59,13 @@ public class ZhipuAnalysisHandlerGlm4v extends AbstractZhipuAnalysisHandler { messages.add(chatMessage); String requestId = String.format(requestIdTemplate, System.currentTimeMillis()); - ChatCompletionRequest request = ChatCompletionRequest.builder() + return ChatCompletionRequest.builder() .model(getAnalysisModel()) .stream(Boolean.FALSE) .invokeMethod(Constants.invokeMethod) .messages(messages) .requestId(requestId) .build(); - return request; } @Override @@ -73,7 +73,7 @@ public class ZhipuAnalysisHandlerGlm4v extends AbstractZhipuAnalysisHandler { ModelApiResponse response = sendRequest(text, url); log.info("get zhi pu ai response : {}", Optional.ofNullable(response).map(JsonUtil::toJson).orElse("null")); Assert.isTrue(Objects.nonNull(response) && response.isSuccess(), () -> { - throw new HzServiceException(response.getMsg()); + throw ErrorCode.throwCommonException(Optional.ofNullable(response).map(ModelApiResponse::getMsg).orElse("没有收到大模型平台响应")); }); try { String resultJson = response.getData().getChoices().get(0).getMessage().getContent().toString(); @@ -81,7 +81,7 @@ public class ZhipuAnalysisHandlerGlm4v extends AbstractZhipuAnalysisHandler { return resultJson; } catch (Exception e) { log.info("get data from response error", e); - throw new HzServiceException("获取数据失败"); + throw ErrorCode.GET_DATA_FAILURE.throwException(); } } diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/zhipuai/service/impl/ZhipuAnalysisServiceImpl.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/zhipuai/service/impl/ZhipuAnalysisServiceImpl.java index d3b9a78..0afde6f 100644 --- a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/zhipuai/service/impl/ZhipuAnalysisServiceImpl.java +++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/zhipuai/service/impl/ZhipuAnalysisServiceImpl.java @@ -4,6 +4,7 @@ import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.hnac.hzims.bigmodel.api.dto.BigModelAnalysisRequestDTO; import com.hnac.hzims.bigmodel.api.dto.BigModelAnalysisResponseDTO; import com.hnac.hzims.bigmodel.zhipuai.constants.BaseEnum; +import com.hnac.hzims.bigmodel.zhipuai.constants.ErrorCode; import com.hnac.hzims.bigmodel.zhipuai.constants.ResultStrategyType; import com.hnac.hzims.bigmodel.zhipuai.entity.ZhipuAnalysisInfoEntity; import com.hnac.hzims.bigmodel.zhipuai.handler.ResultStrategy; @@ -41,29 +42,29 @@ public class ZhipuAnalysisServiceImpl implements ZhipuAnalysisService { private final ZhipuAnalysisInfoService infoService; - private final String multiQuestionBrief = "从给出的图片回答以下{}个问题\n"; + private static final String MULTI_QUESTION_BRIEF = "从给出的图片回答以下{}个问题\n"; - private final String multiQuestionPrefix = "第{}个问题,"; + private static final String MULTI_QUESTION_PREFIX = "第{}个问题,"; - private final String multiQuestionConstrains = "- 不要在输出中添加任何注释和思考过程和其他多余的内容,以JSON格式输出简单结果,{}结果只包含'是'或者'否'\n"; + private static final String MULTI_QUESTION_CONSTRAINS = "- 不要在输出中添加任何注释和思考过程和其他多余的内容,以JSON格式输出简单结果,{}结果只包含'是'或者'否'\n"; - private final String multiQuestionConstrainsList = "'{}'代表第{}个问题,"; + private static final String MULTI_QUESTION_CONSTRAINS_LIST = "'{}'代表第{}个问题,"; @Override public ZhipuAnalysisFileResponse analysis(ZhipuAnalysisFileRequest request) { Assert.isTrue(StringUtil.isNotBlank(request.getFilePath()) || StringUtil.isNotBlank(request.getUrl()), () -> { - throw new HzServiceException("文件为空"); + throw ErrorCode.GET_FILE_CONTENT_FAILURE.throwException(); }); ZhipuAnalysisFileResponse response = new ZhipuAnalysisFileResponse(); ZhipuAnalysisInfoEntity info = getAnalysisInfo(request); Assert.isTrue(Objects.nonNull(info), () -> { - throw new HzServiceException("没有找到对应的策略信息"); + throw ErrorCode.STRATEGY_NOT_FOUND.throwException(); }); ZhipuAnalyser analyser = analysisFactory.getAnalysisStrategy(info.getModel()); Assert.isTrue(StringUtil.isNotBlank(info.getRequestContent()), () -> { - throw new HzServiceException("智谱平台交互内容为空"); + throw ErrorCode.REQUEST_TEXT_IS_EMPTY.throwException(); }); //拼接文字内容 StringBuilder textBuilder = new StringBuilder(); @@ -78,13 +79,13 @@ public class ZhipuAnalysisServiceImpl implements ZhipuAnalysisService { Object resultObject = analyser.getResultValue(analyser.getText(), info.getResultKey(), getSendUrl(request)); Assert.isTrue(Objects.nonNull(resultObject), () -> { - throw new HzServiceException("智谱平台分析失败"); + throw ErrorCode.ANALYSIS_FAILURE.throwException(); }); String resultStr = resultObject.toString(); ResultStrategyType strategyType = BaseEnum.getInstance(info.getResultStrategy(), ResultStrategyType.class); Assert.isTrue(Objects.nonNull(strategyType), () -> { - throw new HzServiceException("没有找到对应的结果数据解析策略"); + throw ErrorCode.STRATEGY_NOT_FOUND.throwException(); }); ResultStrategy strategy = strategyType.getStrategy(); @@ -100,14 +101,14 @@ public class ZhipuAnalysisServiceImpl implements ZhipuAnalysisService { if (StringUtil.isNotBlank(request.getUrl())) { return request.getUrl(); } - if (StringUtil.isNotBlank(request.getFilePath())) { - try { - return FileUtil.getBase64(request.getFilePath()); - } catch (IOException e) { - throw new HzServiceException("获取文件内容失败"); - } + Assert.isTrue(StringUtil.isNotBlank(request.getFilePath()), () -> { + throw ErrorCode.GET_FILE_CONTENT_FAILURE.throwException(); + }); + try { + return FileUtil.getBase64(request.getFilePath()); + } catch (IOException e) { + throw ErrorCode.GET_FILE_CONTENT_FAILURE.throwException(); } - return null; } @Override @@ -121,7 +122,7 @@ public class ZhipuAnalysisServiceImpl implements ZhipuAnalysisService { .eq(StringUtil.isNotBlank(request.getCheckTypeSon()), ZhipuAnalysisInfoEntity::getCheckTypeSon, request.getCheckTypeSon()) .last("limit 1;")); } - log.info("the analysis information is {}", Optional.ofNullable(result).map(r -> JsonUtil.toJson(r)).orElse("null")); + log.debug("the analysis information is {}", Optional.ofNullable(result).map(r -> JsonUtil.toJson(r)).orElse("null")); return result; } @@ -131,15 +132,15 @@ public class ZhipuAnalysisServiceImpl implements ZhipuAnalysisService { BigModelAnalysisResponseDTO response = new BigModelAnalysisResponseDTO(); try { Assert.isTrue(StringUtil.isNotBlank(request.getUrl()), () -> { - throw new HzServiceException("文件为空"); + throw ErrorCode.GET_FILE_CONTENT_FAILURE.throwException(); }); Assert.isTrue(CollectionUtil.isNotEmpty(request.getCodeList()) || CollectionUtil.isNotEmpty(request.getCheckTypeSonList()), () -> { - throw new HzServiceException("识别类型为空"); + throw ErrorCode.EMPTY_ANALYSIS_TYPE.throwException(); }); List infoList = infoService.list(Wrappers.lambdaQuery().in(CollectionUtil.isNotEmpty(request.getCodeList()), ZhipuAnalysisInfoEntity::getCode, request.getCodeList()) .in(CollectionUtil.isNotEmpty(request.getCheckTypeSonList()), ZhipuAnalysisInfoEntity::getCheckTypeSon, request.getCheckTypeSonList())); Assert.isTrue(CollectionUtil.isNotEmpty(infoList), () -> { - throw new HzServiceException("未知的识别类型"); + throw ErrorCode.UNKNOWN_ANALYSIS_TYPE.throwException(); }); ZhipuAnalyser analyser = analysisFactory.getAnalysisStrategy(infoList.get(0).getModel()); @@ -148,7 +149,7 @@ public class ZhipuAnalysisServiceImpl implements ZhipuAnalysisService { if (null == resultMap) { response.setCode(ResultCode.FAILURE.getCode()); - response.setMsg("智谱大模型分析失败"); + response.setMsg(ErrorCode.ANALYSIS_FAILURE.getMsg()); return response; } @@ -184,9 +185,9 @@ public class ZhipuAnalysisServiceImpl implements ZhipuAnalysisService { response.setMsg(e.getMessage()); } else { response.setCode(ResultCode.FAILURE.getCode()); - response.setMsg("智谱大模型分析失败"); + response.setMsg(ErrorCode.ANALYSIS_FAILURE.getMsg()); } - log.error("智谱大模型分析失败", e); + log.error(ErrorCode.ANALYSIS_FAILURE.getMessage(), e); } return response; } @@ -196,18 +197,18 @@ public class ZhipuAnalysisServiceImpl implements ZhipuAnalysisService { StringBuilder titleBuilder = new StringBuilder(); StringBuilder formatBuilder = new StringBuilder(); stringBuilder.append(ZhipuAnalyser.QUESTION_PROFILE) - .append(StringUtil.format(multiQuestionBrief, infoList.size())); + .append(StringUtil.format(MULTI_QUESTION_BRIEF, infoList.size())); formatBuilder.append("{"); for (int index = 1; index <= infoList.size(); index++) { ZhipuAnalysisInfoEntity infoEntity = infoList.get(index - 1); - stringBuilder.append(StringUtil.format(multiQuestionPrefix, index)); - titleBuilder.append(StringUtil.format(multiQuestionConstrainsList, infoEntity.getResultKey(), index)); + stringBuilder.append(StringUtil.format(MULTI_QUESTION_PREFIX, index)); + titleBuilder.append(StringUtil.format(MULTI_QUESTION_CONSTRAINS_LIST, infoEntity.getResultKey(), index)); formatBuilder.append(infoEntity.getRequestOutputFormat()).append(","); } formatBuilder.deleteCharAt(formatBuilder.length() - 1); formatBuilder.append("}"); stringBuilder.append(ZhipuAnalyser.QUESTION_CONSTRAINS) - .append(StringUtil.format(multiQuestionConstrains, titleBuilder.toString())) + .append(StringUtil.format(MULTI_QUESTION_CONSTRAINS, titleBuilder.toString())) .append(ZhipuAnalyser.QUESTION_OUTPUT_FORMAT).append(formatBuilder); return stringBuilder.toString(); } From 3b55e5954a872f26f996c3c2f6debfbb9f72801c Mon Sep 17 00:00:00 2001 From: liwen Date: Mon, 26 Aug 2024 09:20:47 +0800 Subject: [PATCH 2/2] =?UTF-8?q?update:=20=E5=AE=89=E5=85=A8=E6=A8=A1?= =?UTF-8?q?=E5=9D=97=E5=AF=BC=E5=87=BA=E5=8A=9F=E8=83=BD=E4=BC=98=E5=8C=96?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../safeproduct/vo/CarMaintenanceDetailImgVO.java | 22 ++++++++++++ .../safeproduct/vo/CarMaintenanceDetailStrVO.java | 21 +++++++++++ .../safeproduct/vo/CarMaintenanceDetailVO.java | 5 --- .../safeproduct/vo/CarUsedRecordDetailImgVO.java | 22 ++++++++++++ .../safeproduct/vo/CarUsedRecordDetailStrVO.java | 21 +++++++++++ .../safeproduct/vo/CarUsedRecordDetailVO.java | 5 --- .../vo/ConferenceRecordDetailImgVO.java | 22 ++++++++++++ .../vo/ConferenceRecordDetailStrVO.java | 21 +++++++++++ .../safeproduct/vo/ConferenceRecordDetailVO.java | 7 ---- .../safeproduct/vo/RehearsalRecordDetailImgVO.java | 6 ++-- .../safeproduct/vo/RehearsalRecordDetailStrVO.java | 6 ++-- .../safeproduct/vo/TrainRecordDetailImgVO.java | 22 ++++++++++++ .../safeproduct/vo/TrainRecordDetailStrVO.java | 21 +++++++++++ .../hzims/safeproduct/vo/TrainRecordDetailVO.java | 7 ---- .../safeproduct/controller/CarController.java | 3 +- .../controller/ConferenceController.java | 3 +- .../controller/RehearsalController.java | 3 +- .../safeproduct/controller/TrainController.java | 3 +- .../service/ICarMaintenanceService.java | 1 - .../service/impl/CarMaintenanceServiceImpl.java | 40 +++++++++++++-------- .../service/impl/CarUsedRecordServiceImpl.java | 28 ++++++++++----- .../service/impl/ConferenceRecordServiceImpl.java | 22 ++++++++---- .../service/impl/TrainRecordServiceImpl.java | 35 ++++++++++++------ .../template/卫生考核表(五周).docx | Bin 12280 -> 12350 bytes .../template/卫生考核表(四周).docx | Bin 12116 -> 12196 bytes 25 files changed, 268 insertions(+), 78 deletions(-) create mode 100644 hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/CarMaintenanceDetailImgVO.java create mode 100644 hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/CarMaintenanceDetailStrVO.java create mode 100644 hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/CarUsedRecordDetailImgVO.java create mode 100644 hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/CarUsedRecordDetailStrVO.java create mode 100644 hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/ConferenceRecordDetailImgVO.java create mode 100644 hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/ConferenceRecordDetailStrVO.java create mode 100644 hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/TrainRecordDetailImgVO.java create mode 100644 hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/TrainRecordDetailStrVO.java diff --git a/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/CarMaintenanceDetailImgVO.java b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/CarMaintenanceDetailImgVO.java new file mode 100644 index 0000000..c75df94 --- /dev/null +++ b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/CarMaintenanceDetailImgVO.java @@ -0,0 +1,22 @@ +package com.hnac.hzims.safeproduct.vo; + +import cn.afterturn.easypoi.entity.ImageEntity; +import io.swagger.annotations.ApiModel; +import io.swagger.annotations.ApiModelProperty; +import lombok.Data; +import lombok.EqualsAndHashCode; + +import java.util.List; + +/** + * @author liwen + * @date 2024-08-23 + */ +@Data +@EqualsAndHashCode(callSuper = true) +@ApiModel(value = "车辆维保记录VO类-图片实体类") +public class CarMaintenanceDetailImgVO extends CarMaintenanceDetailVO { + + @ApiModelProperty("图片列表") + private List images; +} diff --git a/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/CarMaintenanceDetailStrVO.java b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/CarMaintenanceDetailStrVO.java new file mode 100644 index 0000000..c8f8e75 --- /dev/null +++ b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/CarMaintenanceDetailStrVO.java @@ -0,0 +1,21 @@ +package com.hnac.hzims.safeproduct.vo; + +import io.swagger.annotations.ApiModel; +import io.swagger.annotations.ApiModelProperty; +import lombok.Data; +import lombok.EqualsAndHashCode; + +import java.util.List; + +/** + * @author liwen + * @date 2024-08-23 + */ +@Data +@EqualsAndHashCode(callSuper = true) +@ApiModel(value = "车辆维保记录VO类-图片字符串类") +public class CarMaintenanceDetailStrVO extends CarMaintenanceDetailVO { + + @ApiModelProperty("图片列表") + private List images; +} diff --git a/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/CarMaintenanceDetailVO.java b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/CarMaintenanceDetailVO.java index 554bd7b..8d18ae4 100644 --- a/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/CarMaintenanceDetailVO.java +++ b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/CarMaintenanceDetailVO.java @@ -1,12 +1,10 @@ package com.hnac.hzims.safeproduct.vo; -import cn.afterturn.easypoi.entity.ImageEntity; import io.swagger.annotations.ApiModel; import io.swagger.annotations.ApiModelProperty; import lombok.Data; import java.util.Date; -import java.util.List; /** * @author liwen @@ -64,9 +62,6 @@ public class CarMaintenanceDetailVO { @ApiModelProperty("维保类型") private String maintenanceType; - @ApiModelProperty("图片列表") - private List images; - @ApiModelProperty("年份") private String year; diff --git a/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/CarUsedRecordDetailImgVO.java b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/CarUsedRecordDetailImgVO.java new file mode 100644 index 0000000..6310c23 --- /dev/null +++ b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/CarUsedRecordDetailImgVO.java @@ -0,0 +1,22 @@ +package com.hnac.hzims.safeproduct.vo; + +import cn.afterturn.easypoi.entity.ImageEntity; +import io.swagger.annotations.ApiModel; +import io.swagger.annotations.ApiModelProperty; +import lombok.Data; +import lombok.EqualsAndHashCode; + +import java.util.List; + +/** + * @author liwen + * @date 2024-08-23 + */ +@Data +@EqualsAndHashCode(callSuper = true) +@ApiModel(value = "车辆用车记录VO类-图片实体类") +public class CarUsedRecordDetailImgVO extends CarUsedRecordDetailVO { + + @ApiModelProperty("图片列表") + private List images; +} diff --git a/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/CarUsedRecordDetailStrVO.java b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/CarUsedRecordDetailStrVO.java new file mode 100644 index 0000000..2d5f620 --- /dev/null +++ b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/CarUsedRecordDetailStrVO.java @@ -0,0 +1,21 @@ +package com.hnac.hzims.safeproduct.vo; + +import io.swagger.annotations.ApiModel; +import io.swagger.annotations.ApiModelProperty; +import lombok.Data; +import lombok.EqualsAndHashCode; + +import java.util.List; + +/** + * @author liwen + * @date 2024-08-23 + */ +@Data +@EqualsAndHashCode(callSuper = true) +@ApiModel(value = "车辆用车记录VO类-图片字符串类") +public class CarUsedRecordDetailStrVO extends CarUsedRecordDetailVO { + + @ApiModelProperty("图片列表") + private List images; +} diff --git a/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/CarUsedRecordDetailVO.java b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/CarUsedRecordDetailVO.java index 50564f4..5f496bd 100644 --- a/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/CarUsedRecordDetailVO.java +++ b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/CarUsedRecordDetailVO.java @@ -1,13 +1,11 @@ package com.hnac.hzims.safeproduct.vo; -import cn.afterturn.easypoi.entity.ImageEntity; import io.swagger.annotations.ApiModel; import io.swagger.annotations.ApiModelProperty; import lombok.Data; import java.math.BigDecimal; import java.util.Date; -import java.util.List; /** * @author liwen @@ -65,9 +63,6 @@ public class CarUsedRecordDetailVO { @ApiModelProperty("确认时间") private Date confirmationTime; - @ApiModelProperty("图片列表") - private List images; - @ApiModelProperty("年份") private String year; diff --git a/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/ConferenceRecordDetailImgVO.java b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/ConferenceRecordDetailImgVO.java new file mode 100644 index 0000000..839ac6a --- /dev/null +++ b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/ConferenceRecordDetailImgVO.java @@ -0,0 +1,22 @@ +package com.hnac.hzims.safeproduct.vo; + +import cn.afterturn.easypoi.entity.ImageEntity; +import io.swagger.annotations.ApiModel; +import io.swagger.annotations.ApiModelProperty; +import lombok.Data; +import lombok.EqualsAndHashCode; + +import java.util.List; + +/** + * @author liwen + * @date 2024-08-23 + */ +@Data +@EqualsAndHashCode(callSuper = true) +@ApiModel(value = "会议记录VO类-图片实体类") +public class ConferenceRecordDetailImgVO extends ConferenceRecordDetailVO { + + @ApiModelProperty("图片列表") + private List images; +} diff --git a/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/ConferenceRecordDetailStrVO.java b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/ConferenceRecordDetailStrVO.java new file mode 100644 index 0000000..2650b11 --- /dev/null +++ b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/ConferenceRecordDetailStrVO.java @@ -0,0 +1,21 @@ +package com.hnac.hzims.safeproduct.vo; + +import io.swagger.annotations.ApiModel; +import io.swagger.annotations.ApiModelProperty; +import lombok.Data; +import lombok.EqualsAndHashCode; + +import java.util.List; + +/** + * @author liwen + * @date 2024-08-23 + */ +@Data +@EqualsAndHashCode(callSuper = true) +@ApiModel(value = "会议记录VO类-图片实体类") +public class ConferenceRecordDetailStrVO extends ConferenceRecordDetailVO { + + @ApiModelProperty("图片列表") + private List images; +} diff --git a/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/ConferenceRecordDetailVO.java b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/ConferenceRecordDetailVO.java index 6bfaadb..7abdf86 100644 --- a/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/ConferenceRecordDetailVO.java +++ b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/ConferenceRecordDetailVO.java @@ -1,13 +1,9 @@ package com.hnac.hzims.safeproduct.vo; -import cn.afterturn.easypoi.entity.ImageEntity; import io.swagger.annotations.ApiModel; import io.swagger.annotations.ApiModelProperty; import lombok.Data; -import java.util.Date; -import java.util.List; - /** * @author liwen * @date 2024-01-15 @@ -55,9 +51,6 @@ public class ConferenceRecordDetailVO { @ApiModelProperty("会议附件") private String filePath; - @ApiModelProperty("图片列表") - private List images; - @ApiModelProperty("年份") private String year; diff --git a/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/RehearsalRecordDetailImgVO.java b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/RehearsalRecordDetailImgVO.java index abb312d..bbd34fa 100644 --- a/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/RehearsalRecordDetailImgVO.java +++ b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/RehearsalRecordDetailImgVO.java @@ -4,12 +4,14 @@ import cn.afterturn.easypoi.entity.ImageEntity; import io.swagger.annotations.ApiModel; import io.swagger.annotations.ApiModelProperty; import lombok.Data; +import lombok.EqualsAndHashCode; import java.util.List; @Data -@ApiModel(value = "演练记录表VO类") -public class RehearsalRecordDetailImgVO extends RehearsalRecordDetailVO{ +@EqualsAndHashCode(callSuper = true) +@ApiModel(value = "演练记录表VO类-图片实体类") +public class RehearsalRecordDetailImgVO extends RehearsalRecordDetailVO { @ApiModelProperty("图片列表") private List images; diff --git a/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/RehearsalRecordDetailStrVO.java b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/RehearsalRecordDetailStrVO.java index 2a7c8bf..953a997 100644 --- a/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/RehearsalRecordDetailStrVO.java +++ b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/RehearsalRecordDetailStrVO.java @@ -3,12 +3,14 @@ package com.hnac.hzims.safeproduct.vo; import io.swagger.annotations.ApiModel; import io.swagger.annotations.ApiModelProperty; import lombok.Data; +import lombok.EqualsAndHashCode; import java.util.List; @Data -@ApiModel(value = "演练记录表VO类") -public class RehearsalRecordDetailStrVO extends RehearsalRecordDetailVO{ +@EqualsAndHashCode(callSuper = true) +@ApiModel(value = "演练记录表VO类-图片字符串类") +public class RehearsalRecordDetailStrVO extends RehearsalRecordDetailVO { @ApiModelProperty("图片列表") private List images; diff --git a/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/TrainRecordDetailImgVO.java b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/TrainRecordDetailImgVO.java new file mode 100644 index 0000000..6d5724a --- /dev/null +++ b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/TrainRecordDetailImgVO.java @@ -0,0 +1,22 @@ +package com.hnac.hzims.safeproduct.vo; + +import cn.afterturn.easypoi.entity.ImageEntity; +import io.swagger.annotations.ApiModel; +import io.swagger.annotations.ApiModelProperty; +import lombok.Data; +import lombok.EqualsAndHashCode; + +import java.util.List; + +/** + * @author liwen + * @date 2024-08-23 + */ +@Data +@EqualsAndHashCode(callSuper = true) +@ApiModel(value = "培训记录表VO类-图片实体类") +public class TrainRecordDetailImgVO extends TrainRecordDetailVO { + + @ApiModelProperty("图片列表") + private List images; +} diff --git a/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/TrainRecordDetailStrVO.java b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/TrainRecordDetailStrVO.java new file mode 100644 index 0000000..a5a23f9 --- /dev/null +++ b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/TrainRecordDetailStrVO.java @@ -0,0 +1,21 @@ +package com.hnac.hzims.safeproduct.vo; + +import io.swagger.annotations.ApiModel; +import io.swagger.annotations.ApiModelProperty; +import lombok.Data; +import lombok.EqualsAndHashCode; + +import java.util.List; + +/** + * @author liwen + * @date 2024-08-23 + */ +@Data +@EqualsAndHashCode(callSuper = true) +@ApiModel(value = "培训记录表VO类-图片字符串类") +public class TrainRecordDetailStrVO extends TrainRecordDetailVO { + + @ApiModelProperty("图片列表") + private List images; +} diff --git a/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/TrainRecordDetailVO.java b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/TrainRecordDetailVO.java index e8850de..2eb2148 100644 --- a/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/TrainRecordDetailVO.java +++ b/hzims-service-api/safeproduct-api/src/main/java/com/hnac/hzims/safeproduct/vo/TrainRecordDetailVO.java @@ -1,13 +1,9 @@ package com.hnac.hzims.safeproduct.vo; -import cn.afterturn.easypoi.entity.ImageEntity; import io.swagger.annotations.ApiModel; import io.swagger.annotations.ApiModelProperty; import lombok.Data; -import java.util.Date; -import java.util.List; - /** * @author liwen * @date 2024-01-15 @@ -55,9 +51,6 @@ public class TrainRecordDetailVO { @ApiModelProperty("培训附件") private String filePath; - @ApiModelProperty("图片列表") - private List images; - @ApiModelProperty("年份") private String year; diff --git a/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/controller/CarController.java b/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/controller/CarController.java index d88ca90..33d77e2 100644 --- a/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/controller/CarController.java +++ b/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/controller/CarController.java @@ -19,7 +19,6 @@ import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; import io.swagger.annotations.ApiOperation; import lombok.AllArgsConstructor; -import org.springblade.core.boot.ctrl.BladeController; import org.springblade.core.mp.support.Query; import org.springblade.core.tool.api.R; import org.springframework.web.bind.annotation.*; @@ -41,7 +40,7 @@ import java.util.Map; @AllArgsConstructor @Business(module = Constants.APP_NAME, value = "车辆管理", ignore = false) @Api(value = "车辆管理", tags = "车辆管理接口") -public class CarController extends BladeController { +public class CarController { private final ICarService carService; diff --git a/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/controller/ConferenceController.java b/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/controller/ConferenceController.java index 119188f..fcd7aac 100644 --- a/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/controller/ConferenceController.java +++ b/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/controller/ConferenceController.java @@ -17,7 +17,6 @@ import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; import io.swagger.annotations.ApiOperation; import lombok.AllArgsConstructor; -import org.springblade.core.boot.ctrl.BladeController; import org.springblade.core.mp.support.Query; import org.springblade.core.tool.api.R; import org.springframework.web.bind.annotation.*; @@ -38,7 +37,7 @@ import java.util.Map; @RequestMapping("/conference") @Business(module = Constants.APP_NAME, value = "会议管理", ignore = false) @Api(value = "会议管理", tags = "会议管理接口") -public class ConferenceController extends BladeController { +public class ConferenceController { private final IConferencePlanService conferencePlanService; diff --git a/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/controller/RehearsalController.java b/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/controller/RehearsalController.java index 08d28ce..af81138 100644 --- a/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/controller/RehearsalController.java +++ b/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/controller/RehearsalController.java @@ -19,7 +19,6 @@ import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; import io.swagger.annotations.ApiOperation; import lombok.AllArgsConstructor; -import org.springblade.core.boot.ctrl.BladeController; import org.springblade.core.mp.support.Query; import org.springblade.core.tool.api.R; import org.springframework.web.bind.annotation.*; @@ -40,7 +39,7 @@ import java.util.Map; @RequestMapping("/rehearsal") @Business(module = Constants.APP_NAME, value = "演练管理", ignore = false) @Api(value = "演练管理", tags = "演练管理接口") -public class RehearsalController extends BladeController { +public class RehearsalController { private final IRehearsalRecordService rehearsalRecordService; diff --git a/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/controller/TrainController.java b/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/controller/TrainController.java index ef252f9..3c39c65 100644 --- a/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/controller/TrainController.java +++ b/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/controller/TrainController.java @@ -23,7 +23,6 @@ import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; import io.swagger.annotations.ApiOperation; import lombok.AllArgsConstructor; -import org.springblade.core.boot.ctrl.BladeController; import org.springblade.core.mp.support.Query; import org.springblade.core.tool.api.R; import org.springframework.web.bind.annotation.*; @@ -45,7 +44,7 @@ import java.util.Map; @RequestMapping("/train") @Business(module = Constants.APP_NAME, value = "培训管理", ignore = false) @Api(value = "培训管理", tags = "培训管理接口") -public class TrainController extends BladeController { +public class TrainController { private final ITrainPlanService trainPlanService; diff --git a/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/service/ICarMaintenanceService.java b/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/service/ICarMaintenanceService.java index 7f6531a..1e48db1 100644 --- a/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/service/ICarMaintenanceService.java +++ b/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/service/ICarMaintenanceService.java @@ -10,7 +10,6 @@ import org.springblade.core.mp.support.Query; import org.springblade.core.tool.api.R; import javax.servlet.http.HttpServletResponse; -import java.util.List; import java.util.Map; /** diff --git a/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/service/impl/CarMaintenanceServiceImpl.java b/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/service/impl/CarMaintenanceServiceImpl.java index dec42a9..8da1751 100644 --- a/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/service/impl/CarMaintenanceServiceImpl.java +++ b/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/service/impl/CarMaintenanceServiceImpl.java @@ -17,11 +17,14 @@ import com.hnac.hzims.safeproduct.mapper.CarMaintenanceMapper; import com.hnac.hzims.safeproduct.mapper.CarMapper; import com.hnac.hzims.safeproduct.service.ICarMaintenanceService; import com.hnac.hzims.safeproduct.utils.BaseUtil; +import com.hnac.hzims.safeproduct.vo.CarMaintenanceDetailImgVO; +import com.hnac.hzims.safeproduct.vo.CarMaintenanceDetailStrVO; import com.hnac.hzims.safeproduct.vo.CarMaintenanceDetailVO; import com.hnac.hzims.safeproduct.vo.CarMaintenancePageVO; import org.springblade.core.mp.support.Query; import org.springblade.core.tool.api.R; import org.springblade.core.tool.utils.DateUtil; +import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Service; @@ -123,20 +126,6 @@ public class CarMaintenanceServiceImpl extends ServiceImpl list = new ArrayList<>(); - if (StringUtils.isNotEmpty(carMaintenanceDetailVO.getImgPath())) { - String[] imgArr = carMaintenanceDetailVO.getImgPath().split(","); - for (String img : imgArr) { - ImageEntity imageEntity = new ImageEntity(BaseUtil.imgToByte(savePath + - BaseUtil.downloadFileByUrl(img, savePath)), 180, 150); - list.add(imageEntity); - } - } else { - // 添加空的ImageEntity,防止数据填入时显示"{{" - list.add(new ImageEntity()); - } - carMaintenanceDetailVO.setImages(list); // 表头年月 String code = carMaintenanceDetailVO.getCode(); carMaintenanceDetailVO.setYear(code.substring(4, 8)); @@ -148,7 +137,28 @@ public class CarMaintenanceServiceImpl extends ServiceImpl params = BaseUtil.obj2Map(carMaintenanceDetailVO); + // 图片 + Map params; + if (StringUtils.isNotEmpty(carMaintenanceDetailVO.getImgPath())) { + List list = new ArrayList<>(); + CarMaintenanceDetailImgVO imgVO = new CarMaintenanceDetailImgVO(); + BeanUtils.copyProperties(carMaintenanceDetailVO, imgVO); + String[] imgArr = carMaintenanceDetailVO.getImgPath().split(","); + for (String img : imgArr) { + ImageEntity imageEntity = new ImageEntity(BaseUtil.imgToByte(savePath + + BaseUtil.downloadFileByUrl(img, savePath)), 180, 150); + list.add(imageEntity); + } + imgVO.setImages(list); + params = BaseUtil.obj2Map(imgVO); + } else { + List list = new ArrayList<>(); + list.add(""); + CarMaintenanceDetailStrVO strVO = new CarMaintenanceDetailStrVO(); + BeanUtils.copyProperties(carMaintenanceDetailVO, strVO); + strVO.setImages(list); + params = BaseUtil.obj2Map(strVO); + } String templateFile = "template/车辆维保记录单" + SafeProductConstant.DOCX_SUFFIX; String wordPath = savePath + "/车辆维保记录单" + SafeProductConstant.DOCX_SUFFIX; String pdfPath = savePath + "/车辆维保记录单" + SafeProductConstant.PDF_SUFFIX; diff --git a/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/service/impl/CarUsedRecordServiceImpl.java b/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/service/impl/CarUsedRecordServiceImpl.java index 386e7c5..9c8de83 100644 --- a/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/service/impl/CarUsedRecordServiceImpl.java +++ b/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/service/impl/CarUsedRecordServiceImpl.java @@ -14,11 +14,14 @@ import com.hnac.hzims.safeproduct.enums.CarUsedRecordEnum; import com.hnac.hzims.safeproduct.mapper.CarUsedRecordMapper; import com.hnac.hzims.safeproduct.service.ICarUsedRecordService; import com.hnac.hzims.safeproduct.utils.BaseUtil; +import com.hnac.hzims.safeproduct.vo.CarUsedRecordDetailImgVO; +import com.hnac.hzims.safeproduct.vo.CarUsedRecordDetailStrVO; import com.hnac.hzims.safeproduct.vo.CarUsedRecordDetailVO; import com.hnac.hzims.safeproduct.vo.CarUsedRecordPageVO; import org.springblade.core.mp.support.Query; import org.springblade.core.tool.api.R; import org.springblade.core.tool.utils.DateUtil; +import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Service; import org.springframework.util.CollectionUtils; @@ -117,25 +120,32 @@ public class CarUsedRecordServiceImpl extends ServiceImpl list = new ArrayList<>(); + Map params; if (StringUtils.isNotEmpty(carUsedRecordDetailVO.getImgPath())) { + List list = new ArrayList<>(); + CarUsedRecordDetailImgVO imgVO = new CarUsedRecordDetailImgVO(); + BeanUtils.copyProperties(carUsedRecordDetailVO, imgVO); String[] imgArr = carUsedRecordDetailVO.getImgPath().split(","); for (String img : imgArr) { ImageEntity imageEntity = new ImageEntity(BaseUtil.imgToByte(savePath + BaseUtil.downloadFileByUrl(img, savePath)), 180, 150); list.add(imageEntity); } + imgVO.setImages(list); + params = BaseUtil.obj2Map(imgVO); } else { - // 添加空的ImageEntity,防止数据填入时显示"{{" - list.add(new ImageEntity()); + List list = new ArrayList<>(); + list.add(""); + CarUsedRecordDetailStrVO strVO = new CarUsedRecordDetailStrVO(); + BeanUtils.copyProperties(carUsedRecordDetailVO, strVO); + strVO.setImages(list); + params = BaseUtil.obj2Map(strVO); } - carUsedRecordDetailVO.setImages(list); - // 表头年月 - String code = carUsedRecordDetailVO.getCode(); - carUsedRecordDetailVO.setYear(code.substring(4, 8)); - carUsedRecordDetailVO.setMonth(code.substring(8, 10)); - Map params = BaseUtil.obj2Map(carUsedRecordDetailVO); String templateFile = "template/用车记录单" + SafeProductConstant.DOCX_SUFFIX; String wordPath = savePath + "/用车记录单" + SafeProductConstant.DOCX_SUFFIX; String pdfPath = savePath + "/用车记录单" + SafeProductConstant.PDF_SUFFIX; diff --git a/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/service/impl/ConferenceRecordServiceImpl.java b/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/service/impl/ConferenceRecordServiceImpl.java index b8b4ed6..205a5f5 100644 --- a/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/service/impl/ConferenceRecordServiceImpl.java +++ b/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/service/impl/ConferenceRecordServiceImpl.java @@ -17,9 +17,12 @@ import com.hnac.hzims.safeproduct.mapper.ConferenceRecordMapper; import com.hnac.hzims.safeproduct.service.IConferenceRecordService; import com.hnac.hzims.safeproduct.utils.BaseUtil; import com.hnac.hzims.safeproduct.utils.TimeUtils; +import com.hnac.hzims.safeproduct.vo.ConferenceRecordDetailImgVO; +import com.hnac.hzims.safeproduct.vo.ConferenceRecordDetailStrVO; import com.hnac.hzims.safeproduct.vo.ConferenceRecordDetailVO; import com.hnac.hzims.safeproduct.vo.ConferenceRecordVO; import org.springblade.core.mp.support.Query; +import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; @@ -120,28 +123,33 @@ public class ConferenceRecordServiceImpl extends ServiceImpl list = new ArrayList<>(); + Map params; if (StringUtils.isNotEmpty(conferenceRecordDetailVO.getImgPath())) { + List list = new ArrayList<>(); + ConferenceRecordDetailImgVO imgVO = new ConferenceRecordDetailImgVO(); + BeanUtils.copyProperties(conferenceRecordDetailVO, imgVO); String[] imgArr = conferenceRecordDetailVO.getImgPath().split(","); for (String img : imgArr) { ImageEntity imageEntity = new ImageEntity(BaseUtil.imgToByte(savePath + BaseUtil.downloadFileByUrl(img, savePath)), 180, 150); list.add(imageEntity); } + imgVO.setImages(list); + params = BaseUtil.obj2Map(imgVO); } else { - // 添加空的ImageEntity,防止数据填入时显示"{{" - list.add(new ImageEntity()); + List list = new ArrayList<>(); + list.add(""); + ConferenceRecordDetailStrVO strVO = new ConferenceRecordDetailStrVO(); + BeanUtils.copyProperties(conferenceRecordDetailVO, strVO); + strVO.setImages(list); + params = BaseUtil.obj2Map(strVO); } - conferenceRecordDetailVO.setImages(list); - Map params = BaseUtil.obj2Map(conferenceRecordDetailVO); String templateFile = "template/会议记录表" + SafeProductConstant.DOCX_SUFFIX; String wordPath = savePath + "/会议记录表" + SafeProductConstant.DOCX_SUFFIX; String pdfPath = savePath + "/会议记录表" + SafeProductConstant.PDF_SUFFIX; BaseUtil.exportDocument(templateFile, params, wordPath, pdfPath,"filePath", response); } - - /** * 查询会议记录表详情 */ diff --git a/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/service/impl/TrainRecordServiceImpl.java b/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/service/impl/TrainRecordServiceImpl.java index 4d96ddd..5551eec 100644 --- a/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/service/impl/TrainRecordServiceImpl.java +++ b/hzims-service/safeproduct/src/main/java/com/hnac/hzims/safeproduct/service/impl/TrainRecordServiceImpl.java @@ -19,10 +19,13 @@ import com.hnac.hzims.safeproduct.service.ITestService; import com.hnac.hzims.safeproduct.service.ITrainRecordService; import com.hnac.hzims.safeproduct.utils.BaseUtil; import com.hnac.hzims.safeproduct.utils.TimeUtils; +import com.hnac.hzims.safeproduct.vo.TrainRecordDetailImgVO; +import com.hnac.hzims.safeproduct.vo.TrainRecordDetailStrVO; import com.hnac.hzims.safeproduct.vo.TrainRecordDetailVO; import com.hnac.hzims.safeproduct.vo.TrainRecordVO; import org.springblade.core.mp.support.Query; import org.springblade.core.tool.utils.CollectionUtil; +import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Service; @@ -163,20 +166,32 @@ public class TrainRecordServiceImpl extends ServiceImpl - new ImageEntity(BaseUtil.imgToByte(savePath + BaseUtil.downloadFileByUrl(img, savePath)), 180, 150) - ).collect(Collectors.toList())); - } else { - // 添加空的ImageEntity,防止数据填入时显示"{{" - trainRecordDetailVO.setImages(Collections.singletonList(new ImageEntity())); - } // 表头年月 String code = trainRecordDetailVO.getCode(); trainRecordDetailVO.setYear(code.substring(4, 8)); trainRecordDetailVO.setMonth(code.substring(8, 10)); - Map params = BaseUtil.obj2Map(trainRecordDetailVO); + // 图片 + Map params; + if (StringUtils.isNotEmpty(trainRecordDetailVO.getImgPath())) { + List list = new ArrayList<>(); + TrainRecordDetailImgVO imgVO = new TrainRecordDetailImgVO(); + BeanUtils.copyProperties(trainRecordDetailVO, imgVO); + String[] imgArr = trainRecordDetailVO.getImgPath().split(","); + for (String img : imgArr) { + ImageEntity imageEntity = new ImageEntity(BaseUtil.imgToByte(savePath + + BaseUtil.downloadFileByUrl(img, savePath)), 180, 150); + list.add(imageEntity); + } + imgVO.setImages(list); + params = BaseUtil.obj2Map(imgVO); + } else { + List list = new ArrayList<>(); + list.add(""); + TrainRecordDetailStrVO strVO = new TrainRecordDetailStrVO(); + BeanUtils.copyProperties(trainRecordDetailVO, strVO); + strVO.setImages(list); + params = BaseUtil.obj2Map(strVO); + } String templateFile = "template/培训记录表" + SafeProductConstant.DOCX_SUFFIX; String wordPath = savePath + "/培训记录表" + SafeProductConstant.DOCX_SUFFIX; String pdfPath = savePath + "/培训记录表" + SafeProductConstant.PDF_SUFFIX; diff --git a/hzims-service/safeproduct/src/main/resources/template/卫生考核表(五周).docx b/hzims-service/safeproduct/src/main/resources/template/卫生考核表(五周).docx index 812968828b622a3764d4ad135c21a0b23a3b51c6..e217f447f9309c7afd602d95f59eaa4e0aa7288d 100644 GIT binary patch delta 4877 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 S{u4&^XH5}+K$Zgk-2M+;C?Pxm delta 4732 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 K1`;d)00020&HK0j diff --git a/hzims-service/safeproduct/src/main/resources/template/卫生考核表(四周).docx b/hzims-service/safeproduct/src/main/resources/template/卫生考核表(四周).docx index a91c9f02db9d96bf047eef72ba2cfde21051ed0b..0043a37dbad27dd689defcc2b322ff2b4cd35ed3 100644 GIT binary patch delta 4660 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 delta 4574 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