|  | @ -2,19 +2,27 @@ package com.yihu.jw.service;/**
 | 
	
		
			
				|  |  |  * Created by nature of king on 2018/4/27.
 | 
	
		
			
				|  |  |  */
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  | import com.alibaba.fastjson.JSONArray;
 | 
	
		
			
				|  |  | import com.alibaba.fastjson.JSONObject;
 | 
	
		
			
				|  |  | import com.yihu.base.mysql.query.BaseJpaService;
 | 
	
		
			
				|  |  | import com.yihu.jw.dao.*;
 | 
	
		
			
				|  |  | import com.yihu.jw.entity.health.bank.*;
 | 
	
		
			
				|  |  | import com.yihu.jw.restmodel.common.Envelop;
 | 
	
		
			
				|  |  | import com.yihu.jw.rm.health.bank.HealthBankMapping;
 | 
	
		
			
				|  |  | import com.yihu.jw.util.DateUtils;
 | 
	
		
			
				|  |  | import com.yihu.jw.util.ISqlUtils;
 | 
	
		
			
				|  |  | import org.apache.commons.lang3.StringUtils;
 | 
	
		
			
				|  |  | import org.slf4j.Logger;
 | 
	
		
			
				|  |  | import org.slf4j.LoggerFactory;
 | 
	
		
			
				|  |  | import org.springframework.beans.factory.annotation.Autowired;
 | 
	
		
			
				|  |  | import org.springframework.data.redis.core.StringRedisTemplate;
 | 
	
		
			
				|  |  | import org.springframework.jdbc.core.BeanPropertyRowMapper;
 | 
	
		
			
				|  |  | import org.springframework.jdbc.core.JdbcTemplate;
 | 
	
		
			
				|  |  | import org.springframework.stereotype.Service;
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  | import javax.transaction.Transactional;
 | 
	
		
			
				|  |  | import java.text.ParseException;
 | 
	
		
			
				|  |  | import java.text.SimpleDateFormat;
 | 
	
		
			
				|  |  | import java.util.ArrayList;
 | 
	
		
			
				|  |  | import java.util.Date;
 | 
	
		
			
				|  |  | import java.util.List;
 | 
	
	
		
			
				|  | @ -29,7 +37,9 @@ import java.util.Map;
 | 
	
		
			
				|  |  | @Transactional
 | 
	
		
			
				|  |  | public class CreditsDetailService extends BaseJpaService<CreditsDetailDO,CredittsLogDetailDao> {
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |     private Logger logger = LoggerFactory.getLogger(CreditsDetailService.class);
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |     private static String STEP = "health:blank:step";
 | 
	
		
			
				|  |  |     @Autowired
 | 
	
		
			
				|  |  |     private CredittsLogDetailDao credittsLogDetailDao;
 | 
	
		
			
				|  |  |     @Autowired
 | 
	
	
		
			
				|  | @ -41,23 +51,27 @@ public class CreditsDetailService extends BaseJpaService<CreditsDetailDO,Creditt
 | 
	
		
			
				|  |  |     @Autowired
 | 
	
		
			
				|  |  |     private AccountDao accountDao;
 | 
	
		
			
				|  |  |     @Autowired
 | 
	
		
			
				|  |  |     private TaskDetailDao taskDetailDao;
 | 
	
		
			
				|  |  |     private TaskPatientDetailDao taskPatientDetailDao;
 | 
	
		
			
				|  |  |     @Autowired
 | 
	
		
			
				|  |  |     private TaskRuleDao taskRuleDao;
 | 
	
		
			
				|  |  |     @Autowired
 | 
	
		
			
				|  |  |     private StringRedisTemplate redisTemplate;
 | 
	
		
			
				|  |  |     @Autowired
 | 
	
		
			
				|  |  |     private ActiveRecordService activeRecordService;
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |    /**
 | 
	
		
			
				|  |  |      *  find creditsLogInfo
 | 
	
		
			
				|  |  |      *
 | 
	
		
			
				|  |  |      * @return
 | 
	
		
			
				|  |  |      * @throws ParseException
 | 
	
		
			
				|  |  |      */
 | 
	
		
			
				|  |  |     public Envelop<CreditsDetailDO> findByCondition(CreditsDetailDO creditsDetailDO, Integer page, Integer size) throws ParseException {
 | 
	
		
			
				|  |  |    public Envelop<CreditsDetailDO> findByCondition(CreditsDetailDO creditsDetailDO, Integer page, Integer size) throws ParseException {
 | 
	
		
			
				|  |  |         String sql = new ISqlUtils().getSql(creditsDetailDO,page,size,"*");
 | 
	
		
			
				|  |  |         List<CreditsDetailDO> creditsDetailDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper(CreditsDetailDO.class));
 | 
	
		
			
				|  |  |         for (CreditsDetailDO creditsDetailDO1 : creditsDetailDOS){
 | 
	
		
			
				|  |  |             if (creditsDetailDO1.getTradeType().equalsIgnoreCase("HEALTH_TASK")){
 | 
	
		
			
				|  |  |             if (creditsDetailDO1.getTradeType() != null && creditsDetailDO1.getTradeType().equalsIgnoreCase("ACTIVITY_TASK")){
 | 
	
		
			
				|  |  |                 TaskDO taskDO = taskDao.findOne(creditsDetailDO1.getTransactionId());
 | 
	
		
			
				|  |  |                 creditsDetailDO1.setTaskDO(taskDO);
 | 
	
		
			
				|  |  |             }else if(creditsDetailDO1.getTradeType().equalsIgnoreCase("HEALTH_ACTIVITY")){
 | 
	
		
			
				|  |  |                 ActivityDO activityDO = activityDao.findOne(creditsDetailDO1.getTransactionId());
 | 
	
		
			
				|  |  |                 creditsDetailDO1.setActivityDO(activityDO);
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  |         }
 | 
	
		
			
				|  |  |         String sqlcount = new ISqlUtils().getSql(creditsDetailDO,0,0,"count");
 | 
	
	
		
			
				|  | @ -84,10 +98,16 @@ public class CreditsDetailService extends BaseJpaService<CreditsDetailDO,Creditt
 | 
	
		
			
				|  |  |         if (accountDOS == null || accountDOS.size() == 0){
 | 
	
		
			
				|  |  |             accountDO1.setTotal(0);
 | 
	
		
			
				|  |  |             accountDO1.setAccountName(creditsDetailDO.getName());
 | 
	
		
			
				|  |  |             accountDO1.setCardNumber("jw");
 | 
	
		
			
				|  |  |             accountDO1.setHospital("海沧区");
 | 
	
		
			
				|  |  |             accountDO1.setPassword("321321312321");
 | 
	
		
			
				|  |  |             accountDO1.setHospitalName("haichan");
 | 
	
		
			
				|  |  |             if(creditsDetailDO.getIdCard().length()>=4){// 判断是否长度大于等于4
 | 
	
		
			
				|  |  |                 String cardNumber=creditsDetailDO.getIdCard().substring(creditsDetailDO.getIdCard().length()- 4,creditsDetailDO.getIdCard().length());//截取两个数字之间的部分
 | 
	
		
			
				|  |  |                 int random = (int)((Math.random()*9+1)*100000);
 | 
	
		
			
				|  |  |                 accountDO1.setCardNumber(cardNumber+Integer.toString(random));
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  |             accountDO1.setHospital(creditsDetailDO.getHospital());
 | 
	
		
			
				|  |  |             accountDO1.setPassword("123456");
 | 
	
		
			
				|  |  |             accountDO1.setHospitalName(creditsDetailDO.getHospitalName());
 | 
	
		
			
				|  |  |             accountDO1.setStatus(1);
 | 
	
		
			
				|  |  |             accountDO1.setSaasId("dev");
 | 
	
		
			
				|  |  |             accountDO1.setCreateTime(new Date());
 | 
	
		
			
				|  |  |             accountDO1.setUpdateTime(new Date());
 | 
	
		
			
				|  |  |             accountDao.save(accountDO1);
 | 
	
	
		
			
				|  | @ -109,7 +129,6 @@ public class CreditsDetailService extends BaseJpaService<CreditsDetailDO,Creditt
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |     /*
 | 
	
		
			
				|  |  |     public Envelop<Boolean> exchangeGoods(GoodsDO goodsDO){
 | 
	
		
			
				|  |  |         CreditsDetailDO creditsLogDetailDO = new CreditsDetailDO();
 | 
	
	
		
			
				|  | @ -147,7 +166,7 @@ public class CreditsDetailService extends BaseJpaService<CreditsDetailDO,Creditt
 | 
	
		
			
				|  |  |                         "ba.hospital AS hospital," +
 | 
	
		
			
				|  |  |                         "ba.total AS total," +
 | 
	
		
			
				|  |  |                         "ba.create_time AS create_time," +
 | 
	
		
			
				|  |  |                         "(ba.total +(cd1.total)) AS sum" +
 | 
	
		
			
				|  |  |                         " if(ba.total=0,ba.total,(ba.total +COALESCE((cd1.total),0))) AS sum" +
 | 
	
		
			
				|  |  |                         " FROM" +
 | 
	
		
			
				|  |  |                         " wlyy_health_bank_account ba" +
 | 
	
		
			
				|  |  |                         " LEFT JOIN ( " +
 | 
	
	
		
			
				|  | @ -159,13 +178,13 @@ public class CreditsDetailService extends BaseJpaService<CreditsDetailDO,Creditt
 | 
	
		
			
				|  |  |                         " WHERE " +
 | 
	
		
			
				|  |  |                         "cd.trade_direction = - 1" +
 | 
	
		
			
				|  |  |                         " GROUP BY " +
 | 
	
		
			
				|  |  |                         " cd.patient_id ) cd1 ON cd1.patient_id = ba.patient_id\n" +
 | 
	
		
			
				|  |  |                         " cd.patient_id ) cd1 ON cd1.patient_id = ba.patient_id " +
 | 
	
		
			
				|  |  |                         " WHERE " + buffer +
 | 
	
		
			
				|  |  |                         " ORDER BY" +
 | 
	
		
			
				|  |  |                         " ba.create_time DESC " +
 | 
	
		
			
				|  |  |                         "LIMIT "+(page-1)*size+","+size +")ba1" +
 | 
	
		
			
				|  |  |                         " ORDER BY " +
 | 
	
		
			
				|  |  |                         " ba1.sum DESC";
 | 
	
		
			
				|  |  |                         " ba1.total DESC";
 | 
	
		
			
				|  |  |         List<AccountDO> accountDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper(AccountDO.class));
 | 
	
		
			
				|  |  |         String sqlCount = "SELECT count(1) AS total"+
 | 
	
		
			
				|  |  |                 " FROM " +
 | 
	
	
		
			
				|  | @ -184,7 +203,7 @@ public class CreditsDetailService extends BaseJpaService<CreditsDetailDO,Creditt
 | 
	
		
			
				|  |  |                 "WHERE " + buffer +
 | 
	
		
			
				|  |  |                 " ORDER BY " +
 | 
	
		
			
				|  |  |                 " ba.create_time, " +
 | 
	
		
			
				|  |  |                 " (ba.total + cd1.total) DESC ";
 | 
	
		
			
				|  |  |                 " (ba.total + COALESCE(cd1.total,0)) DESC ";
 | 
	
		
			
				|  |  |         List<Map<String,Object>> rstotal = jdbcTemplate.queryForList(sqlCount);
 | 
	
		
			
				|  |  |         Long count = 0L;
 | 
	
		
			
				|  |  |         if(rstotal!=null&&rstotal.size()>0){
 | 
	
	
		
			
				|  | @ -212,10 +231,15 @@ public class CreditsDetailService extends BaseJpaService<CreditsDetailDO,Creditt
 | 
	
		
			
				|  |  |                     accountDO1.setPatientId(creditsDetailDO.getPatientId());
 | 
	
		
			
				|  |  |                     accountDO1.setTotal(0);
 | 
	
		
			
				|  |  |                     accountDO1.setAccountName(creditsDetailDO.getName());
 | 
	
		
			
				|  |  |                     accountDO1.setCardNumber("jw");
 | 
	
		
			
				|  |  |                     accountDO1.setHospital("海沧区");
 | 
	
		
			
				|  |  |                     accountDO1.setPassword("321321312321");
 | 
	
		
			
				|  |  |                     accountDO1.setHospitalName("haichan");
 | 
	
		
			
				|  |  |                     if(creditsDetailDO.getIdCard().length()>=4){// 判断是否长度大于等于4
 | 
	
		
			
				|  |  |                         String cardNumber=creditsDetailDO.getIdCard().substring(creditsDetailDO.getIdCard().length()- 4,creditsDetailDO.getIdCard().length());//截取两个数字之间的部分
 | 
	
		
			
				|  |  |                         int random = (int)((Math.random()*9+1)*100000);
 | 
	
		
			
				|  |  |                         accountDO1.setCardNumber(cardNumber+Integer.toString(random));
 | 
	
		
			
				|  |  |                     }
 | 
	
		
			
				|  |  |                     accountDO1.setHospital(creditsDetailDO.getHospital());
 | 
	
		
			
				|  |  |                     accountDO1.setPassword("123456");
 | 
	
		
			
				|  |  |                     accountDO1.setHospitalName(creditsDetailDO.getHospitalName());
 | 
	
		
			
				|  |  |                     accountDO1.setStatus(1);
 | 
	
		
			
				|  |  |                     accountDO1.setCreateTime(new Date());
 | 
	
		
			
				|  |  |                     accountDO1.setUpdateTime(new Date());
 | 
	
		
			
				|  |  |                     accountDao.save(accountDO1);
 | 
	
	
		
			
				|  | @ -224,31 +248,49 @@ public class CreditsDetailService extends BaseJpaService<CreditsDetailDO,Creditt
 | 
	
		
			
				|  |  |                 }
 | 
	
		
			
				|  |  |                 TaskDO taskDO = new TaskDO();
 | 
	
		
			
				|  |  |                 taskDO.setTaskCode(creditsDetailDO.getFlag());
 | 
	
		
			
				|  |  |                 taskDO.setPatientId(creditsDetailDO.getPatientId());
 | 
	
		
			
				|  |  |                 taskDO.setId(creditsDetailDO.getTransactionId());
 | 
	
		
			
				|  |  |                 /*taskDO.setPatientId(creditsDetailDO.getPatientId());*/
 | 
	
		
			
				|  |  |                 String sql = ISqlUtils.getSql(taskDO,1,1,"*");
 | 
	
		
			
				|  |  |                 List<TaskDO> taskDOList = jdbcTemplate.query(sql,new BeanPropertyRowMapper(TaskDO.class));
 | 
	
		
			
				|  |  |                 if (taskDOList != null && taskDOList.size() != 0){
 | 
	
		
			
				|  |  |                     creditsDetailDO.setTransactionId(taskDOList.get(0).getId());
 | 
	
		
			
				|  |  |                 }else {
 | 
	
		
			
				|  |  |                     List<TaskDO> taskDOS = getTasks(taskDO.getPatientId());
 | 
	
		
			
				|  |  |                     for (TaskDO taskDO1:taskDOS){
 | 
	
		
			
				|  |  |                         taskDao.save(taskDO1);
 | 
	
		
			
				|  |  |                     }
 | 
	
		
			
				|  |  |                     List<TaskDO> taskDOList1 = jdbcTemplate.query(sql,new BeanPropertyRowMapper(TaskDO.class));
 | 
	
		
			
				|  |  |                     creditsDetailDO.setTransactionId(taskDOList1.get(0).getId());
 | 
	
		
			
				|  |  |                 }
 | 
	
		
			
				|  |  |                 if (creditsDetailDO.getTradeDirection() == 1){
 | 
	
		
			
				|  |  |                     if (creditsDetailDO.getTradeType().equals("HEALTH_TASK")){
 | 
	
		
			
				|  |  |                         TaskDetailDO taskDetailDO = new TaskDetailDO();
 | 
	
		
			
				|  |  |                         taskDetailDO.setIntegrate(creditsDetailDO.getIntegrate());
 | 
	
		
			
				|  |  |                         taskDetailDO.setTaskId(creditsDetailDO.getTransactionId());
 | 
	
		
			
				|  |  |                         taskDetailDO.setSaasId(creditsDetailDO.getSaasId());
 | 
	
		
			
				|  |  |                         taskDetailDO.setPatientId(creditsDetailDO.getPatientId());
 | 
	
		
			
				|  |  |                         taskDetailDO.setTradeDirection(creditsDetailDO.getTradeDirection());
 | 
	
		
			
				|  |  |                         taskDetailDO.setStatus("1");
 | 
	
		
			
				|  |  |                         taskDetailDO.setCreateTime(new Date());
 | 
	
		
			
				|  |  |                         taskDetailDO.setUpdateTime(new Date());
 | 
	
		
			
				|  |  |                         taskDetailDao.save(taskDetailDO);
 | 
	
		
			
				|  |  |                 creditsDetailDO.setTransactionId(taskDOList.get(0).getId());
 | 
	
		
			
				|  |  |                 String ruleSql = "SELECT * FROM wlyy_health_bank_task_rule WHERE id= '"+taskDOList.get(0).getRuleCode()+"'";
 | 
	
		
			
				|  |  |                 List<TaskRuleDO> taskRuleDOS = jdbcTemplate.query(ruleSql,new BeanPropertyRowMapper(TaskRuleDO.class));
 | 
	
		
			
				|  |  |                 TaskRuleDO taskRuleDO = taskRuleDOS.get(0);
 | 
	
		
			
				|  |  |                 creditsDetailDO.setIntegrate(taskRuleDO.getIntegrate());
 | 
	
		
			
				|  |  |                 creditsDetailDO.setTradeDirection(taskRuleDO.getTradeDirection());
 | 
	
		
			
				|  |  |                 String taskSql = "select * from wlyy_health_bank_task_patient_detail where task_id = '"+taskDOList.get(0).getId()+"' and patient_id = '" + creditsDetailDO.getPatientId() +"'";
 | 
	
		
			
				|  |  |                 List<TaskPatientDetailDO> taskPatientDetailDOS = jdbcTemplate.query(taskSql,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
 | 
	
		
			
				|  |  |                 if (taskPatientDetailDOS == null || taskPatientDetailDOS.size() ==0){
 | 
	
		
			
				|  |  |                     TaskPatientDetailDO taskPatientDetailDO = new TaskPatientDetailDO();
 | 
	
		
			
				|  |  |                     taskPatientDetailDO.setTaskId(creditsDetailDO.getTransactionId());
 | 
	
		
			
				|  |  |                     taskPatientDetailDO.setSaasId(creditsDetailDO.getSaasId());
 | 
	
		
			
				|  |  |                     taskPatientDetailDO.setPatientId(creditsDetailDO.getPatientId());
 | 
	
		
			
				|  |  |                     taskPatientDetailDO.setPatientIdcard(creditsDetailDO.getIdCard());
 | 
	
		
			
				|  |  |                     taskPatientDetailDO.setPatientOpenid(creditsDetailDO.getOpenId());
 | 
	
		
			
				|  |  |                     taskPatientDetailDO.setUnionId(creditsDetailDO.getUnionId());
 | 
	
		
			
				|  |  |                     taskPatientDetailDO.setStatus(Integer.parseInt("0"));
 | 
	
		
			
				|  |  |                     taskPatientDetailDO.setCreateTime(new Date());
 | 
	
		
			
				|  |  |                     taskPatientDetailDO.setUpdateTime(new Date());
 | 
	
		
			
				|  |  |                     taskPatientDetailDO.setActivityId(taskDOList.get(0).getTransactionId());
 | 
	
		
			
				|  |  |                     taskPatientDetailDO.setTotal(Long.parseLong("0"));
 | 
	
		
			
				|  |  |                     taskPatientDetailDao.save(taskPatientDetailDO);
 | 
	
		
			
				|  |  |                 }else if (taskPatientDetailDOS != null && taskDOList.get(0).getPeriod() == 0){
 | 
	
		
			
				|  |  |                     String taskSql1 = "select * from wlyy_health_bank_task_patient_detail where task_id = '"+taskDOList.get(0).getId()+
 | 
	
		
			
				|  |  |                             "' and patient_id = '"+creditsDetailDO.getPatientId()+"' and create_time > '" + DateUtils.getDayBegin() +"' and create_time < '"+ DateUtils.getDayEnd() +"'";
 | 
	
		
			
				|  |  |                     List<TaskPatientDetailDO> taskPatientDetailDOS1 = jdbcTemplate.query(taskSql1,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
 | 
	
		
			
				|  |  |                     if (taskPatientDetailDOS1 == null || taskPatientDetailDOS1.size() == 0){
 | 
	
		
			
				|  |  |                         TaskPatientDetailDO taskPatientDetailDO = new TaskPatientDetailDO();
 | 
	
		
			
				|  |  |                         taskPatientDetailDO.setTaskId(creditsDetailDO.getTransactionId());
 | 
	
		
			
				|  |  |                         taskPatientDetailDO.setSaasId(creditsDetailDO.getSaasId());
 | 
	
		
			
				|  |  |                         taskPatientDetailDO.setPatientId(creditsDetailDO.getPatientId());
 | 
	
		
			
				|  |  |                         taskPatientDetailDO.setPatientIdcard(creditsDetailDO.getIdCard());
 | 
	
		
			
				|  |  |                         taskPatientDetailDO.setPatientOpenid(creditsDetailDO.getOpenId());
 | 
	
		
			
				|  |  |                         taskPatientDetailDO.setActivityId(taskDOList.get(0).getTransactionId());
 | 
	
		
			
				|  |  |                         taskPatientDetailDO.setStatus(Integer.parseInt("0"));
 | 
	
		
			
				|  |  |                         taskPatientDetailDO.setCreateTime(new Date());
 | 
	
		
			
				|  |  |                         taskPatientDetailDO.setUpdateTime(new Date());
 | 
	
		
			
				|  |  |                         taskPatientDetailDO.setTotal(Long.parseLong("0"));
 | 
	
		
			
				|  |  |                         taskPatientDetailDao.save(taskPatientDetailDO);
 | 
	
		
			
				|  |  |                     }
 | 
	
		
			
				|  |  |                 }
 | 
	
		
			
				|  |  |                 creditsDetailDO.setCreateTime(new Date());
 | 
	
	
		
			
				|  | @ -257,6 +299,18 @@ public class CreditsDetailService extends BaseJpaService<CreditsDetailDO,Creditt
 | 
	
		
			
				|  |  |                 creditsDetailDO1.setFlag(creditsDetailDO.getFlag());
 | 
	
		
			
				|  |  |                 List<CreditsDetailDO> creditsDetailDOList = new ArrayList<>();
 | 
	
		
			
				|  |  |                 creditsDetailDOList.add(creditsDetailDO1);
 | 
	
		
			
				|  |  |                 TaskPatientDetailDO taskPatientDetailDO = new TaskPatientDetailDO();
 | 
	
		
			
				|  |  |                 taskPatientDetailDO.setPatientId(creditsDetailDO1.getPatientId());
 | 
	
		
			
				|  |  |                 taskPatientDetailDO.setTaskId(creditsDetailDO1.getTransactionId());
 | 
	
		
			
				|  |  |                 String taskSql1 = ISqlUtils.getAllSql(taskPatientDetailDO);
 | 
	
		
			
				|  |  |                 List<TaskPatientDetailDO> taskPatientDetailDOS1 = jdbcTemplate.query(taskSql1,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
 | 
	
		
			
				|  |  |                 TaskPatientDetailDO taskPatientDetailDO1 = taskPatientDetailDOS1.get(0);
 | 
	
		
			
				|  |  |                 if (creditsDetailDO1.getTradeDirection() == 1){
 | 
	
		
			
				|  |  |                     taskPatientDetailDO1.setTotal(taskPatientDetailDO1.getTotal()+creditsDetailDO1.getIntegrate());
 | 
	
		
			
				|  |  |                 }else if (creditsDetailDO.getTradeDirection() == -1){
 | 
	
		
			
				|  |  |                     taskPatientDetailDO1.setTotal(taskPatientDetailDO1.getTotal()-creditsDetailDO1.getIntegrate());
 | 
	
		
			
				|  |  |                 }
 | 
	
		
			
				|  |  |                 taskPatientDetailDao.save(taskPatientDetailDO1);
 | 
	
		
			
				|  |  |                 AccountDO accountDO = accountDao.findOne(creditsDetailDO1.getAccountId());
 | 
	
		
			
				|  |  |                 if (creditsDetailDO1.getTradeDirection() == 1){
 | 
	
		
			
				|  |  |                     accountDO.setTotal(accountDO.getTotal()+creditsDetailDO1.getIntegrate());
 | 
	
	
		
			
				|  | @ -280,17 +334,394 @@ public class CreditsDetailService extends BaseJpaService<CreditsDetailDO,Creditt
 | 
	
		
			
				|  |  |         }
 | 
	
		
			
				|  |  |     }
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |     /**
 | 
	
		
			
				|  |  |      * 活动排名
 | 
	
		
			
				|  |  |      *
 | 
	
		
			
				|  |  |      * @param activityId 活动id
 | 
	
		
			
				|  |  |      * @param ids 微信编码
 | 
	
		
			
				|  |  |      *
 | 
	
		
			
				|  |  |      * @param page 页码
 | 
	
		
			
				|  |  |      *
 | 
	
		
			
				|  |  |      * @param size 分页大小
 | 
	
		
			
				|  |  |      * @return
 | 
	
		
			
				|  |  |      */
 | 
	
		
			
				|  |  |     public Envelop<TaskPatientDetailDO> selectByActivityRanking(String activityId,List<String> ids,Integer page,Integer size){
 | 
	
		
			
				|  |  |         StringBuffer buffer = new StringBuffer();
 | 
	
		
			
				|  |  |         buffer.append("(");
 | 
	
		
			
				|  |  |         if (ids == null || ids.size() == 0){
 | 
	
		
			
				|  |  |             buffer.append("''");
 | 
	
		
			
				|  |  |         }else {
 | 
	
		
			
				|  |  |             for (int i=0;i<ids.size();i++){
 | 
	
		
			
				|  |  |                 buffer.append("'"+ids.get(i)+"'").append(",");
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  |             buffer.deleteCharAt(buffer.length()-1);
 | 
	
		
			
				|  |  |         }
 | 
	
		
			
				|  |  |         buffer.append(") ");
 | 
	
		
			
				|  |  |         String sql = "SELECT " +
 | 
	
		
			
				|  |  |                 " * " +
 | 
	
		
			
				|  |  |                 "FROM " +
 | 
	
		
			
				|  |  |                 " ( " +
 | 
	
		
			
				|  |  |                 " SELECT " +
 | 
	
		
			
				|  |  |                 " SUM(ptpd.total) AS total, " +
 | 
	
		
			
				|  |  |                 " ptpd.patient_openid AS patient_openid, " +
 | 
	
		
			
				|  |  |                 " ptpd.task_id AS task_id, " +
 | 
	
		
			
				|  |  |                 " ptpd.activity_id AS activity_id, " +
 | 
	
		
			
				|  |  |                 " ptpd.create_time as create_time, " +
 | 
	
		
			
				|  |  |                 " ptpd.patient_id AS patient_id " +
 | 
	
		
			
				|  |  |                 " FROM " +
 | 
	
		
			
				|  |  |                 " wlyy_health_bank_task_patient_detail ptpd " +
 | 
	
		
			
				|  |  |                 " WHERE " +
 | 
	
		
			
				|  |  |                 " activity_id = '" + activityId +
 | 
	
		
			
				|  |  |                 "' GROUP BY " +
 | 
	
		
			
				|  |  |                 " patient_id " +
 | 
	
		
			
				|  |  |                 " ORDER BY ptpd.create_time DESC " +
 | 
	
		
			
				|  |  |                 " )btpd1 " +
 | 
	
		
			
				|  |  |                 " WHERE  patient_id IN "+buffer+
 | 
	
		
			
				|  |  |                 " ORDER BY btpd1.total DESC "+" LIMIT " + (page-1)*size+","+size;
 | 
	
		
			
				|  |  |         List<TaskPatientDetailDO> taskPatientDetailDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
 | 
	
		
			
				|  |  |         for (TaskPatientDetailDO taskPatientDetailDO : taskPatientDetailDOS){
 | 
	
		
			
				|  |  |             String accountSql = "select * from wlyy_health_bank_account where patient_id = '"+taskPatientDetailDO.getPatientId()+"'";
 | 
	
		
			
				|  |  |             List<AccountDO> accountDOS = jdbcTemplate.query(accountSql,new BeanPropertyRowMapper(AccountDO.class));
 | 
	
		
			
				|  |  |             taskPatientDetailDO.setAccountDO(accountDOS.get(0));
 | 
	
		
			
				|  |  |         }
 | 
	
		
			
				|  |  |         String sqlCount =  "SELECT " +
 | 
	
		
			
				|  |  |                 " count(1) AS total " +
 | 
	
		
			
				|  |  |                 "FROM " +
 | 
	
		
			
				|  |  |                 " ( " +
 | 
	
		
			
				|  |  |                 " SELECT " +
 | 
	
		
			
				|  |  |                 " SUM(ptpd.total) AS total, " +
 | 
	
		
			
				|  |  |                 " ptpd.patient_openid AS patient_openid, " +
 | 
	
		
			
				|  |  |                 " ptpd.task_id AS task_id, " +
 | 
	
		
			
				|  |  |                 " ptpd.activity_id AS activity_id, " +
 | 
	
		
			
				|  |  |                 " ptpd.create_time as create_time, " +
 | 
	
		
			
				|  |  |                 " ptpd.patient_id AS patient_id " +
 | 
	
		
			
				|  |  |                 " FROM " +
 | 
	
		
			
				|  |  |                 " wlyy_health_bank_task_patient_detail ptpd " +
 | 
	
		
			
				|  |  |                 " WHERE " +
 | 
	
		
			
				|  |  |                 " activity_id = '" + activityId+
 | 
	
		
			
				|  |  |                 "' GROUP BY " +
 | 
	
		
			
				|  |  |                 " patient_openid " +
 | 
	
		
			
				|  |  |                 " ORDER BY ptpd.create_time DESC " +
 | 
	
		
			
				|  |  |                 " )btpd1 " +
 | 
	
		
			
				|  |  |                 "WHERE  patient_openid IN "+buffer+
 | 
	
		
			
				|  |  |                 " ORDER BY btpd1.total DESC ";
 | 
	
		
			
				|  |  |         List<Map<String,Object>> rstotal = jdbcTemplate.queryForList(sqlCount);
 | 
	
		
			
				|  |  |         Long count = 0L;
 | 
	
		
			
				|  |  |         if(rstotal!=null&&rstotal.size()>0){
 | 
	
		
			
				|  |  |             count = (Long) rstotal.get(0).get("total");
 | 
	
		
			
				|  |  |         }
 | 
	
		
			
				|  |  |         return Envelop.getSuccessListWithPage(HealthBankMapping.api_success, taskPatientDetailDOS,page,size,count);
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |     }
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |     /**
 | 
	
		
			
				|  |  |      * 固定数据
 | 
	
		
			
				|  |  |      * 根据活动查询积分
 | 
	
		
			
				|  |  |      *
 | 
	
		
			
				|  |  |      * @param activityId 活动id
 | 
	
		
			
				|  |  |      *
 | 
	
		
			
				|  |  |      * @param patientId 居民id
 | 
	
		
			
				|  |  |      *
 | 
	
		
			
				|  |  |      * @param page 页码
 | 
	
		
			
				|  |  |      *
 | 
	
		
			
				|  |  |      * @param size 分页大小
 | 
	
		
			
				|  |  |      * @return
 | 
	
		
			
				|  |  |      */
 | 
	
		
			
				|  |  |     public Envelop<CreditsDetailDO> selectByActivity(String activityId,String patientId,Integer page,Integer size){
 | 
	
		
			
				|  |  |         String sql="SELECT * " +
 | 
	
		
			
				|  |  |                 "FROM " +
 | 
	
		
			
				|  |  |                 " wlyy_health_bank_credits_detail " +
 | 
	
		
			
				|  |  |                 "WHERE" +
 | 
	
		
			
				|  |  |                 " transaction_id IN ( " +
 | 
	
		
			
				|  |  |                 " SELECT " +
 | 
	
		
			
				|  |  |                 " bt.id " +
 | 
	
		
			
				|  |  |                 " FROM " +
 | 
	
		
			
				|  |  |                 " wlyy_health_bank_task bt " +
 | 
	
		
			
				|  |  |                 " WHERE " +
 | 
	
		
			
				|  |  |                 " transaction_id = '"+activityId +"' " +
 | 
	
		
			
				|  |  |                 " ) " +
 | 
	
		
			
				|  |  |                 " and patient_id = '" +patientId+
 | 
	
		
			
				|  |  |                 "' LIMIT "+(page-1)*size +","+size;
 | 
	
		
			
				|  |  |         List<CreditsDetailDO> creditsDetailDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper(CreditsDetailDO.class));
 | 
	
		
			
				|  |  |         for (CreditsDetailDO creditsDetailDO : creditsDetailDOS){
 | 
	
		
			
				|  |  |             TaskDO taskDO = taskDao.findOne(creditsDetailDO.getTransactionId());
 | 
	
		
			
				|  |  |             creditsDetailDO.setTaskDO(taskDO);
 | 
	
		
			
				|  |  |         }
 | 
	
		
			
				|  |  |         String sqlcount = "SELECT count(1) AS" +
 | 
	
		
			
				|  |  |                 " total FROM " +
 | 
	
		
			
				|  |  |                 " wlyy_health_bank_credits_detail " +
 | 
	
		
			
				|  |  |                 "WHERE" +
 | 
	
		
			
				|  |  |                 " transaction_id IN ( " +
 | 
	
		
			
				|  |  |                 " SELECT " +
 | 
	
		
			
				|  |  |                 " bt.id " +
 | 
	
		
			
				|  |  |                 " FROM " +
 | 
	
		
			
				|  |  |                 " wlyy_health_bank_task bt " +
 | 
	
		
			
				|  |  |                 " WHERE " +
 | 
	
		
			
				|  |  |                 " transaction_id = '"+activityId +"' " +
 | 
	
		
			
				|  |  |                 " ) " +
 | 
	
		
			
				|  |  |                 " and patient_id = '" +patientId+
 | 
	
		
			
				|  |  |                 "'";
 | 
	
		
			
				|  |  |         List<Map<String,Object>> rstotal = jdbcTemplate.queryForList(sqlcount);
 | 
	
		
			
				|  |  |         Long count = 0L;
 | 
	
		
			
				|  |  |         if(rstotal!=null&&rstotal.size()>0){
 | 
	
		
			
				|  |  |             count = (Long) rstotal.get(0).get("total");
 | 
	
		
			
				|  |  |         }
 | 
	
		
			
				|  |  |         return Envelop.getSuccessListWithPage(HealthBankMapping.api_success,creditsDetailDOS,page,size,count);
 | 
	
		
			
				|  |  |     }
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |     /**
 | 
	
		
			
				|  |  |      * 根据活动查找全部排行
 | 
	
		
			
				|  |  |      *
 | 
	
		
			
				|  |  |      * @param patientId
 | 
	
		
			
				|  |  |      * @param activityId 活动id
 | 
	
		
			
				|  |  |      * @param page 页码
 | 
	
		
			
				|  |  |      * @param size 分页大小
 | 
	
		
			
				|  |  |      * @return
 | 
	
		
			
				|  |  |      */
 | 
	
		
			
				|  |  |     public Envelop<TaskPatientDetailDO> selectByActivityRanking1(String activityId,String patientId,Integer page,Integer size){
 | 
	
		
			
				|  |  |         String sql = "SELECT " +
 | 
	
		
			
				|  |  |                 " * " +
 | 
	
		
			
				|  |  |                 "FROM " +
 | 
	
		
			
				|  |  |                 " ( " +
 | 
	
		
			
				|  |  |                 " SELECT " +
 | 
	
		
			
				|  |  |                 " SUM(ptpd.total) AS total, " +
 | 
	
		
			
				|  |  |                 " ptpd.patient_openid AS patient_openid, " +
 | 
	
		
			
				|  |  |                 " ptpd.task_id AS task_id, " +
 | 
	
		
			
				|  |  |                 " ptpd.activity_id AS activity_id, " +
 | 
	
		
			
				|  |  |                 " ptpd.create_time as create_time, " +
 | 
	
		
			
				|  |  |                 " ptpd.patient_id AS patient_id " +
 | 
	
		
			
				|  |  |                 " FROM " +
 | 
	
		
			
				|  |  |                 " wlyy_health_bank_task_patient_detail ptpd " +
 | 
	
		
			
				|  |  |                 " WHERE " +
 | 
	
		
			
				|  |  |                 " activity_id = '" + activityId +
 | 
	
		
			
				|  |  |                 "' GROUP BY " +
 | 
	
		
			
				|  |  |                 " patient_openid " +
 | 
	
		
			
				|  |  |                 " ORDER BY ptpd.create_time DESC " +
 | 
	
		
			
				|  |  |                 " )btpd1 " +
 | 
	
		
			
				|  |  |                 " ORDER BY btpd1.total DESC "+" LIMIT " + (page-1)*size+","+size;
 | 
	
		
			
				|  |  |         List<TaskPatientDetailDO> taskPatientDetailDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
 | 
	
		
			
				|  |  |         logger.info(taskPatientDetailDOS.toString()+""+taskPatientDetailDOS.size());
 | 
	
		
			
				|  |  |         for (int i = 0;taskPatientDetailDOS != null&&taskPatientDetailDOS.size()!=0 && i<taskPatientDetailDOS.size();i++){
 | 
	
		
			
				|  |  |             TaskPatientDetailDO taskPatientDetailDO = taskPatientDetailDOS.get(i);
 | 
	
		
			
				|  |  |             String accountSql = "select * from wlyy_health_bank_account where patient_id = '"+taskPatientDetailDO.getPatientId()+"'";
 | 
	
		
			
				|  |  |             List<AccountDO> accountDOS = jdbcTemplate.query(accountSql,new BeanPropertyRowMapper(AccountDO.class));
 | 
	
		
			
				|  |  |             if (taskPatientDetailDOS.get(i).getPatientId().equalsIgnoreCase(patientId)){
 | 
	
		
			
				|  |  |                 /*String taskSql = "select count(1)+1 as total from (" +
 | 
	
		
			
				|  |  |                         "select *  from (SELECT " +
 | 
	
		
			
				|  |  |                         " SUM(ptpd.total) AS total, " +
 | 
	
		
			
				|  |  |                         " ptpd.patient_openid AS patient_openid, " +
 | 
	
		
			
				|  |  |                         " ptpd.task_id AS task_id, " +
 | 
	
		
			
				|  |  |                         " ptpd.activity_id AS activity_id, " +
 | 
	
		
			
				|  |  |                         " ptpd.create_time as create_time, " +
 | 
	
		
			
				|  |  |                         " ptpd.patient_id AS patient_id " +
 | 
	
		
			
				|  |  |                         " FROM " +
 | 
	
		
			
				|  |  |                         " wlyy_health_bank_task_patient_detail ptpd " +
 | 
	
		
			
				|  |  |                         " WHERE " +
 | 
	
		
			
				|  |  |                         " activity_id = '" + activityId + "')ptpd1 where" +
 | 
	
		
			
				|  |  |                         " ptpd1.patient_id = '"+patientId+"' AND ptpd1.total > "+taskPatientDetailDOS.get(i).getTotal()+") ptpd2";
 | 
	
		
			
				|  |  |                 List<Map<String,Object>> rstotal1 = jdbcTemplate.queryForList(taskSql);
 | 
	
		
			
				|  |  |                 Long count = 0L;
 | 
	
		
			
				|  |  |                 if(rstotal1!=null&&rstotal1.size()>0){
 | 
	
		
			
				|  |  |                     count = (Long) rstotal1.get(0).get("total");
 | 
	
		
			
				|  |  |                 }
 | 
	
		
			
				|  |  |                 accountDOS.get(0).setActivityRanking(count);*/
 | 
	
		
			
				|  |  |                 taskPatientDetailDO.setIsFlag(1);
 | 
	
		
			
				|  |  |             }else {
 | 
	
		
			
				|  |  |                 taskPatientDetailDO.setIsFlag(0);
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  |             taskPatientDetailDO.setAccountDO(accountDOS.get(0));
 | 
	
		
			
				|  |  |         }
 | 
	
		
			
				|  |  |         String sqlCount =  "SELECT " +
 | 
	
		
			
				|  |  |                 " count(1) AS total " +
 | 
	
		
			
				|  |  |                 "FROM " +
 | 
	
		
			
				|  |  |                 " ( " +
 | 
	
		
			
				|  |  |                 " SELECT " +
 | 
	
		
			
				|  |  |                 " SUM(ptpd.total) AS total, " +
 | 
	
		
			
				|  |  |                 " ptpd.patient_openid AS patient_openid, " +
 | 
	
		
			
				|  |  |                 " ptpd.task_id AS task_id, " +
 | 
	
		
			
				|  |  |                 " ptpd.activity_id AS activity_id, " +
 | 
	
		
			
				|  |  |                 " ptpd.create_time as create_time, " +
 | 
	
		
			
				|  |  |                 " ptpd.patient_id AS patient_id " +
 | 
	
		
			
				|  |  |                 " FROM " +
 | 
	
		
			
				|  |  |                 " wlyy_health_bank_task_patient_detail ptpd " +
 | 
	
		
			
				|  |  |                 " WHERE " +
 | 
	
		
			
				|  |  |                 " activity_id = '" + activityId+
 | 
	
		
			
				|  |  |                 "' GROUP BY " +
 | 
	
		
			
				|  |  |                 " patient_openid " +
 | 
	
		
			
				|  |  |                 " ORDER BY ptpd.create_time DESC " +
 | 
	
		
			
				|  |  |                 " )btpd1 " +
 | 
	
		
			
				|  |  |                 " ORDER BY btpd1.total DESC ";
 | 
	
		
			
				|  |  |         List<Map<String,Object>> rstotal = jdbcTemplate.queryForList(sqlCount);
 | 
	
		
			
				|  |  |         Long count = 0L;
 | 
	
		
			
				|  |  |         if(rstotal!=null&&rstotal.size()>0){
 | 
	
		
			
				|  |  |             count = (Long) rstotal.get(0).get("total");
 | 
	
		
			
				|  |  |         }
 | 
	
		
			
				|  |  |         return Envelop.getSuccessListWithPage(HealthBankMapping.api_success, taskPatientDetailDOS,page,size,count);
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |     }
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |     /**
 | 
	
		
			
				|  |  |      * 医生主动加分
 | 
	
		
			
				|  |  |      *
 | 
	
		
			
				|  |  |      * @param array 居民信息集合
 | 
	
		
			
				|  |  |      *
 | 
	
		
			
				|  |  |      * @param ruleId 规则id
 | 
	
		
			
				|  |  |      * @return
 | 
	
		
			
				|  |  |      */
 | 
	
		
			
				|  |  |     public Envelop<Boolean> doctorAddIntegrate(JSONArray array, String ruleId, String description) throws Exception {
 | 
	
		
			
				|  |  |         Envelop<Boolean> envelop = new Envelop<>();
 | 
	
		
			
				|  |  |         for (int i=0;i<array.size();i++){
 | 
	
		
			
				|  |  |             TaskRuleDO taskRuleDO = taskRuleDao.findOne(ruleId);
 | 
	
		
			
				|  |  |             JSONObject object = array.getJSONObject(i);
 | 
	
		
			
				|  |  |             String patientId = object.getString("code");
 | 
	
		
			
				|  |  |             String idCard = object.getString("idcard");
 | 
	
		
			
				|  |  |             String unionId = object.getString("unionid");
 | 
	
		
			
				|  |  |             String openId = object.getString("openid");
 | 
	
		
			
				|  |  |             String hospital = object.getString("hospital");
 | 
	
		
			
				|  |  |             String hospitalName = object.getString("hospitalName");
 | 
	
		
			
				|  |  |             String taskSql = "select * from wlyy_health_bank_task bt where type = 'RULE_TASK' AND transaction_id = '"+ruleId +"'";
 | 
	
		
			
				|  |  |             List<TaskDO> taskDOList = jdbcTemplate.query(taskSql,new BeanPropertyRowMapper(TaskDO.class));
 | 
	
		
			
				|  |  |             TaskDO taskDO1 = new TaskDO();
 | 
	
		
			
				|  |  |             if (taskDOList.isEmpty() && taskDOList.size() == 0){
 | 
	
		
			
				|  |  |                 TaskDO taskDO = new TaskDO();
 | 
	
		
			
				|  |  |                 taskDO.setTransactionId(taskRuleDO.getId());
 | 
	
		
			
				|  |  |                 taskDO.setTaskCode("RULE");
 | 
	
		
			
				|  |  |                 taskDO.setStatus(1);
 | 
	
		
			
				|  |  |                 taskDO.setRuleCode(taskRuleDO.getId());
 | 
	
		
			
				|  |  |                 taskDO.setType("RULE_TASK");
 | 
	
		
			
				|  |  |                 taskDO.setCreateTime(new Date());
 | 
	
		
			
				|  |  |                 taskDO.setUpdateTime(new Date());
 | 
	
		
			
				|  |  |                 taskDO.setPeriod(taskRuleDO.getPeriod());
 | 
	
		
			
				|  |  |                 taskDO.setSaasId("dev");
 | 
	
		
			
				|  |  |                 taskDO.setTitle(taskRuleDO.getDescription());
 | 
	
		
			
				|  |  |                 taskDO.setContent(taskRuleDO.getDescription());
 | 
	
		
			
				|  |  |                 taskDO1 = taskDao.save(taskDO);
 | 
	
		
			
				|  |  |             }else {
 | 
	
		
			
				|  |  |                 taskDO1 = taskDOList.get(0);
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  |             if (taskRuleDO.getPeriod() == 1){
 | 
	
		
			
				|  |  |                     String sql = "select * from wlyy_health_bank_task_patient_detail where patient_id = '"+patientId+"'AND task_id ='"+taskDO1.getId()+"'";
 | 
	
		
			
				|  |  |                     List<TaskPatientDetailDO> taskPatientDetailDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
 | 
	
		
			
				|  |  |                     if (taskPatientDetailDOS != null && taskPatientDetailDOS.size() != 0){
 | 
	
		
			
				|  |  |                         throw new Exception("已奖励过");
 | 
	
		
			
				|  |  |                     }
 | 
	
		
			
				|  |  |             }else if (taskRuleDO.getPeriod() == 0){
 | 
	
		
			
				|  |  |                     SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
 | 
	
		
			
				|  |  |                     Date date = new Date();
 | 
	
		
			
				|  |  |                     String date1 = dateFormat.format(date);
 | 
	
		
			
				|  |  |                     String begin = DateUtils.getMinMonthDate(date1);
 | 
	
		
			
				|  |  |                     String end = DateUtils.getMaxMonthDate(date1);
 | 
	
		
			
				|  |  |                     String sql = "select * from wlyy_health_bank_task_patient_detail where patient_id = '"+patientId+"'AND task_id ='"+taskDO1.getId()+"' AND create_time > '"+begin+"' AND create_time < '"+end+"'";
 | 
	
		
			
				|  |  |                     List<TaskPatientDetailDO> taskPatientDetailDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
 | 
	
		
			
				|  |  |                     if (taskPatientDetailDOS != null && taskPatientDetailDOS.size() != 0){
 | 
	
		
			
				|  |  |                         throw new Exception("已奖励过");
 | 
	
		
			
				|  |  |                     }
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  |             String sql1 = "select * from wlyy_health_bank_task_patient_detail where task_id = '"+taskDO1.getId()+"' " +
 | 
	
		
			
				|  |  |                     "AND patient_idcard = '"+idCard+"' AND patient_openid = '"+openId+"' AND union_id = '"+unionId+"'";
 | 
	
		
			
				|  |  |             List<TaskPatientDetailDO> taskPatientDetailDOS = jdbcTemplate.query(sql1,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
 | 
	
		
			
				|  |  |             TaskPatientDetailDO taskPatientDetailDO1 = new TaskPatientDetailDO();
 | 
	
		
			
				|  |  |             if (taskPatientDetailDOS.isEmpty() && taskPatientDetailDOS.size() == 0){
 | 
	
		
			
				|  |  |                 TaskPatientDetailDO taskPatientDetailDO = new TaskPatientDetailDO();
 | 
	
		
			
				|  |  |                 taskPatientDetailDO.setStatus(1);
 | 
	
		
			
				|  |  |                 taskPatientDetailDO.setTotal(Long.parseLong("0"));
 | 
	
		
			
				|  |  |                 taskPatientDetailDO.setPatientId(patientId);
 | 
	
		
			
				|  |  |                 taskPatientDetailDO.setPatientOpenid(openId);
 | 
	
		
			
				|  |  |                 taskPatientDetailDO.setPatientIdcard(idCard);
 | 
	
		
			
				|  |  |                 taskPatientDetailDO.setUnionId(unionId);
 | 
	
		
			
				|  |  |                 taskPatientDetailDO.setSaasId("dev");
 | 
	
		
			
				|  |  |                 taskPatientDetailDO.setCreateTime(new Date());
 | 
	
		
			
				|  |  |                 taskPatientDetailDO.setUpdateTime(new Date());
 | 
	
		
			
				|  |  |                 taskPatientDetailDO.setTaskId(taskDO1.getId());
 | 
	
		
			
				|  |  |                 taskPatientDetailDO1 = taskPatientDetailDao.save(taskPatientDetailDO);
 | 
	
		
			
				|  |  |             }else {
 | 
	
		
			
				|  |  |                 taskPatientDetailDO1 = taskPatientDetailDOS.get(0);
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  |             String sql = "select * from wlyy_health_bank_account where patient_id = '"+patientId+"'";
 | 
	
		
			
				|  |  |             List<AccountDO> accountDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper(AccountDO.class));
 | 
	
		
			
				|  |  |             if (taskRuleDO.getTradeDirection() == -1 && taskRuleDO.getIntegrate() == 0){
 | 
	
		
			
				|  |  |                 String integrateSql = "select * from wlyy_health_bank_credits_detail where patient_id = '"+patientId+"' " +
 | 
	
		
			
				|  |  |                         "AND transaction_id IN (SELECT id FROM wlyy_health_bank_task WHERE task_code IN ('BP_BIND','GLU_BIND','BP_MEASURE','GLU_MEASURE','RULE'))";
 | 
	
		
			
				|  |  |                 List<CreditsDetailDO> creditsDetailDOS = jdbcTemplate.query(integrateSql,new BeanPropertyRowMapper(CreditsDetailDO.class));
 | 
	
		
			
				|  |  |                 for (CreditsDetailDO creditsDetailDO:creditsDetailDOS){
 | 
	
		
			
				|  |  |                     if (creditsDetailDO.getTradeDirection()==1&&creditsDetailDO.getStatus()!=0){
 | 
	
		
			
				|  |  |                         AccountDO accountDO = accountDOS.get(0);
 | 
	
		
			
				|  |  |                         int total = accountDO.getTotal() - creditsDetailDO.getIntegrate();
 | 
	
		
			
				|  |  |                         creditsDetailDO.setStatus(0);
 | 
	
		
			
				|  |  |                         creditsDetailDO.setDescription(description);
 | 
	
		
			
				|  |  |                         credittsLogDetailDao.save(creditsDetailDO);
 | 
	
		
			
				|  |  |                         accountDO.setTotal(total);
 | 
	
		
			
				|  |  |                         accountDao.save(accountDO);
 | 
	
		
			
				|  |  |                     }
 | 
	
		
			
				|  |  |                 }
 | 
	
		
			
				|  |  |                 CreditsDetailDO creditsDetailDO1 = new CreditsDetailDO();
 | 
	
		
			
				|  |  |                 creditsDetailDO1.setStatus(1);
 | 
	
		
			
				|  |  |                 creditsDetailDO1.setSaasId("dev");
 | 
	
		
			
				|  |  |                 creditsDetailDO1.setAccountId(accountDOS.get(0).getId());
 | 
	
		
			
				|  |  |                 creditsDetailDO1.setHospital(hospital);
 | 
	
		
			
				|  |  |                 creditsDetailDO1.setHospitalName(hospitalName);
 | 
	
		
			
				|  |  |                 creditsDetailDO1.setPatientId(patientId);
 | 
	
		
			
				|  |  |                 creditsDetailDO1.setIntegrate(taskRuleDO.getIntegrate());
 | 
	
		
			
				|  |  |                 creditsDetailDO1.setTradeDirection(taskRuleDO.getTradeDirection());
 | 
	
		
			
				|  |  |                 creditsDetailDO1.setDescription(description);
 | 
	
		
			
				|  |  |                 creditsDetailDO1.setCreateTime(new Date());
 | 
	
		
			
				|  |  |                 creditsDetailDO1.setUpdateTime(new Date());
 | 
	
		
			
				|  |  |                 creditsDetailDO1.setTransactionId(taskDO1.getId());
 | 
	
		
			
				|  |  |                 creditsDetailDO1.setTradeType("ACTIVITY_TASK");
 | 
	
		
			
				|  |  |                 credittsLogDetailDao.save(creditsDetailDO1);
 | 
	
		
			
				|  |  |             }else{
 | 
	
		
			
				|  |  |                 CreditsDetailDO creditsDetailDO = new CreditsDetailDO();
 | 
	
		
			
				|  |  |                 creditsDetailDO.setStatus(1);
 | 
	
		
			
				|  |  |                 creditsDetailDO.setSaasId("dev");
 | 
	
		
			
				|  |  |                 creditsDetailDO.setAccountId(accountDOS.get(0).getId());
 | 
	
		
			
				|  |  |                 creditsDetailDO.setHospital(hospital);
 | 
	
		
			
				|  |  |                 creditsDetailDO.setHospitalName(hospitalName);
 | 
	
		
			
				|  |  |                 creditsDetailDO.setPatientId(patientId);
 | 
	
		
			
				|  |  |                 creditsDetailDO.setIntegrate(taskRuleDO.getIntegrate());
 | 
	
		
			
				|  |  |                 creditsDetailDO.setTradeDirection(taskRuleDO.getTradeDirection());
 | 
	
		
			
				|  |  |                 creditsDetailDO.setDescription(description);
 | 
	
		
			
				|  |  |                 creditsDetailDO.setCreateTime(new Date());
 | 
	
		
			
				|  |  |                 creditsDetailDO.setUpdateTime(new Date());
 | 
	
		
			
				|  |  |                 creditsDetailDO.setTransactionId(taskDO1.getId());
 | 
	
		
			
				|  |  |                 creditsDetailDO.setTradeType("ACTIVITY_TASK");
 | 
	
		
			
				|  |  |                 credittsLogDetailDao.save(creditsDetailDO);
 | 
	
		
			
				|  |  |                 if (taskRuleDO.getTradeDirection() == -1){
 | 
	
		
			
				|  |  |                     String integrateSql = "select * from wlyy_health_bank_credits_detail where patient_id = '"+patientId+"' " +
 | 
	
		
			
				|  |  |                             "AND transaction_id IN (SELECT id FROM wlyy_health_bank_task WHERE task_code IN ('BP_BIND','GLU_BIND','BP_MEASURE','GLU_MEASURE','RULE'))";
 | 
	
		
			
				|  |  |                     List<CreditsDetailDO> creditsDetailDOS = jdbcTemplate.query(integrateSql,new BeanPropertyRowMapper(CreditsDetailDO.class));
 | 
	
		
			
				|  |  |                     for (CreditsDetailDO creditsDetailDO1:creditsDetailDOS){
 | 
	
		
			
				|  |  |                         if (creditsDetailDO1.getTradeDirection()==1&&creditsDetailDO1.getStatus()!=0){
 | 
	
		
			
				|  |  |                             AccountDO accountDO = accountDOS.get(0);
 | 
	
		
			
				|  |  |                             int total = accountDO.getTotal() - creditsDetailDO1.getIntegrate();
 | 
	
		
			
				|  |  |                             creditsDetailDO1.setStatus(0);
 | 
	
		
			
				|  |  |                             creditsDetailDO1.setDescription(description);
 | 
	
		
			
				|  |  |                             credittsLogDetailDao.save(creditsDetailDO1);
 | 
	
		
			
				|  |  |                             accountDO.setTotal(total);
 | 
	
		
			
				|  |  |                             accountDao.save(accountDO);
 | 
	
		
			
				|  |  |                         }
 | 
	
		
			
				|  |  |                     }
 | 
	
		
			
				|  |  |                 }else if (taskRuleDO.getTradeDirection() == 1){
 | 
	
		
			
				|  |  |                     AccountDO accountDO = accountDOS.get(0);
 | 
	
		
			
				|  |  |                     accountDO.setTotal(accountDO.getTotal() + taskRuleDO.getIntegrate());
 | 
	
		
			
				|  |  |                     accountDao.save(accountDO);
 | 
	
		
			
				|  |  |                 }
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  |         }
 | 
	
		
			
				|  |  |         envelop.setObj(true);
 | 
	
		
			
				|  |  |         return envelop;
 | 
	
		
			
				|  |  |     }
 | 
	
		
			
				|  |  |     /**
 | 
	
		
			
				|  |  |      * 固定数据
 | 
	
		
			
				|  |  |      *
 | 
	
		
			
				|  |  |      * @param
 | 
	
		
			
				|  |  |      * @return
 | 
	
		
			
				|  |  |      *//*
 | 
	
		
			
				|  |  |     public List<TaskDO> getTasks(String patientId){
 | 
	
		
			
				|  |  |         List<TaskDO> taskDOList = new ArrayList<>();
 | 
	
		
			
				|  |  |         TaskDO taskDO = new TaskDO();
 | 
	
		
			
				|  |  |         taskDO.setPatientId(patientId);
 | 
	
		
			
				|  |  |         *//*taskDO.setPatientId(patientId);*//*
 | 
	
		
			
				|  |  |         taskDO.setTaskCode("BIND");
 | 
	
		
			
				|  |  |         taskDO.setPeriod(1);
 | 
	
		
			
				|  |  |         taskDO.setTaskTitle("首次绑定");
 | 
	
	
		
			
				|  | @ -301,7 +732,7 @@ public class CreditsDetailService extends BaseJpaService<CreditsDetailDO,Creditt
 | 
	
		
			
				|  |  |         taskDO.setUpdateTime(new Date());
 | 
	
		
			
				|  |  |         taskDOList.add(taskDO);
 | 
	
		
			
				|  |  |         TaskDO taskDO1 = new TaskDO();
 | 
	
		
			
				|  |  |         taskDO1.setPatientId(patientId);
 | 
	
		
			
				|  |  |         *//*taskDO1.setPatientId(patientId);*//*
 | 
	
		
			
				|  |  |         taskDO1.setTaskCode("MEASURE");
 | 
	
		
			
				|  |  |         taskDO1.setPeriod(0);
 | 
	
		
			
				|  |  |         taskDO1.setTaskTitle("每日测量");
 | 
	
	
		
			
				|  | @ -313,5 +744,170 @@ public class CreditsDetailService extends BaseJpaService<CreditsDetailDO,Creditt
 | 
	
		
			
				|  |  |         taskDOList.add(taskDO1);
 | 
	
		
			
				|  |  |         return taskDOList;
 | 
	
		
			
				|  |  |     }
 | 
	
		
			
				|  |  | */
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |     public Envelop<CreditsDetailDO> stepAddIntegrate(CreditsDetailDO creditsDetailDO){
 | 
	
		
			
				|  |  |         try {
 | 
	
		
			
				|  |  |             synchronized (creditsDetailDO.getPatientId()){
 | 
	
		
			
				|  |  |                 String sqlAccount = "select * from wlyy_health_bank_account ba where ba.patient_id = '"+creditsDetailDO.getPatientId() +"'";
 | 
	
		
			
				|  |  |                 List<AccountDO> accountDOList = jdbcTemplate.query(sqlAccount,new BeanPropertyRowMapper(AccountDO.class));
 | 
	
		
			
				|  |  |                 if (accountDOList != null && accountDOList.size() != 0){
 | 
	
		
			
				|  |  |                     creditsDetailDO.setAccountId(accountDOList.get(0).getId());
 | 
	
		
			
				|  |  |                 }else {
 | 
	
		
			
				|  |  |                     AccountDO accountDO1 = new AccountDO();
 | 
	
		
			
				|  |  |                     accountDO1.setPatientId(creditsDetailDO.getPatientId());
 | 
	
		
			
				|  |  |                     accountDO1.setSaasId("dev");
 | 
	
		
			
				|  |  |                     accountDO1.setTotal(0);
 | 
	
		
			
				|  |  |                     accountDO1.setAccountName(creditsDetailDO.getName());
 | 
	
		
			
				|  |  |                     if(creditsDetailDO.getIdCard().length()>=4){// 判断是否长度大于等于4
 | 
	
		
			
				|  |  |                         String cardNumber=creditsDetailDO.getIdCard().substring(creditsDetailDO.getIdCard().length()- 4,creditsDetailDO.getIdCard().length());//截取两个数字之间的部分
 | 
	
		
			
				|  |  |                         int random = (int)((Math.random()*9+1)*100000);
 | 
	
		
			
				|  |  |                         accountDO1.setCardNumber(cardNumber+Integer.toString(random));
 | 
	
		
			
				|  |  |                     }
 | 
	
		
			
				|  |  |                     accountDO1.setHospital(creditsDetailDO.getHospital());
 | 
	
		
			
				|  |  |                     accountDO1.setPassword("123456");
 | 
	
		
			
				|  |  |                     accountDO1.setHospitalName(creditsDetailDO.getHospitalName());
 | 
	
		
			
				|  |  |                     accountDO1.setStatus(1);
 | 
	
		
			
				|  |  |                     accountDO1.setCreateTime(new Date());
 | 
	
		
			
				|  |  |                     accountDO1.setUpdateTime(new Date());
 | 
	
		
			
				|  |  |                     accountDao.save(accountDO1);
 | 
	
		
			
				|  |  |                     List<AccountDO> accountDOS = jdbcTemplate.query(sqlAccount,new BeanPropertyRowMapper(AccountDO.class));
 | 
	
		
			
				|  |  |                     creditsDetailDO.setAccountId(accountDOS.get(0).getId());
 | 
	
		
			
				|  |  |                 }
 | 
	
		
			
				|  |  |                 TaskDO taskDO = taskDao.findOne(creditsDetailDO.getTransactionId());
 | 
	
		
			
				|  |  |                 String sql1 = "select *  from wlyy_health_bank_task_patient_detail where patient_openid = '"+creditsDetailDO.getOpenId()+"' " +
 | 
	
		
			
				|  |  |                         "AND patient_idcard = '"+creditsDetailDO.getIdCard()+"' AND union_id = '"+creditsDetailDO.getUnionId()+"' AND task_id = '"+creditsDetailDO.getTransactionId()+"'";
 | 
	
		
			
				|  |  |                 List<TaskPatientDetailDO> taskPatientDetailDOList = jdbcTemplate.query(sql1,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
 | 
	
		
			
				|  |  |                 TaskPatientDetailDO taskPatientDetailDO = taskPatientDetailDOList.get(0);
 | 
	
		
			
				|  |  |                 String sql = "select * from wlyy_health_bank_credits_detail where patient_id = '"+creditsDetailDO.getPatientId()+"' AND " +
 | 
	
		
			
				|  |  |                         "transaction_id = '"+creditsDetailDO.getTransactionId()+"' AND create_time > '"+DateUtils.getDayBegin() +"' AND" +
 | 
	
		
			
				|  |  |                         " create_time < '"+DateUtils.getDayEnd()+"'";
 | 
	
		
			
				|  |  |                 List<CreditsDetailDO> creditsDetailDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper<>(CreditsDetailDO.class));
 | 
	
		
			
				|  |  |                 String step = redisTemplate.opsForValue().get(STEP);
 | 
	
		
			
				|  |  |                 if (StringUtils.isEmpty(step)){
 | 
	
		
			
				|  |  |                     throw new Exception("获取步数失败!");
 | 
	
		
			
				|  |  |                 }
 | 
	
		
			
				|  |  |                 JSONObject object = JSONObject.parseObject(step);
 | 
	
		
			
				|  |  |                 int step1 = object.getInteger("step1");
 | 
	
		
			
				|  |  |                 int step2 = object.getInteger("step2");
 | 
	
		
			
				|  |  |                 int step3 = object.getInteger("step3");
 | 
	
		
			
				|  |  |                 if (creditsDetailDOS != null && creditsDetailDOS.size() != 0){
 | 
	
		
			
				|  |  |                     CreditsDetailDO creditsDetailDO1 = creditsDetailDOS.get(0);
 | 
	
		
			
				|  |  |                     TaskRuleDO taskRuleDO = taskRuleDao.findOne(taskDO.getRuleCode());
 | 
	
		
			
				|  |  |                     if (creditsDetailDO.getStepNumber() == step1){
 | 
	
		
			
				|  |  |                         creditsDetailDO1.setIntegrate(1);
 | 
	
		
			
				|  |  |                         creditsDetailDO1.setTradeDirection(1);
 | 
	
		
			
				|  |  |                         CreditsDetailDO creditsDetailDO2 = credittsLogDetailDao.save(creditsDetailDO1);
 | 
	
		
			
				|  |  |                         AccountDO accountDO = accountDao.findOne(creditsDetailDO2.getAccountId());
 | 
	
		
			
				|  |  |                         accountDO.setTotal(accountDO.getTotal()+creditsDetailDO2.getIntegrate());
 | 
	
		
			
				|  |  |                         AccountDO accountDO1 = accountDao.save(accountDO);
 | 
	
		
			
				|  |  |                         creditsDetailDO2.setTotal(accountDO1.getTotal());
 | 
	
		
			
				|  |  |                         taskPatientDetailDO.setTotal(taskPatientDetailDO.getTotal()+creditsDetailDO2.getIntegrate());
 | 
	
		
			
				|  |  |                         taskPatientDetailDao.save(taskPatientDetailDO);
 | 
	
		
			
				|  |  |                         creditsDetailDOS.clear();
 | 
	
		
			
				|  |  |                         creditsDetailDOS.add(creditsDetailDO2);
 | 
	
		
			
				|  |  |                     }else if (creditsDetailDO.getStepNumber() == step2){
 | 
	
		
			
				|  |  |                         creditsDetailDO1.setIntegrate(creditsDetailDO1.getIntegrate()+2);
 | 
	
		
			
				|  |  |                         creditsDetailDO1.setTradeDirection(1);
 | 
	
		
			
				|  |  |                         CreditsDetailDO creditsDetailDO2 = credittsLogDetailDao.save(creditsDetailDO1);
 | 
	
		
			
				|  |  |                         AccountDO accountDO = accountDao.findOne(creditsDetailDO2.getAccountId());
 | 
	
		
			
				|  |  |                         accountDO.setTotal(accountDO.getTotal()+(creditsDetailDO2.getIntegrate()-1));
 | 
	
		
			
				|  |  |                         AccountDO accountDO1 = accountDao.save(accountDO);
 | 
	
		
			
				|  |  |                         creditsDetailDO2.setTotal(accountDO1.getTotal());
 | 
	
		
			
				|  |  |                         taskPatientDetailDO.setTotal(taskPatientDetailDO.getTotal()+(creditsDetailDO2.getIntegrate()-1));
 | 
	
		
			
				|  |  |                         taskPatientDetailDao.save(taskPatientDetailDO);
 | 
	
		
			
				|  |  |                         creditsDetailDOS.clear();
 | 
	
		
			
				|  |  |                         creditsDetailDOS.add(creditsDetailDO2);
 | 
	
		
			
				|  |  |                     }else if (creditsDetailDO.getStepNumber() == step3){
 | 
	
		
			
				|  |  |                         if (creditsDetailDO1.getIntegrate() == 1){
 | 
	
		
			
				|  |  |                             creditsDetailDO1.setIntegrate(creditsDetailDO1.getIntegrate()+7);
 | 
	
		
			
				|  |  |                             creditsDetailDO1.setTradeDirection(1);
 | 
	
		
			
				|  |  |                             CreditsDetailDO creditsDetailDO2 = credittsLogDetailDao.save(creditsDetailDO1);
 | 
	
		
			
				|  |  |                             AccountDO accountDO = accountDao.findOne(creditsDetailDO2.getAccountId());
 | 
	
		
			
				|  |  |                             accountDO.setTotal(accountDO.getTotal()+(creditsDetailDO2.getIntegrate()-1));
 | 
	
		
			
				|  |  |                             AccountDO accountDO1 = accountDao.save(accountDO);
 | 
	
		
			
				|  |  |                             creditsDetailDO2.setTotal(accountDO1.getTotal());
 | 
	
		
			
				|  |  |                             taskPatientDetailDO.setTotal(taskPatientDetailDO.getTotal()+(creditsDetailDO2.getIntegrate()-1));
 | 
	
		
			
				|  |  |                             taskPatientDetailDao.save(taskPatientDetailDO);
 | 
	
		
			
				|  |  |                             creditsDetailDOS.clear();
 | 
	
		
			
				|  |  |                             creditsDetailDOS.add(creditsDetailDO2);
 | 
	
		
			
				|  |  |                         }else if(creditsDetailDO1.getIntegrate() == 3){
 | 
	
		
			
				|  |  |                             creditsDetailDO1.setIntegrate(creditsDetailDO1.getIntegrate()+5);
 | 
	
		
			
				|  |  |                             creditsDetailDO1.setTradeDirection(1);
 | 
	
		
			
				|  |  |                             CreditsDetailDO creditsDetailDO2 = credittsLogDetailDao.save(creditsDetailDO1);
 | 
	
		
			
				|  |  |                             AccountDO accountDO = accountDao.findOne(creditsDetailDO2.getAccountId());
 | 
	
		
			
				|  |  |                             accountDO.setTotal(accountDO.getTotal()+(creditsDetailDO2.getIntegrate()-3));
 | 
	
		
			
				|  |  |                             AccountDO accountDO1 = accountDao.save(accountDO);
 | 
	
		
			
				|  |  |                             creditsDetailDO2.setTotal(accountDO1.getTotal());
 | 
	
		
			
				|  |  |                             taskPatientDetailDO.setTotal(taskPatientDetailDO.getTotal()+(creditsDetailDO2.getIntegrate()-3));
 | 
	
		
			
				|  |  |                             taskPatientDetailDao.save(taskPatientDetailDO);
 | 
	
		
			
				|  |  |                             creditsDetailDOS.clear();
 | 
	
		
			
				|  |  |                             creditsDetailDOS.add(creditsDetailDO2);
 | 
	
		
			
				|  |  |                         }
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |                     }
 | 
	
		
			
				|  |  |                 }else{
 | 
	
		
			
				|  |  |                     CreditsDetailDO creditsDetailDO1 = new CreditsDetailDO();
 | 
	
		
			
				|  |  |                     if (creditsDetailDO.getStepNumber() == step1){
 | 
	
		
			
				|  |  |                         creditsDetailDO1.setIntegrate(1);
 | 
	
		
			
				|  |  |                         creditsDetailDO1.setTradeDirection(1);
 | 
	
		
			
				|  |  |                     }else if (creditsDetailDO.getStepNumber() == step2){
 | 
	
		
			
				|  |  |                         creditsDetailDO1.setIntegrate(3);
 | 
	
		
			
				|  |  |                         creditsDetailDO1.setTradeDirection(1);
 | 
	
		
			
				|  |  |                     }else if (creditsDetailDO.getStepNumber() == step3){
 | 
	
		
			
				|  |  |                         creditsDetailDO1.setIntegrate(8);
 | 
	
		
			
				|  |  |                         creditsDetailDO1.setTradeDirection(1);
 | 
	
		
			
				|  |  |                     }
 | 
	
		
			
				|  |  |                     creditsDetailDO1.setSaasId("dev");
 | 
	
		
			
				|  |  |                     creditsDetailDO1.setTradeType("ACTIVITY_TASK");
 | 
	
		
			
				|  |  |                     creditsDetailDO1.setPatientId(creditsDetailDO.getPatientId());
 | 
	
		
			
				|  |  |                     creditsDetailDO1.setHospital(creditsDetailDO.getHospital());
 | 
	
		
			
				|  |  |                     creditsDetailDO1.setHospitalName(creditsDetailDO.getHospitalName());
 | 
	
		
			
				|  |  |                     creditsDetailDO1.setAccountId(creditsDetailDO.getAccountId());
 | 
	
		
			
				|  |  |                     creditsDetailDO1.setStatus(1);
 | 
	
		
			
				|  |  |                     creditsDetailDO1.setCreateTime(new Date());
 | 
	
		
			
				|  |  |                     creditsDetailDO1.setUpdateTime(new Date());
 | 
	
		
			
				|  |  |                     creditsDetailDO1.setTransactionId(taskPatientDetailDO.getTaskId());
 | 
	
		
			
				|  |  |                     CreditsDetailDO creditsDetailDO2 = credittsLogDetailDao.save(creditsDetailDO1);
 | 
	
		
			
				|  |  |                     AccountDO accountDO = accountDao.findOne(creditsDetailDO2.getAccountId());
 | 
	
		
			
				|  |  |                     accountDO.setTotal(accountDO.getTotal()+creditsDetailDO2.getIntegrate());
 | 
	
		
			
				|  |  |                     taskPatientDetailDO.setTotal(taskPatientDetailDO.getTotal()+creditsDetailDO2.getIntegrate());
 | 
	
		
			
				|  |  |                     taskPatientDetailDao.save(taskPatientDetailDO);
 | 
	
		
			
				|  |  |                     creditsDetailDO2.setTotal(accountDO.getTotal());
 | 
	
		
			
				|  |  |                     creditsDetailDOS.add(creditsDetailDO2);
 | 
	
		
			
				|  |  |                 }
 | 
	
		
			
				|  |  |                 try{
 | 
	
		
			
				|  |  |                     activeRecordService.insert("dev",creditsDetailDOS.get(0).getTransactionId(),null,null,null,creditsDetailDOS.get(0).getPatientId());
 | 
	
		
			
				|  |  |                 }catch (Exception e){
 | 
	
		
			
				|  |  |                     logger.error("插入活跃出错:"+e.getMessage());
 | 
	
		
			
				|  |  |                 }
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |                 Envelop<CreditsDetailDO> envelop = new Envelop<>();
 | 
	
		
			
				|  |  |                 envelop.setDetailModelList(creditsDetailDOS);
 | 
	
		
			
				|  |  |                 return envelop;
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  |         }catch (Exception e){
 | 
	
		
			
				|  |  |             e.printStackTrace();
 | 
	
		
			
				|  |  |             Envelop<CreditsDetailDO> envelop = new Envelop<>();
 | 
	
		
			
				|  |  |             return envelop;
 | 
	
		
			
				|  |  |         }
 | 
	
		
			
				|  |  |     }
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |   /*  public JSONObject getStepNumber(){
 | 
	
		
			
				|  |  |         String step = redisTemplate.opsForValue().get(STEP);
 | 
	
		
			
				|  |  |         logger.info("redis数据:"+step);
 | 
	
		
			
				|  |  |         String sql = ""
 | 
	
		
			
				|  |  |         String step1 = systemDictDao.
 | 
	
		
			
				|  |  |         logger.info("数据库的数据:"+step1);
 | 
	
		
			
				|  |  |         if (step != null && step.equalsIgnoreCase(step1)){
 | 
	
		
			
				|  |  |             JSONObject jsonObject = JSONObject.parseObject(step);
 | 
	
		
			
				|  |  |             logger.info("数据不一致:"+jsonObject.toString());
 | 
	
		
			
				|  |  |             return jsonObject;
 | 
	
		
			
				|  |  |         }else {
 | 
	
		
			
				|  |  |             JSONObject jsonObject = JSONObject.parseObject(step);
 | 
	
		
			
				|  |  |             redisTemplate.opsForValue().set(STEP,step1);
 | 
	
		
			
				|  |  |             logger.info("数据一致:"+jsonObject.toString());
 | 
	
		
			
				|  |  |             return jsonObject;
 | 
	
		
			
				|  |  |         }
 | 
	
		
			
				|  |  |     }*/
 | 
	
		
			
				|  |  | }
 |