|
|
@@ -0,0 +1,126 @@
|
|
|
+/*
|
|
|
+ * Copyright 2017-2020 吴学文 and java110 team.
|
|
|
+ *
|
|
|
+ * Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
+ * you may not use this file except in compliance with the License.
|
|
|
+ * You may obtain a copy of the License at
|
|
|
+ *
|
|
|
+ * http://www.apache.org/licenses/LICENSE-2.0
|
|
|
+ *
|
|
|
+ * Unless required by applicable law or agreed to in writing, software
|
|
|
+ * distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
+ * See the License for the specific language governing permissions and
|
|
|
+ * limitations under the License.
|
|
|
+ */
|
|
|
+package com.java110.user.cmd.question;
|
|
|
+
|
|
|
+import com.alibaba.fastjson.JSONObject;
|
|
|
+import com.java110.core.annotation.Java110Cmd;
|
|
|
+import com.java110.core.context.ICmdDataFlowContext;
|
|
|
+import com.java110.core.event.cmd.Cmd;
|
|
|
+import com.java110.core.event.cmd.CmdEvent;
|
|
|
+import com.java110.dto.user.UserQuestionAnswerValueDto;
|
|
|
+import com.java110.intf.user.IUserQuestionAnswerV1InnerServiceSMO;
|
|
|
+import com.java110.intf.user.IUserQuestionAnswerValueV1InnerServiceSMO;
|
|
|
+import com.java110.utils.exception.CmdException;
|
|
|
+import com.java110.utils.util.Assert;
|
|
|
+import com.java110.utils.util.BeanConvertUtil;
|
|
|
+import com.java110.vo.ResultVo;
|
|
|
+import org.springframework.beans.factory.annotation.Autowired;
|
|
|
+import com.java110.dto.user.UserQuestionAnswerDto;
|
|
|
+
|
|
|
+import java.util.List;
|
|
|
+import java.util.ArrayList;
|
|
|
+
|
|
|
+import org.springframework.http.ResponseEntity;
|
|
|
+import org.springframework.http.HttpStatus;
|
|
|
+import org.slf4j.Logger;
|
|
|
+import org.slf4j.LoggerFactory;
|
|
|
+
|
|
|
+
|
|
|
+/**
|
|
|
+ * 类表述:查询
|
|
|
+ * 服务编码:userQuestionAnswer.listUserQuestionAnswer
|
|
|
+ * 请求路劲:/app/userQuestionAnswer.ListUserQuestionAnswer
|
|
|
+ * add by 吴学文 at 2023-07-13 00:38:00 mail: 928255095@qq.com
|
|
|
+ * open source address: https://gitee.com/wuxw7/MicroCommunity
|
|
|
+ * 官网:http://www.homecommunity.cn
|
|
|
+ * 温馨提示:如果您对此文件进行修改 请不要删除原有作者及注释信息,请补充您的 修改的原因以及联系邮箱如下
|
|
|
+ * // modify by 张三 at 2021-09-12 第10行在某种场景下存在某种bug 需要修复,注释10至20行 加入 20行至30行
|
|
|
+ */
|
|
|
+@Java110Cmd(serviceCode = "question.listUserQuestionAnswer")
|
|
|
+public class ListUserQuestionAnswerCmd extends Cmd {
|
|
|
+
|
|
|
+ private static Logger logger = LoggerFactory.getLogger(ListUserQuestionAnswerCmd.class);
|
|
|
+ @Autowired
|
|
|
+ private IUserQuestionAnswerV1InnerServiceSMO userQuestionAnswerV1InnerServiceSMOImpl;
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private IUserQuestionAnswerValueV1InnerServiceSMO userQuestionAnswerValueV1InnerServiceSMOImpl;
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public void validate(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) {
|
|
|
+ super.validatePageInfo(reqJson);
|
|
|
+ Assert.hasKeyAndValue(reqJson, "communityId", "未包含小区信息");
|
|
|
+ Assert.hasKeyAndValue(reqJson, "qaId", "未包含小区信息");
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public void doCmd(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) throws CmdException {
|
|
|
+
|
|
|
+ UserQuestionAnswerDto userQuestionAnswerDto = BeanConvertUtil.covertBean(reqJson, UserQuestionAnswerDto.class);
|
|
|
+
|
|
|
+ int count = userQuestionAnswerV1InnerServiceSMOImpl.queryUserQuestionAnswersCount(userQuestionAnswerDto);
|
|
|
+
|
|
|
+ List<UserQuestionAnswerDto> userQuestionAnswerDtos = null;
|
|
|
+
|
|
|
+ if (count > 0) {
|
|
|
+ userQuestionAnswerDtos = userQuestionAnswerV1InnerServiceSMOImpl.queryUserQuestionAnswers(userQuestionAnswerDto);
|
|
|
+ } else {
|
|
|
+ userQuestionAnswerDtos = new ArrayList<>();
|
|
|
+ }
|
|
|
+
|
|
|
+ //todo 刷入答案
|
|
|
+ freshUserQuestionAnswerValues(userQuestionAnswerDtos);
|
|
|
+
|
|
|
+ ResultVo resultVo = new ResultVo((int) Math.ceil((double) count / (double) reqJson.getInteger("row")), count, userQuestionAnswerDtos);
|
|
|
+
|
|
|
+ ResponseEntity<String> responseEntity = new ResponseEntity<String>(resultVo.toString(), HttpStatus.OK);
|
|
|
+
|
|
|
+ cmdDataFlowContext.setResponseEntity(responseEntity);
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 刷入 投票内容
|
|
|
+ *
|
|
|
+ * @param userQuestionAnswerDtos
|
|
|
+ */
|
|
|
+ private void freshUserQuestionAnswerValues(List<UserQuestionAnswerDto> userQuestionAnswerDtos) {
|
|
|
+
|
|
|
+ if (userQuestionAnswerDtos == null || userQuestionAnswerDtos.size() < 1) {
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ UserQuestionAnswerValueDto userQuestionAnswerValueDto = new UserQuestionAnswerValueDto();
|
|
|
+ userQuestionAnswerValueDto.setQaId(userQuestionAnswerDtos.get(0).getQaId());
|
|
|
+ userQuestionAnswerValueDto.setCommunityId(userQuestionAnswerDtos.get(0).getCommunityId());
|
|
|
+ List<UserQuestionAnswerValueDto> values
|
|
|
+ = userQuestionAnswerValueV1InnerServiceSMOImpl.queryUserQuestionAnswerValues(userQuestionAnswerValueDto);
|
|
|
+
|
|
|
+ if (values == null || values.size() < 1) {
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ //todo 比较
|
|
|
+ List<UserQuestionAnswerValueDto> tValues = null;
|
|
|
+ for (UserQuestionAnswerDto userQuestionAnswerDto : userQuestionAnswerDtos) {
|
|
|
+ tValues = new ArrayList<>();
|
|
|
+ for (UserQuestionAnswerValueDto tmpUserQuestionAnswerValue : values) {
|
|
|
+ if (userQuestionAnswerDto.getUserQaId().equals(tmpUserQuestionAnswerValue.getUserQaId())) {
|
|
|
+ tValues.add(tmpUserQuestionAnswerValue);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ userQuestionAnswerDto.setValues(tValues);
|
|
|
+ }
|
|
|
+
|
|
|
+ }
|
|
|
+}
|