From 8b7258c9427882bb1798f1502eaa35184c6e374e Mon Sep 17 00:00:00 2001
From: linwe <872216996@qq.com>
Date: Fri, 09 Aug 2024 14:29:18 +0800
Subject: [PATCH] 短信指定楼栋发送
---
src/main/java/org/springblade/modules/answerRecord/service/impl/AnswerRecordServiceImpl.java | 106 +++++++++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 106 insertions(+), 0 deletions(-)
diff --git a/src/main/java/org/springblade/modules/answerRecord/service/impl/AnswerRecordServiceImpl.java b/src/main/java/org/springblade/modules/answerRecord/service/impl/AnswerRecordServiceImpl.java
index f0be066..be1db66 100644
--- a/src/main/java/org/springblade/modules/answerRecord/service/impl/AnswerRecordServiceImpl.java
+++ b/src/main/java/org/springblade/modules/answerRecord/service/impl/AnswerRecordServiceImpl.java
@@ -17,14 +17,24 @@
package org.springblade.modules.answerRecord.service.impl;
import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.core.toolkit.Constants;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import org.springblade.common.constant.CommonConstant;
+import org.springblade.common.utils.SpringUtils;
import org.springblade.modules.answerRecord.dto.AnswerRecordDTO;
import org.springblade.modules.answerRecord.entity.AnswerRecordEntity;
import org.springblade.modules.answerRecord.mapper.AnswerRecordMapper;
import org.springblade.modules.answerRecord.service.IAnswerRecordService;
import org.springblade.modules.answerRecord.vo.AnswerRecordVO;
+import org.springblade.modules.property.entity.PropertyCompanyEntity;
+import org.springblade.modules.property.service.IPropertyCompanyService;
+import org.springblade.modules.subjectChoices.vo.SubjectChoicesVO;
+import org.springblade.modules.subjectOption.vo.SubjectOptionVO;
import org.springframework.stereotype.Service;
+import java.math.BigDecimal;
+import java.util.ArrayList;
import java.util.List;
/**
@@ -63,5 +73,101 @@
return this.baseMapper.selectAnswerRecordList(answerRecordDTO);
}
+ @Override
+ public Boolean saveAnswer(List<SubjectChoicesVO> subjectChoicesVO) {
+ BigDecimal bigDecimal = BigDecimal.valueOf(0);
+ List<AnswerRecordEntity> answerRecordEntityList = new ArrayList<>();
+ // 遍历题目和选项
+ for (SubjectChoicesVO choicesVO : subjectChoicesVO) {
+ List<SubjectOptionVO> subjectOptionList = choicesVO.getSubjectOptionList();
+ if (choicesVO.getChoicesType().intValue() == 3) {
+ bigDecimal = bigDecimal.add(choicesVO.getScore());
+ }
+ for (SubjectOptionVO subjectOptionVO : subjectOptionList) {
+ // 删除掉之前保存的记录
+ remove(Wrappers.<AnswerRecordEntity>lambdaQuery()
+ .eq(AnswerRecordEntity::getPropertyId, choicesVO.getPropertyId())
+ .eq(AnswerRecordEntity::getSubjectChoicesId, choicesVO.getId()));
+ // 判断选项的id
+ if (subjectOptionVO.getId().equals(choicesVO.getChooseId())) {
+ if (CommonConstant.NUMBER_ZERO.equals(choicesVO.getChoicesType().intValue())) {
+ AnswerRecordDTO answerRecordDTO = new AnswerRecordDTO();
+ answerRecordDTO.setPropertyId(choicesVO.getPropertyId());
+ answerRecordDTO.setAnswerOption(subjectOptionVO.getId());
+ answerRecordDTO.setSubjectChoicesId(choicesVO.getId());
+ answerRecordDTO.setSubjectChoicesType(1);
+ answerRecordDTO.setSubjectOptionId(subjectOptionVO.getId());
+ answerRecordEntityList.add(answerRecordDTO);
+ bigDecimal = bigDecimal.add(subjectOptionVO.getScore());
+ break;
+ }
+ }
+ if (CommonConstant.NUMBER_THREE.equals(choicesVO.getChoicesType().intValue())) {
+ AnswerRecordDTO answerRecordDTO = new AnswerRecordDTO();
+ answerRecordDTO.setPropertyId(choicesVO.getPropertyId());
+ answerRecordDTO.setAnswerOption(subjectOptionVO.getId());
+ answerRecordDTO.setSubjectChoicesId(choicesVO.getId());
+ answerRecordDTO.setAnswer(subjectOptionVO.getNumbers());
+ answerRecordDTO.setSubjectOptionId(subjectOptionVO.getId());
+ answerRecordDTO.setSubjectChoicesType(3);
+ answerRecordEntityList.add(answerRecordDTO);
+ BigDecimal multiply = BigDecimal.valueOf(subjectOptionVO.getNumbers()).multiply(subjectOptionVO.getScore());
+ bigDecimal = bigDecimal.subtract(multiply);
+ }
+ }
+ }
+ // 保存得分
+ IPropertyCompanyService bean = SpringUtils.getBean(IPropertyCompanyService.class);
+ PropertyCompanyEntity one = bean.getOne(Wrappers.<PropertyCompanyEntity>lambdaQuery().eq(PropertyCompanyEntity::getId, subjectChoicesVO.get(0).getPropertyId()));
+ if (subjectChoicesVO.get(0).getSubclassName().equals("基础信息")) {
+ one.setBaseInfoScore(bigDecimal);
+ } else if (subjectChoicesVO.get(0).getSubclassName().equals("经营信息")) {
+ one.setOperateinfoScore(bigDecimal);
+ } else if (subjectChoicesVO.get(0).getSubclassName().equals("纳税信息")) {
+ one.setTaxInfoScore(bigDecimal);
+ } else if (subjectChoicesVO.get(0).getSubclassName().equals("党建信息")) {
+ one.setPartyBuildingInfoScore(bigDecimal);
+ bean.update(Wrappers.<PropertyCompanyEntity>lambdaUpdate().set(PropertyCompanyEntity::getPartyBuildingInfoScore, bigDecimal)
+ .eq(PropertyCompanyEntity::getId, subjectChoicesVO.get(0).getPropertyId()));
+ } else if (subjectChoicesVO.get(0).getSubclassName().equals("街道社区")) {
+ one.setStreetScore(bigDecimal);
+ }else if (subjectChoicesVO.get(0).getSubclassName().equals("企业良好行为")) {
+ one.setGoodCorporateScore(bigDecimal);
+ } else if (subjectChoicesVO.get(0).getSubclassName().equals("项目良好行为")) {
+ one.setGoodProjectScore(bigDecimal);
+ } else if (subjectChoicesVO.get(0).getSubclassName().equals("违法违规行为惩戒")) {
+ one.setLllegalAndIrregularScore(bigDecimal);
+ }
+ // 计算总分
+ BigDecimal add = one.getBaseInfoScore()
+ .add(one.getOperateinfoScore())
+ .add(one.getOperateinfoScore())
+ .add(one.getPartyBuildingInfoScore())
+ .add(one.getGoodCorporateScore())
+ .add(one.getGoodProjectScore())
+ .add(one.getLllegalAndIrregularScore())
+ .add(one.getEvaluateScore())
+ .add(one.getStreetScore());
+ one.setAllScore(getAllScore(add));
+ bean.updateById(one);
+ return saveBatch(answerRecordEntityList);
+ }
+
+ /**
+ * 判断结果,如果大于100 则设置100 小于/等于0 设置为0
+ *
+ * @param allScore
+ * @return
+ */
+ private BigDecimal getAllScore(BigDecimal allScore) {
+ if (allScore.compareTo(BigDecimal.valueOf(0)) > 100) {
+ return BigDecimal.valueOf(100);
+ }
+ if (allScore.compareTo(BigDecimal.valueOf(0)) > 0) {
+ return allScore;
+ }
+ return BigDecimal.valueOf(0);
+ }
+
}
--
Gitblit v1.9.3