CreditsDetailService.java 92 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625
  1. package com.yihu.jw.service;/**
  2. * Created by nature of king on 2018/4/27.
  3. */
  4. import com.alibaba.fastjson.JSONArray;
  5. import com.alibaba.fastjson.JSONObject;
  6. import com.yihu.jw.dao.*;
  7. import com.yihu.jw.entity.health.bank.*;
  8. import com.yihu.jw.restmodel.web.MixEnvelop;
  9. import com.yihu.jw.rm.health.bank.HealthBankMapping;
  10. import com.yihu.jw.util.DateUtils;
  11. import com.yihu.jw.util.ISqlUtils;
  12. import com.yihu.jw.util.date.DateUtil;
  13. import com.yihu.mysql.query.BaseJpaService;
  14. import org.slf4j.Logger;
  15. import org.slf4j.LoggerFactory;
  16. import org.springframework.beans.factory.annotation.Autowired;
  17. import org.springframework.data.redis.core.StringRedisTemplate;
  18. import org.springframework.jdbc.core.BeanPropertyRowMapper;
  19. import org.springframework.jdbc.core.JdbcTemplate;
  20. import org.springframework.stereotype.Service;
  21. import org.springframework.util.StringUtils;
  22. import javax.print.DocFlavor;
  23. import javax.transaction.Transactional;
  24. import java.text.ParseException;
  25. import java.text.SimpleDateFormat;
  26. import java.util.*;
  27. /**
  28. * @author wangzhinan
  29. * @create 2018-04-27 16:53
  30. * @desc credits log info Service
  31. **/
  32. @Service
  33. @Transactional
  34. public class CreditsDetailService extends BaseJpaService<CreditsDetailDO,CredittsLogDetailDao> {
  35. private Logger logger = LoggerFactory.getLogger(CreditsDetailService.class);
  36. private static String STEP = "health:blank:step";
  37. @Autowired
  38. private CredittsLogDetailDao credittsLogDetailDao;
  39. @Autowired
  40. private TaskDao taskDao;
  41. @Autowired
  42. private ActivityDao activityDao;
  43. @Autowired
  44. private JdbcTemplate jdbcTemplate;
  45. @Autowired
  46. private AccountDao accountDao;
  47. @Autowired
  48. private TaskPatientDetailDao taskPatientDetailDao;
  49. @Autowired
  50. private TaskRuleDao taskRuleDao;
  51. @Autowired
  52. private StringRedisTemplate redisTemplate;
  53. @Autowired
  54. private ActiveRecordService activeRecordService;
  55. @Autowired
  56. private ActivityRuleDao activityRuleDao;
  57. @Autowired
  58. private ExchangeGoodsDao exchangeGoodsDao;
  59. @Autowired
  60. private TaskGoodsDao taskGoodsDao;
  61. /**
  62. * find creditsLogInfo
  63. *
  64. * @return
  65. * @throws ParseException
  66. */
  67. public MixEnvelop<CreditsDetailDO, CreditsDetailDO> findByCondition(CreditsDetailDO creditsDetailDO, Integer page, Integer size) throws ParseException {
  68. String sql = new ISqlUtils().getSql(creditsDetailDO,page,size,"*");
  69. List<CreditsDetailDO> creditsDetailDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper(CreditsDetailDO.class));
  70. for (CreditsDetailDO creditsDetailDO1 : creditsDetailDOS){
  71. if (creditsDetailDO1.getTradeType() != null && creditsDetailDO1.getTradeType().equalsIgnoreCase("ACTIVITY_TASK")){
  72. TaskDO taskDO = taskDao.findOne(creditsDetailDO1.getTransactionId());
  73. creditsDetailDO1.setTaskDO(taskDO);
  74. }else if (creditsDetailDO1.getTradeType()!=null&&creditsDetailDO1.getTradeType().equals("EXCHANGE_GOODS")){
  75. ExchangeGoodsDO exchangeGoodsDO =exchangeGoodsDao.findOne(creditsDetailDO1.getTransactionId());
  76. TaskGoodsDO taskGoodsDO = taskGoodsDao.selectById(exchangeGoodsDO.getActivityGoodsId());
  77. exchangeGoodsDO.setTaskGoodsDO(taskGoodsDO);
  78. creditsDetailDO1.setExchangeGoodsDO(exchangeGoodsDO);
  79. }
  80. }
  81. String sqlcount = new ISqlUtils().getSql(creditsDetailDO,0,0,"count");
  82. List<Map<String,Object>> rstotal = jdbcTemplate.queryForList(sqlcount);
  83. Long count = 0L;
  84. if(rstotal!=null&&rstotal.size()>0){
  85. count = (Long) rstotal.get(0).get("total");
  86. }
  87. return MixEnvelop.getSuccessListWithPage(HealthBankMapping.api_success, creditsDetailDOS,page,size,count);
  88. }
  89. /**
  90. * 获取账户信息
  91. *
  92. * @param creditsDetailDO
  93. * @return
  94. */
  95. public MixEnvelop<AccountDO, AccountDO> findByTradeDirection(CreditsDetailDO creditsDetailDO){
  96. AccountDO accountDO1 = new AccountDO();
  97. accountDO1.setPatientId(creditsDetailDO.getPatientId());
  98. String sql1 = ISqlUtils.getAllSql(accountDO1);
  99. List<AccountDO> accountDOS = jdbcTemplate.query(sql1,new BeanPropertyRowMapper(AccountDO.class));
  100. if (accountDOS == null || accountDOS.size() == 0){
  101. accountDO1.setTotal(0);
  102. accountDO1.setAccountName(creditsDetailDO.getName());
  103. if(creditsDetailDO.getIdCard().length()>=4){// 判断是否长度大于等于4
  104. String cardNumber=creditsDetailDO.getIdCard().substring(creditsDetailDO.getIdCard().length()- 4,creditsDetailDO.getIdCard().length());//截取两个数字之间的部分
  105. int random = (int)((Math.random()*9+1)*100000);
  106. accountDO1.setCardNumber(cardNumber+Integer.toString(random));
  107. }
  108. accountDO1.setHospital(creditsDetailDO.getHospital());
  109. accountDO1.setPassword("123456");
  110. accountDO1.setHospitalName(creditsDetailDO.getHospitalName());
  111. accountDO1.setStatus(1);
  112. accountDO1.setSaasId("dev");
  113. accountDO1.setCreateTime(new Date());
  114. accountDO1.setUpdateTime(new Date());
  115. accountDao.save(accountDO1);
  116. }
  117. List<AccountDO> accountDOS1 = jdbcTemplate.query(sql1,new BeanPropertyRowMapper(AccountDO.class));
  118. AccountDO accountDO = accountDOS1.get(0);
  119. String sql = "SELECT SUM(cd.integrate) as total FROM wlyy_health_bank_credits_detail cd where cd.trade_direction = "+creditsDetailDO.getTradeDirection() +" AND cd.patient_id = '" +creditsDetailDO.getPatientId()+"'";
  120. List<Map<String,Object>> rstotal = jdbcTemplate.queryForList(sql);
  121. if (rstotal!= null && rstotal.size()>0){
  122. if (rstotal.get(0).get("total") == null){
  123. accountDO.setUsedTotal(0);
  124. }else {
  125. accountDO.setUsedTotal(Integer.parseInt(rstotal.get(0).get("total").toString()));
  126. }
  127. }
  128. return MixEnvelop.getSuccess(HealthBankMapping.api_success,accountDO);
  129. }
  130. /*
  131. public Envelop<Boolean> exchangeGoods(GoodsDO goodsDO){
  132. CreditsDetailDO creditsLogDetailDO = new CreditsDetailDO();
  133. Envelop<Boolean> envelop = new Envelop<>();
  134. envelop.setObj(true);
  135. return envelop;
  136. }
  137. */
  138. public MixEnvelop<AccountDO, AccountDO> selectByRanking(List<String> patientIds, Integer page, Integer size){
  139. StringBuffer buffer = new StringBuffer();
  140. buffer.append(" ba.patient_id in(");
  141. if (patientIds == null || patientIds.size() == 0){
  142. buffer.append("''");
  143. }else {
  144. for (int i=0;i<patientIds.size();i++){
  145. buffer.append("'"+patientIds.get(i)+"'").append(",");
  146. }
  147. buffer.deleteCharAt(buffer.length()-1);
  148. }
  149. buffer.append(") ");
  150. String sql =
  151. "SELECT ba1.patient_id AS patient_id," +
  152. "ba1.account_name AS account_name," +
  153. "ba1.hospital AS hospital," +
  154. "ba1.total AS total," +
  155. "ba1.create_time AS create_time," +
  156. "ba1.sum AS sum" +
  157. " FROM" +
  158. "( SELECT " +
  159. "ba.patient_id AS patient_id," +
  160. "ba.account_name AS account_name," +
  161. "ba.hospital AS hospital," +
  162. "ba.total AS total," +
  163. "ba.create_time AS create_time," +
  164. " if(ba.total=0,ba.total,(ba.total +COALESCE((cd1.total),0))) AS sum" +
  165. " FROM" +
  166. " wlyy_health_bank_account ba" +
  167. " LEFT JOIN ( " +
  168. "SELECT" +
  169. " SUM(cd.integrate) AS total," +
  170. " cd.patient_id AS patient_id" +
  171. " FROM" +
  172. " wlyy_health_bank_credits_detail cd" +
  173. " WHERE " +
  174. "cd.trade_direction = - 1" +
  175. " GROUP BY " +
  176. " cd.patient_id ) cd1 ON cd1.patient_id = ba.patient_id " +
  177. " WHERE " + buffer +
  178. " ORDER BY" +
  179. " ba.create_time DESC )ba1" +
  180. " ORDER BY " +
  181. " ba1.total DESC"+
  182. " LIMIT "+(page-1)*size+","+size ;
  183. List<AccountDO> accountDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper(AccountDO.class));
  184. String sqlCount = "SELECT count(1) AS total"+
  185. " FROM " +
  186. " wlyy_health_bank_account ba LEFT JOIN " +
  187. " ( " +
  188. " SELECT " +
  189. " SUM(cd.integrate) AS total, " +
  190. " cd.patient_id AS patient_id " +
  191. " FROM " +
  192. " wlyy_health_bank_credits_detail cd " +
  193. " WHERE " +
  194. " cd.trade_direction = - 1 " +
  195. " GROUP BY " +
  196. " cd.patient_id " +
  197. " ) cd1 ON cd1.patient_id = ba.patient_id " +
  198. "WHERE " + buffer +
  199. " ORDER BY " +
  200. " ba.create_time, " +
  201. " (ba.total + COALESCE(cd1.total,0)) DESC ";
  202. List<Map<String,Object>> rstotal = jdbcTemplate.queryForList(sqlCount);
  203. Long count = 0L;
  204. if(rstotal!=null&&rstotal.size()>0){
  205. count = (Long) rstotal.get(0).get("total");
  206. }
  207. return MixEnvelop.getSuccessListWithPage(HealthBankMapping.api_success, accountDOS,page,size,count);
  208. }
  209. /**
  210. * 添加积分
  211. *
  212. * @param creditsDetailDO
  213. * @return
  214. */
  215. public MixEnvelop<CreditsDetailDO, CreditsDetailDO> insert(CreditsDetailDO creditsDetailDO){
  216. try {
  217. synchronized (creditsDetailDO.getPatientId()){
  218. String sqlAccount = "select * from wlyy_health_bank_account ba where ba.patient_id = '"+creditsDetailDO.getPatientId() +"'";
  219. List<AccountDO> accountDOList = jdbcTemplate.query(sqlAccount,new BeanPropertyRowMapper(AccountDO.class));
  220. if (accountDOList != null && accountDOList.size() != 0){
  221. creditsDetailDO.setAccountId(accountDOList.get(0).getId());
  222. }else {
  223. AccountDO accountDO1 = new AccountDO();
  224. accountDO1.setPatientId(creditsDetailDO.getPatientId());
  225. accountDO1.setTotal(0);
  226. accountDO1.setCouponTotal(0L);
  227. accountDO1.setAccountName(creditsDetailDO.getName());
  228. if(creditsDetailDO.getIdCard().length()>=4){// 判断是否长度大于等于4
  229. String cardNumber=creditsDetailDO.getIdCard().substring(creditsDetailDO.getIdCard().length()- 4,creditsDetailDO.getIdCard().length());//截取两个数字之间的部分
  230. int random = (int)((Math.random()*9+1)*100000);
  231. accountDO1.setCardNumber(cardNumber+Integer.toString(random));
  232. }
  233. accountDO1.setHospital(creditsDetailDO.getHospital());
  234. accountDO1.setPassword("123456");
  235. accountDO1.setHospitalName(creditsDetailDO.getHospitalName());
  236. accountDO1.setStatus(1);
  237. accountDO1.setCreateTime(new Date());
  238. accountDO1.setUpdateTime(new Date());
  239. accountDao.save(accountDO1);
  240. List<AccountDO> accountDOS = jdbcTemplate.query(sqlAccount,new BeanPropertyRowMapper(AccountDO.class));
  241. creditsDetailDO.setAccountId(accountDOS.get(0).getId());
  242. }
  243. TaskDO taskDO = new TaskDO();
  244. taskDO.setTaskCode(creditsDetailDO.getFlag());
  245. taskDO.setId(creditsDetailDO.getTransactionId());
  246. /*taskDO.setPatientId(creditsDetailDO.getPatientId());*/
  247. String sql = ISqlUtils.getSql(taskDO,1,1,"*");
  248. List<TaskDO> taskDOList = jdbcTemplate.query(sql,new BeanPropertyRowMapper(TaskDO.class));
  249. creditsDetailDO.setTransactionId(taskDOList.get(0).getId());
  250. String ruleSql = "SELECT * FROM wlyy_health_bank_task_rule WHERE id= '"+taskDOList.get(0).getRuleCode()+"'";
  251. List<TaskRuleDO> taskRuleDOS = jdbcTemplate.query(ruleSql,new BeanPropertyRowMapper(TaskRuleDO.class));
  252. TaskRuleDO taskRuleDO = taskRuleDOS.get(0);
  253. creditsDetailDO.setIntegrate(taskRuleDO.getIntegrate());
  254. creditsDetailDO.setTradeDirection(taskRuleDO.getTradeDirection());
  255. String taskSql = "select * from wlyy_health_bank_task_patient_detail where task_id = '"+taskDOList.get(0).getId()+"' and patient_id = '" + creditsDetailDO.getPatientId() +"'";
  256. List<TaskPatientDetailDO> taskPatientDetailDOS = jdbcTemplate.query(taskSql,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  257. if (taskPatientDetailDOS == null || taskPatientDetailDOS.size() ==0){
  258. TaskPatientDetailDO taskPatientDetailDO = new TaskPatientDetailDO();
  259. taskPatientDetailDO.setTaskId(creditsDetailDO.getTransactionId());
  260. taskPatientDetailDO.setSaasId(creditsDetailDO.getSaasId());
  261. taskPatientDetailDO.setPatientId(creditsDetailDO.getPatientId());
  262. taskPatientDetailDO.setPatientIdcard(creditsDetailDO.getIdCard());
  263. taskPatientDetailDO.setPatientOpenid(creditsDetailDO.getOpenId());
  264. taskPatientDetailDO.setUnionId(creditsDetailDO.getUnionId());
  265. taskPatientDetailDO.setStatus(Integer.parseInt("0"));
  266. taskPatientDetailDO.setCreateTime(new Date());
  267. taskPatientDetailDO.setUpdateTime(new Date());
  268. taskPatientDetailDO.setActivityId(taskDOList.get(0).getTransactionId());
  269. taskPatientDetailDO.setTotal(Long.parseLong("0"));
  270. taskPatientDetailDao.save(taskPatientDetailDO);
  271. }else if (taskPatientDetailDOS != null && taskDOList.get(0).getPeriod() == 0){
  272. String taskSql1 = "select * from wlyy_health_bank_task_patient_detail where task_id = '"+taskDOList.get(0).getId()+
  273. "' and patient_id = '"+creditsDetailDO.getPatientId()+"' and create_time > '" + DateUtils.getDayBegin() +"' and create_time < '"+ DateUtils.getDayEnd() +"'";
  274. List<TaskPatientDetailDO> taskPatientDetailDOS1 = jdbcTemplate.query(taskSql1,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  275. if (taskPatientDetailDOS1 == null || taskPatientDetailDOS1.size() == 0){
  276. TaskPatientDetailDO taskPatientDetailDO = new TaskPatientDetailDO();
  277. taskPatientDetailDO.setTaskId(creditsDetailDO.getTransactionId());
  278. taskPatientDetailDO.setSaasId(creditsDetailDO.getSaasId());
  279. taskPatientDetailDO.setPatientId(creditsDetailDO.getPatientId());
  280. taskPatientDetailDO.setPatientIdcard(creditsDetailDO.getIdCard());
  281. taskPatientDetailDO.setPatientOpenid(creditsDetailDO.getOpenId());
  282. taskPatientDetailDO.setActivityId(taskDOList.get(0).getTransactionId());
  283. taskPatientDetailDO.setStatus(Integer.parseInt("0"));
  284. taskPatientDetailDO.setCreateTime(new Date());
  285. taskPatientDetailDO.setUpdateTime(new Date());
  286. taskPatientDetailDO.setTotal(Long.parseLong("0"));
  287. taskPatientDetailDao.save(taskPatientDetailDO);
  288. }
  289. }
  290. logger.info("uploadTime:"+creditsDetailDO.getUploadTime());
  291. if (creditsDetailDO.getUploadTime()!=null&&creditsDetailDO.getUploadTime()!=""){
  292. creditsDetailDO.setCreateTime(DateUtil.strToDateLong(creditsDetailDO.getUploadTime()));
  293. }else {
  294. creditsDetailDO.setCreateTime(new Date());
  295. }
  296. creditsDetailDO.setUpdateTime(new Date());
  297. CreditsDetailDO creditsDetailDO1 =credittsLogDetailDao.save(creditsDetailDO);
  298. creditsDetailDO1.setFlag(creditsDetailDO.getFlag());
  299. List<CreditsDetailDO> creditsDetailDOList = new ArrayList<>();
  300. creditsDetailDOList.add(creditsDetailDO1);
  301. TaskPatientDetailDO taskPatientDetailDO = new TaskPatientDetailDO();
  302. taskPatientDetailDO.setPatientId(creditsDetailDO1.getPatientId());
  303. taskPatientDetailDO.setTaskId(creditsDetailDO1.getTransactionId());
  304. String taskSql1 = ISqlUtils.getAllSql(taskPatientDetailDO);
  305. List<TaskPatientDetailDO> taskPatientDetailDOS1 = jdbcTemplate.query(taskSql1,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  306. TaskPatientDetailDO taskPatientDetailDO1 = taskPatientDetailDOS1.get(0);
  307. if (creditsDetailDO1.getTradeDirection() == 1){
  308. taskPatientDetailDO1.setTotal(taskPatientDetailDO1.getTotal()+creditsDetailDO1.getIntegrate());
  309. }else if (creditsDetailDO.getTradeDirection() == -1){
  310. taskPatientDetailDO1.setTotal(taskPatientDetailDO1.getTotal()-creditsDetailDO1.getIntegrate());
  311. }
  312. taskPatientDetailDao.save(taskPatientDetailDO1);
  313. AccountDO accountDO = accountDao.findOne(creditsDetailDO1.getAccountId());
  314. if (creditsDetailDO1.getTradeDirection() == 1){
  315. accountDO.setTotal(accountDO.getTotal()+creditsDetailDO1.getIntegrate());
  316. }else if (creditsDetailDO.getTradeDirection() == -1){
  317. accountDO.setTotal(accountDO.getTotal()-creditsDetailDO1.getIntegrate());
  318. }
  319. AccountDO accountDO1 = accountDao.save(accountDO);
  320. List<CreditsDetailDO> creditsDetailDOS = new ArrayList<>();
  321. for (CreditsDetailDO creditsDetailDO2:creditsDetailDOList){
  322. creditsDetailDO2.setTotal(accountDO1.getTotal());
  323. creditsDetailDOS.add(creditsDetailDO2);
  324. }
  325. MixEnvelop<CreditsDetailDO, CreditsDetailDO> envelop = new MixEnvelop<>();
  326. envelop.setDetailModelList(creditsDetailDOS);
  327. return envelop;
  328. }
  329. }catch (Exception e){
  330. e.printStackTrace();
  331. MixEnvelop<CreditsDetailDO, CreditsDetailDO> envelop = new MixEnvelop<>();
  332. return envelop;
  333. }
  334. }
  335. /**
  336. * 活动排名
  337. *
  338. * @param activityId 活动id
  339. * @param ids 微信编码
  340. *
  341. * @param page 页码
  342. *
  343. * @param size 分页大小
  344. * @return
  345. */
  346. public MixEnvelop<TaskPatientDetailDO, TaskPatientDetailDO> selectByActivityRanking(String activityId, List<String> ids, Integer page, Integer size){
  347. StringBuffer buffer = new StringBuffer();
  348. buffer.append("(");
  349. if (ids == null || ids.size() == 0){
  350. buffer.append("''");
  351. }else {
  352. for (int i=0;i<ids.size();i++){
  353. buffer.append("'"+ids.get(i)+"'").append(",");
  354. }
  355. buffer.deleteCharAt(buffer.length()-1);
  356. }
  357. buffer.append(") ");
  358. String sql = "SELECT " +
  359. " * " +
  360. "FROM " +
  361. " ( " +
  362. " SELECT " +
  363. " SUM(ptpd.total) AS total, " +
  364. " ptpd.patient_openid AS patient_openid, " +
  365. " ptpd.task_id AS task_id, " +
  366. " ptpd.activity_id AS activity_id, " +
  367. " ptpd.create_time as create_time, " +
  368. " ptpd.patient_id AS patient_id " +
  369. " FROM " +
  370. " wlyy_health_bank_task_patient_detail ptpd " +
  371. " WHERE " +
  372. " activity_id = '" + activityId +
  373. "' GROUP BY " +
  374. " patient_id " +
  375. " ORDER BY ptpd.create_time DESC " +
  376. " )btpd1 " +
  377. " WHERE patient_id IN "+buffer+
  378. " ORDER BY btpd1.total DESC "+" LIMIT " + (page-1)*size+","+size;
  379. List<TaskPatientDetailDO> taskPatientDetailDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  380. for (TaskPatientDetailDO taskPatientDetailDO : taskPatientDetailDOS){
  381. String accountSql = "select * from wlyy_health_bank_account where patient_id = '"+taskPatientDetailDO.getPatientId()+"'";
  382. List<AccountDO> accountDOS = jdbcTemplate.query(accountSql,new BeanPropertyRowMapper(AccountDO.class));
  383. taskPatientDetailDO.setAccountDO(accountDOS.get(0));
  384. }
  385. String sqlCount = "SELECT " +
  386. " count(1) AS total " +
  387. "FROM " +
  388. " ( " +
  389. " SELECT " +
  390. " SUM(ptpd.total) AS total, " +
  391. " ptpd.patient_openid AS patient_openid, " +
  392. " ptpd.task_id AS task_id, " +
  393. " ptpd.activity_id AS activity_id, " +
  394. " ptpd.create_time as create_time, " +
  395. " ptpd.patient_id AS patient_id " +
  396. " FROM " +
  397. " wlyy_health_bank_task_patient_detail ptpd " +
  398. " WHERE " +
  399. " activity_id = '" + activityId+
  400. "' GROUP BY " +
  401. " patient_openid " +
  402. " ORDER BY ptpd.create_time DESC " +
  403. " )btpd1 " +
  404. "WHERE patient_openid IN "+buffer+
  405. " ORDER BY btpd1.total DESC ";
  406. List<Map<String,Object>> rstotal = jdbcTemplate.queryForList(sqlCount);
  407. Long count = 0L;
  408. if(rstotal!=null&&rstotal.size()>0){
  409. count = (Long) rstotal.get(0).get("total");
  410. }
  411. return MixEnvelop.getSuccessListWithPage(HealthBankMapping.api_success, taskPatientDetailDOS,page,size,count);
  412. }
  413. /**
  414. * 根据活动查询积分
  415. *
  416. * @param activityId 活动id
  417. *
  418. * @param patientId 居民id
  419. *
  420. * @param page 页码
  421. *
  422. * @param size 分页大小
  423. * @return
  424. */
  425. public MixEnvelop<CreditsDetailDO, CreditsDetailDO> selectByActivity(String activityId, String patientId, Integer page, Integer size){
  426. String sql="SELECT * " +
  427. "FROM " +
  428. " wlyy_health_bank_credits_detail " +
  429. "WHERE" +
  430. " transaction_id IN ( " +
  431. " SELECT " +
  432. " bt.id " +
  433. " FROM " +
  434. " wlyy_health_bank_task bt " +
  435. " WHERE " +
  436. " transaction_id = '"+activityId +"' " +
  437. " ) " +
  438. " and patient_id = '" +patientId+
  439. "' LIMIT "+(page-1)*size +","+size;
  440. List<CreditsDetailDO> creditsDetailDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper(CreditsDetailDO.class));
  441. for (CreditsDetailDO creditsDetailDO : creditsDetailDOS){
  442. TaskDO taskDO = taskDao.findOne(creditsDetailDO.getTransactionId());
  443. creditsDetailDO.setTaskDO(taskDO);
  444. }
  445. String sqlcount = "SELECT count(1) AS" +
  446. " total FROM " +
  447. " wlyy_health_bank_credits_detail " +
  448. "WHERE" +
  449. " transaction_id IN ( " +
  450. " SELECT " +
  451. " bt.id " +
  452. " FROM " +
  453. " wlyy_health_bank_task bt " +
  454. " WHERE " +
  455. " transaction_id = '"+activityId +"' " +
  456. " ) " +
  457. " and patient_id = '" +patientId+
  458. "'";
  459. List<Map<String,Object>> rstotal = jdbcTemplate.queryForList(sqlcount);
  460. Long count = 0L;
  461. if(rstotal!=null&&rstotal.size()>0){
  462. count = (Long) rstotal.get(0).get("total");
  463. }
  464. return MixEnvelop.getSuccessListWithPage(HealthBankMapping.api_success,creditsDetailDOS,page,size,count);
  465. }
  466. /**
  467. * 根据活动查找全部排行
  468. *
  469. * @param activityId 活动id
  470. * @param page 页码
  471. * @param size 分页大小
  472. * @return
  473. */
  474. public MixEnvelop<TaskPatientDetailDO, TaskPatientDetailDO> selectByActivityRanking1(String activityId, String patientId, Integer page, Integer size){
  475. String sql = "SELECT " +
  476. " * " +
  477. "FROM " +
  478. " ( " +
  479. " SELECT " +
  480. " SUM(ptpd.total) AS total, " +
  481. " ptpd.patient_openid AS patient_openid, " +
  482. " ptpd.task_id AS task_id, " +
  483. " ptpd.activity_id AS activity_id, " +
  484. " ptpd.create_time as create_time, " +
  485. " ptpd.patient_id AS patient_id " +
  486. " FROM " +
  487. " wlyy_health_bank_task_patient_detail ptpd " +
  488. " WHERE " +
  489. " activity_id = '" + activityId +
  490. "' GROUP BY " +
  491. " patient_openid " +
  492. " ORDER BY ptpd.create_time DESC " +
  493. " )btpd1 " +
  494. " ORDER BY btpd1.total DESC "+" LIMIT " + (page-1)*size+","+size;
  495. List<TaskPatientDetailDO> taskPatientDetailDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  496. logger.info(taskPatientDetailDOS.toString()+""+taskPatientDetailDOS.size());
  497. for (int i = 0;taskPatientDetailDOS != null&&taskPatientDetailDOS.size()!=0 && i<taskPatientDetailDOS.size();i++){
  498. TaskPatientDetailDO taskPatientDetailDO = taskPatientDetailDOS.get(i);
  499. String accountSql = "select * from wlyy_health_bank_account where patient_id = '"+taskPatientDetailDO.getPatientId()+"'";
  500. List<AccountDO> accountDOS = jdbcTemplate.query(accountSql,new BeanPropertyRowMapper(AccountDO.class));
  501. if (taskPatientDetailDOS.get(i).getPatientId().equalsIgnoreCase(patientId)){
  502. /*String taskSql = "select count(1)+1 as total from (" +
  503. "select * from (SELECT " +
  504. " SUM(ptpd.total) AS total, " +
  505. " ptpd.patient_openid AS patient_openid, " +
  506. " ptpd.task_id AS task_id, " +
  507. " ptpd.activity_id AS activity_id, " +
  508. " ptpd.create_time as create_time, " +
  509. " ptpd.patient_id AS patient_id " +
  510. " FROM " +
  511. " wlyy_health_bank_task_patient_detail ptpd " +
  512. " WHERE " +
  513. " activity_id = '" + activityId + "')ptpd1 where" +
  514. " ptpd1.patient_id = '"+patientId+"' AND ptpd1.total > "+taskPatientDetailDOS.get(i).getTotal()+") ptpd2";
  515. List<Map<String,Object>> rstotal1 = jdbcTemplate.queryForList(taskSql);
  516. Long count = 0L;
  517. if(rstotal1!=null&&rstotal1.size()>0){
  518. count = (Long) rstotal1.get(0).get("total");
  519. }
  520. accountDOS.get(0).setActivityRanking(count);*/
  521. taskPatientDetailDO.setIsFlag(1);
  522. }else {
  523. taskPatientDetailDO.setIsFlag(0);
  524. }
  525. taskPatientDetailDO.setAccountDO(accountDOS.get(0));
  526. }
  527. String sqlCount = "SELECT " +
  528. " count(1) AS total " +
  529. "FROM " +
  530. " ( " +
  531. " SELECT " +
  532. " SUM(ptpd.total) AS total, " +
  533. " ptpd.patient_openid AS patient_openid, " +
  534. " ptpd.task_id AS task_id, " +
  535. " ptpd.activity_id AS activity_id, " +
  536. " ptpd.create_time as create_time, " +
  537. " ptpd.patient_id AS patient_id " +
  538. " FROM " +
  539. " wlyy_health_bank_task_patient_detail ptpd " +
  540. " WHERE " +
  541. " activity_id = '" + activityId+
  542. "' GROUP BY " +
  543. " patient_openid " +
  544. " ORDER BY ptpd.create_time DESC " +
  545. " )btpd1 " +
  546. " ORDER BY btpd1.total DESC ";
  547. List<Map<String,Object>> rstotal = jdbcTemplate.queryForList(sqlCount);
  548. Long count = 0L;
  549. if(rstotal!=null&&rstotal.size()>0){
  550. count = (Long) rstotal.get(0).get("total");
  551. }
  552. return MixEnvelop.getSuccessListWithPage(HealthBankMapping.api_success, taskPatientDetailDOS,page,size,count);
  553. }
  554. /**
  555. * 医生主动加分
  556. *
  557. * @param array 居民信息集合
  558. *
  559. * @param ruleId 规则id
  560. * @return
  561. */
  562. public MixEnvelop<Boolean, Boolean> doctorAddIntegrate(JSONArray array, String ruleId, String description) throws Exception {
  563. MixEnvelop<Boolean, Boolean> envelop = new MixEnvelop<>();
  564. for (int i=0;i<array.size();i++){
  565. TaskRuleDO taskRuleDO = taskRuleDao.findOne(ruleId);
  566. JSONObject object = array.getJSONObject(i);
  567. String patientId = object.getString("code");
  568. String idCard = object.getString("idcard");
  569. String unionId = object.getString("unionid");
  570. String openId = object.getString("openid");
  571. String hospital = object.getString("hospital");
  572. String hospitalName = object.getString("hospitalName");
  573. String taskSql = "select * from wlyy_health_bank_task bt where type = 'RULE_TASK' AND transaction_id = '"+ruleId +"'";
  574. List<TaskDO> taskDOList = jdbcTemplate.query(taskSql,new BeanPropertyRowMapper(TaskDO.class));
  575. TaskDO taskDO1 = new TaskDO();
  576. if (taskDOList.isEmpty() && taskDOList.size() == 0){
  577. TaskDO taskDO = new TaskDO();
  578. taskDO.setTransactionId(taskRuleDO.getId());
  579. taskDO.setTaskCode("RULE");
  580. taskDO.setStatus(1);
  581. taskDO.setRuleCode(taskRuleDO.getId());
  582. taskDO.setType("RULE_TASK");
  583. taskDO.setCreateTime(new Date());
  584. taskDO.setUpdateTime(new Date());
  585. taskDO.setPeriod(taskRuleDO.getPeriod());
  586. taskDO.setSaasId("dev");
  587. taskDO.setTitle(taskRuleDO.getDescription());
  588. taskDO.setContent(taskRuleDO.getDescription());
  589. taskDO1 = taskDao.save(taskDO);
  590. }else {
  591. taskDO1 = taskDOList.get(0);
  592. }
  593. if (taskRuleDO.getPeriod() == 1){
  594. String sql = "select * from wlyy_health_bank_task_patient_detail where patient_id = '"+patientId+"'AND task_id ='"+taskDO1.getId()+"'";
  595. List<TaskPatientDetailDO> taskPatientDetailDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  596. if (taskPatientDetailDOS != null && taskPatientDetailDOS.size() != 0){
  597. throw new Exception("已奖励过");
  598. }
  599. }else if (taskRuleDO.getPeriod() == 0){
  600. SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
  601. Date date = new Date();
  602. String date1 = dateFormat.format(date);
  603. String begin = DateUtils.getMinMonthDate(date1);
  604. String end = DateUtils.getMaxMonthDate(date1);
  605. 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+"'";
  606. List<TaskPatientDetailDO> taskPatientDetailDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  607. if (taskPatientDetailDOS != null && taskPatientDetailDOS.size() != 0){
  608. throw new Exception("已奖励过");
  609. }
  610. }
  611. String sql1 = "select * from wlyy_health_bank_task_patient_detail where task_id = '"+taskDO1.getId()+"' " +
  612. "AND patient_idcard = '"+idCard+"' AND patient_openid = '"+openId+"' AND union_id = '"+unionId+"'";
  613. List<TaskPatientDetailDO> taskPatientDetailDOS = jdbcTemplate.query(sql1,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  614. TaskPatientDetailDO taskPatientDetailDO1 = new TaskPatientDetailDO();
  615. if (taskPatientDetailDOS.isEmpty() && taskPatientDetailDOS.size() == 0){
  616. TaskPatientDetailDO taskPatientDetailDO = new TaskPatientDetailDO();
  617. taskPatientDetailDO.setStatus(1);
  618. taskPatientDetailDO.setTotal(Long.parseLong("0"));
  619. taskPatientDetailDO.setPatientId(patientId);
  620. taskPatientDetailDO.setPatientOpenid(openId);
  621. taskPatientDetailDO.setPatientIdcard(idCard);
  622. taskPatientDetailDO.setUnionId(unionId);
  623. taskPatientDetailDO.setSaasId("dev");
  624. taskPatientDetailDO.setCreateTime(new Date());
  625. taskPatientDetailDO.setUpdateTime(new Date());
  626. taskPatientDetailDO.setTaskId(taskDO1.getId());
  627. taskPatientDetailDO1 = taskPatientDetailDao.save(taskPatientDetailDO);
  628. }else {
  629. taskPatientDetailDO1 = taskPatientDetailDOS.get(0);
  630. }
  631. String sql = "select * from wlyy_health_bank_account where patient_id = '"+patientId+"'";
  632. List<AccountDO> accountDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper(AccountDO.class));
  633. if (taskRuleDO.getTradeDirection() == -1 && taskRuleDO.getIntegrate() == 0){
  634. String integrateSql = "select * from wlyy_health_bank_credits_detail where patient_id = '"+patientId+"' " +
  635. "AND transaction_id IN (SELECT id FROM wlyy_health_bank_task WHERE task_code IN ('BP_BIND','GLU_BIND','BP_MEASURE','GLU_MEASURE','RULE'))";
  636. List<CreditsDetailDO> creditsDetailDOS = jdbcTemplate.query(integrateSql,new BeanPropertyRowMapper(CreditsDetailDO.class));
  637. AccountDO accountDO = accountDOS.get(0);
  638. for (CreditsDetailDO creditsDetailDO:creditsDetailDOS){
  639. if (creditsDetailDO.getTradeDirection()==1&&creditsDetailDO.getStatus()!=0){
  640. /* int total = accountDO.getTotal() - creditsDetailDO.getIntegrate();*/
  641. creditsDetailDO.setStatus(0);
  642. creditsDetailDO.setDescription(description);
  643. credittsLogDetailDao.save(creditsDetailDO);
  644. }
  645. }
  646. accountDO.setTotal(0);
  647. accountDao.save(accountDO);
  648. CreditsDetailDO creditsDetailDO1 = new CreditsDetailDO();
  649. creditsDetailDO1.setStatus(1);
  650. creditsDetailDO1.setSaasId("dev");
  651. creditsDetailDO1.setAccountId(accountDOS.get(0).getId());
  652. creditsDetailDO1.setHospital(hospital);
  653. creditsDetailDO1.setHospitalName(hospitalName);
  654. creditsDetailDO1.setPatientId(patientId);
  655. creditsDetailDO1.setIntegrate(taskRuleDO.getIntegrate());
  656. creditsDetailDO1.setTradeDirection(taskRuleDO.getTradeDirection());
  657. creditsDetailDO1.setDescription(description);
  658. creditsDetailDO1.setCreateTime(new Date());
  659. creditsDetailDO1.setUpdateTime(new Date());
  660. creditsDetailDO1.setTransactionId(taskDO1.getId());
  661. creditsDetailDO1.setTradeType("ACTIVITY_TASK");
  662. credittsLogDetailDao.save(creditsDetailDO1);
  663. }else{
  664. CreditsDetailDO creditsDetailDO = new CreditsDetailDO();
  665. creditsDetailDO.setStatus(1);
  666. creditsDetailDO.setSaasId("dev");
  667. creditsDetailDO.setAccountId(accountDOS.get(0).getId());
  668. creditsDetailDO.setHospital(hospital);
  669. creditsDetailDO.setHospitalName(hospitalName);
  670. creditsDetailDO.setPatientId(patientId);
  671. creditsDetailDO.setIntegrate(taskRuleDO.getIntegrate());
  672. creditsDetailDO.setTradeDirection(taskRuleDO.getTradeDirection());
  673. creditsDetailDO.setDescription(description);
  674. creditsDetailDO.setCreateTime(new Date());
  675. creditsDetailDO.setUpdateTime(new Date());
  676. creditsDetailDO.setTransactionId(taskDO1.getId());
  677. creditsDetailDO.setTradeType("ACTIVITY_TASK");
  678. creditsDetailDO = credittsLogDetailDao.save(creditsDetailDO);
  679. if (taskRuleDO.getTradeDirection() == -1){
  680. if (taskRuleDO.getIntegrate() == 0){
  681. String integrateSql = "select * from wlyy_health_bank_credits_detail where patient_id = '"+patientId+"' " +
  682. "AND transaction_id IN (SELECT id FROM wlyy_health_bank_task WHERE task_code IN ('BP_BIND','GLU_BIND','BP_MEASURE','GLU_MEASURE','RULE'))";
  683. List<CreditsDetailDO> creditsDetailDOS = jdbcTemplate.query(integrateSql,new BeanPropertyRowMapper(CreditsDetailDO.class));
  684. AccountDO accountDO = accountDOS.get(0);
  685. for (CreditsDetailDO creditsDetailDO1:creditsDetailDOS){
  686. if (creditsDetailDO1.getTradeDirection()==1&&creditsDetailDO1.getStatus()!=0){
  687. int total = accountDO.getTotal() - creditsDetailDO1.getIntegrate();
  688. creditsDetailDO1.setStatus(0);
  689. creditsDetailDO1.setDescription(description);
  690. credittsLogDetailDao.save(creditsDetailDO1);
  691. }
  692. }
  693. accountDO.setTotal(0);
  694. accountDao.save(accountDO);
  695. }else if (taskRuleDO.getIntegrate()!=0){
  696. AccountDO accountDO = accountDOS.get(0);
  697. int total = accountDO.getTotal() - creditsDetailDO.getIntegrate();
  698. accountDO.setTotal(total);
  699. accountDao.save(accountDO);
  700. }
  701. }else if (taskRuleDO.getTradeDirection() == 1){
  702. AccountDO accountDO = accountDOS.get(0);
  703. accountDO.setTotal(accountDO.getTotal() + taskRuleDO.getIntegrate());
  704. accountDao.save(accountDO);
  705. }
  706. }
  707. }
  708. envelop.setObj(true);
  709. return envelop;
  710. }
  711. /**
  712. * 固定数据
  713. *
  714. * @param
  715. * @return
  716. *//*
  717. public List<TaskDO> getTasks(String patientId){
  718. List<TaskDO> taskDOList = new ArrayList<>();
  719. TaskDO taskDO = new TaskDO();
  720. *//*taskDO.setPatientId(patientId);*//*
  721. taskDO.setTaskCode("BIND");
  722. taskDO.setPeriod(1);
  723. taskDO.setTaskTitle("首次绑定");
  724. taskDO.setTaskContent("(绑定社区登记发放的设备,可获得各类型设备的首绑奖励。)");
  725. taskDO.setTradeType("activity");
  726. taskDO.setTransactionId("402885e96324a409016324c0a45a0006");
  727. taskDO.setCreateTime(new Date());
  728. taskDO.setUpdateTime(new Date());
  729. taskDOList.add(taskDO);
  730. TaskDO taskDO1 = new TaskDO();
  731. *//*taskDO1.setPatientId(patientId);*//*
  732. taskDO1.setTaskCode("MEASURE");
  733. taskDO1.setPeriod(0);
  734. taskDO1.setTaskTitle("每日测量");
  735. taskDO1.setTaskContent("(使用社区发放的已关联您身份信息的设备,绑定后每天完成测量)");
  736. taskDO1.setTradeType("activity");
  737. taskDO1.setTransactionId("402885e96324a409016324c0a45a0006");
  738. taskDO1.setCreateTime(new Date());
  739. taskDO1.setUpdateTime(new Date());
  740. taskDOList.add(taskDO1);
  741. return taskDOList;
  742. }
  743. */
  744. public MixEnvelop<CreditsDetailDO, CreditsDetailDO> stepAddIntegrate(CreditsDetailDO creditsDetailDO){
  745. try {
  746. synchronized (creditsDetailDO.getPatientId()){
  747. String sqlAccount = "select * from wlyy_health_bank_account ba where ba.patient_id = '"+creditsDetailDO.getPatientId() +"'";
  748. List<AccountDO> accountDOList = jdbcTemplate.query(sqlAccount,new BeanPropertyRowMapper(AccountDO.class));
  749. if (accountDOList != null && accountDOList.size() != 0){
  750. creditsDetailDO.setAccountId(accountDOList.get(0).getId());
  751. }else {
  752. AccountDO accountDO1 = new AccountDO();
  753. accountDO1.setPatientId(creditsDetailDO.getPatientId());
  754. accountDO1.setSaasId("dev");
  755. accountDO1.setTotal(0);
  756. accountDO1.setCouponTotal(0L);
  757. accountDO1.setAccountName(creditsDetailDO.getName());
  758. if(creditsDetailDO.getIdCard().length()>=4){// 判断是否长度大于等于4
  759. String cardNumber=creditsDetailDO.getIdCard().substring(creditsDetailDO.getIdCard().length()- 4,creditsDetailDO.getIdCard().length());//截取两个数字之间的部分
  760. int random = (int)((Math.random()*9+1)*100000);
  761. accountDO1.setCardNumber(cardNumber+Integer.toString(random));
  762. }
  763. accountDO1.setHospital(creditsDetailDO.getHospital());
  764. accountDO1.setPassword("123456");
  765. accountDO1.setHospitalName(creditsDetailDO.getHospitalName());
  766. accountDO1.setStatus(1);
  767. accountDO1.setCreateTime(new Date());
  768. accountDO1.setUpdateTime(new Date());
  769. accountDao.save(accountDO1);
  770. List<AccountDO> accountDOS = jdbcTemplate.query(sqlAccount,new BeanPropertyRowMapper(AccountDO.class));
  771. creditsDetailDO.setAccountId(accountDOS.get(0).getId());
  772. }
  773. String sql1 = "select * from wlyy_health_bank_task_patient_detail where "+
  774. " patient_idcard = '"+creditsDetailDO.getIdCard()+"' AND union_id = '"+creditsDetailDO.getUnionId()+"' AND task_id = '"+creditsDetailDO.getTransactionId()+"'";
  775. List<TaskPatientDetailDO> taskPatientDetailDOList = jdbcTemplate.query(sql1,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  776. if(taskPatientDetailDOList == null || taskPatientDetailDOList.size()==0){
  777. throw new Exception("该居民参与活动查不到!");
  778. }
  779. TaskPatientDetailDO taskPatientDetailDO = taskPatientDetailDOList.get(0);
  780. String sql = "select * from wlyy_health_bank_credits_detail where patient_id = '"+creditsDetailDO.getPatientId()+"' AND " +
  781. "transaction_id = '"+creditsDetailDO.getTransactionId()+"' AND create_time > '"+DateUtils.getDayBegin() +"' AND" +
  782. " create_time < '"+DateUtils.getDayEnd()+"'AND ISNULL(description)";
  783. List<CreditsDetailDO> creditsDetailDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper<>(CreditsDetailDO.class));
  784. int integrate1=0;
  785. for (CreditsDetailDO detailDO:creditsDetailDOS){
  786. integrate1+= detailDO.getIntegrate();
  787. }
  788. ActivityRuleDO activityRuleDO = activityRuleDao.selectByActivityId(taskPatientDetailDO.getActivityId());
  789. logger.info("开始"+activityRuleDO.getValue1());
  790. logger.info("参数:"+creditsDetailDO.getIntegrate()+creditsDetailDO.getStepNumber());
  791. if (activityRuleDO.getValue1() != null){
  792. JSONObject object = JSONObject.parseObject(activityRuleDO.getValue1());
  793. //获取步数
  794. JSONArray array = object.getJSONArray("healthStep");
  795. int j = array.size();
  796. int z= 0;
  797. for (int i = 0;i<=array.size();i++){
  798. JSONObject jsonObject = array.getJSONObject(i);
  799. Long step = jsonObject.getLong("step");
  800. int integrate = jsonObject.getInteger("integrate");
  801. if (creditsDetailDOS != null && creditsDetailDOS.size() != 0){
  802. CreditsDetailDO creditsDetailDO1 = creditsDetailDOS.get(0);
  803. if (creditsDetailDO.getStepNumber()>0 && creditsDetailDO.getStepNumber()<=step){
  804. creditsDetailDO.setIntegrate(creditsDetailDO.getIntegrate());
  805. creditsDetailDO.setTradeDirection(1);
  806. creditsDetailDO.setUpdateTime(new Date());
  807. creditsDetailDO.setCreateTime(new Date());
  808. creditsDetailDO.setTradeType("ACTIVITY_TASK");
  809. CreditsDetailDO creditsDetailDO2 = credittsLogDetailDao.save(creditsDetailDO);
  810. AccountDO accountDO = accountDao.findOne(creditsDetailDO2.getAccountId());
  811. accountDO.setTotal(accountDO.getTotal()+creditsDetailDO2.getIntegrate());
  812. AccountDO accountDO1 = accountDao.save(accountDO);
  813. creditsDetailDO2.setTotal(accountDO1.getTotal());
  814. taskPatientDetailDO.setTotal(taskPatientDetailDO.getTotal()+creditsDetailDO2.getIntegrate());
  815. taskPatientDetailDao.save(taskPatientDetailDO);
  816. creditsDetailDOS.clear();
  817. creditsDetailDOS.add(creditsDetailDO2);
  818. break;
  819. }
  820. }else {
  821. CreditsDetailDO creditsDetailDO1 = new CreditsDetailDO();
  822. if (creditsDetailDO.getStepNumber()>0 && creditsDetailDO.getStepNumber()<=step){
  823. creditsDetailDO1.setIntegrate(creditsDetailDO.getIntegrate());
  824. creditsDetailDO1.setTradeDirection(1);
  825. creditsDetailDO1.setSaasId("dev");
  826. creditsDetailDO1.setTradeType("ACTIVITY_TASK");
  827. creditsDetailDO1.setPatientId(creditsDetailDO.getPatientId());
  828. creditsDetailDO1.setHospital(creditsDetailDO.getHospital());
  829. creditsDetailDO1.setHospitalName(creditsDetailDO.getHospitalName());
  830. creditsDetailDO1.setAccountId(creditsDetailDO.getAccountId());
  831. creditsDetailDO1.setStatus(1);
  832. creditsDetailDO1.setCreateTime(new Date());
  833. creditsDetailDO1.setUpdateTime(new Date());
  834. creditsDetailDO1.setTransactionId(taskPatientDetailDO.getTaskId());
  835. CreditsDetailDO creditsDetailDO2 = credittsLogDetailDao.save(creditsDetailDO1);
  836. AccountDO accountDO = accountDao.findOne(creditsDetailDO2.getAccountId());
  837. accountDO.setTotal(accountDO.getTotal()+creditsDetailDO2.getIntegrate());
  838. taskPatientDetailDO.setTotal(taskPatientDetailDO.getTotal()+creditsDetailDO2.getIntegrate());
  839. taskPatientDetailDao.save(taskPatientDetailDO);
  840. accountDao.save(accountDO);
  841. creditsDetailDO2.setTotal(accountDO.getTotal());
  842. creditsDetailDOS.add(creditsDetailDO2);
  843. break;
  844. }
  845. }
  846. }
  847. }
  848. /* for (int i = 0;i<array.size();i++){
  849. JSONObject jsonObject = array.getJSONObject(i);
  850. if (creditsDetailDOS != null && creditsDetailDOS.size() != 0){
  851. CreditsDetailDO creditsDetailDO1 = creditsDetailDOS.get(0);
  852. TaskRuleDO taskRuleDO = taskRuleDao.findOne(taskDO.getRuleCode());
  853. if (creditsDetailDO.getStepNumber() < step1 && creditsDetailDO.getStepNumber() >0){
  854. creditsDetailDO1.setIntegrate(0);
  855. creditsDetailDO1.setTradeDirection(1);
  856. CreditsDetailDO creditsDetailDO2 = credittsLogDetailDao.save(creditsDetailDO1);
  857. AccountDO accountDO = accountDao.findOne(creditsDetailDO2.getAccountId());
  858. accountDO.setTotal(accountDO.getTotal()+creditsDetailDO2.getIntegrate());
  859. AccountDO accountDO1 = accountDao.save(accountDO);
  860. creditsDetailDO2.setTotal(accountDO1.getTotal());
  861. taskPatientDetailDO.setTotal(taskPatientDetailDO.getTotal()+creditsDetailDO2.getIntegrate());
  862. taskPatientDetailDao.save(taskPatientDetailDO);
  863. creditsDetailDOS.clear();
  864. creditsDetailDOS.add(creditsDetailDO2);
  865. }else if (creditsDetailDO.getStepNumber() >= step1 && creditsDetailDO.getStepNumber() < step2){
  866. creditsDetailDO1.setIntegrate(creditsDetailDO1.getIntegrate()+1);
  867. creditsDetailDO1.setTradeDirection(1);
  868. CreditsDetailDO creditsDetailDO2 = credittsLogDetailDao.save(creditsDetailDO1);
  869. AccountDO accountDO = accountDao.findOne(creditsDetailDO2.getAccountId());
  870. accountDO.setTotal(accountDO.getTotal()+(creditsDetailDO2.getIntegrate()));
  871. AccountDO accountDO1 = accountDao.save(accountDO);
  872. creditsDetailDO2.setTotal(accountDO1.getTotal());
  873. taskPatientDetailDO.setTotal(taskPatientDetailDO.getTotal()+(creditsDetailDO2.getIntegrate()));
  874. taskPatientDetailDao.save(taskPatientDetailDO);
  875. creditsDetailDOS.clear();
  876. creditsDetailDOS.add(creditsDetailDO2);
  877. }else if (creditsDetailDO.getStepNumber() >= step2){
  878. if (creditsDetailDO1.getIntegrate() == 1){
  879. creditsDetailDO1.setIntegrate(2);
  880. creditsDetailDO1.setTradeDirection(1);
  881. CreditsDetailDO creditsDetailDO2 = credittsLogDetailDao.save(creditsDetailDO1);
  882. AccountDO accountDO = accountDao.findOne(creditsDetailDO2.getAccountId());
  883. accountDO.setTotal(accountDO.getTotal()+(creditsDetailDO2.getIntegrate()-1));
  884. AccountDO accountDO1 = accountDao.save(accountDO);
  885. creditsDetailDO2.setTotal(accountDO1.getTotal());
  886. taskPatientDetailDO.setTotal(taskPatientDetailDO.getTotal()+(creditsDetailDO2.getIntegrate()-1));
  887. taskPatientDetailDao.save(taskPatientDetailDO);
  888. creditsDetailDOS.clear();
  889. creditsDetailDOS.add(creditsDetailDO2);
  890. }*//*else if(creditsDetailDO1.getIntegrate() == 3){
  891. creditsDetailDO1.setIntegrate(creditsDetailDO1.getIntegrate()+5);
  892. creditsDetailDO1.setTradeDirection(1);
  893. CreditsDetailDO creditsDetailDO2 = credittsLogDetailDao.save(creditsDetailDO1);
  894. AccountDO accountDO = accountDao.findOne(creditsDetailDO2.getAccountId());
  895. accountDO.setTotal(accountDO.getTotal()+(creditsDetailDO2.getIntegrate()-3));
  896. AccountDO accountDO1 = accountDao.save(accountDO);
  897. creditsDetailDO2.setTotal(accountDO1.getTotal());
  898. taskPatientDetailDO.setTotal(taskPatientDetailDO.getTotal()+(creditsDetailDO2.getIntegrate()-3));
  899. taskPatientDetailDao.save(taskPatientDetailDO);
  900. creditsDetailDOS.clear();
  901. creditsDetailDOS.add(creditsDetailDO2);
  902. }*//*
  903. }
  904. }else{
  905. CreditsDetailDO creditsDetailDO1 = new CreditsDetailDO();
  906. if (creditsDetailDO.getStepNumber() < step1 && creditsDetailDO.getStepNumber() >0){
  907. creditsDetailDO1.setIntegrate(0);
  908. creditsDetailDO1.setTradeDirection(1);
  909. }else if (creditsDetailDO.getStepNumber() >= step1 && creditsDetailDO.getStepNumber() < step2){
  910. creditsDetailDO1.setIntegrate(1);
  911. creditsDetailDO1.setTradeDirection(1);
  912. }else if (creditsDetailDO.getStepNumber() >=step2){
  913. creditsDetailDO1.setIntegrate(2);
  914. creditsDetailDO1.setTradeDirection(1);
  915. }
  916. creditsDetailDO1.setSaasId("dev");
  917. creditsDetailDO1.setTradeType("ACTIVITY_TASK");
  918. creditsDetailDO1.setPatientId(creditsDetailDO.getPatientId());
  919. creditsDetailDO1.setHospital(creditsDetailDO.getHospital());
  920. creditsDetailDO1.setHospitalName(creditsDetailDO.getHospitalName());
  921. creditsDetailDO1.setAccountId(creditsDetailDO.getAccountId());
  922. creditsDetailDO1.setStatus(1);
  923. creditsDetailDO1.setCreateTime(new Date());
  924. creditsDetailDO1.setUpdateTime(new Date());
  925. creditsDetailDO1.setTransactionId(taskPatientDetailDO.getTaskId());
  926. CreditsDetailDO creditsDetailDO2 = credittsLogDetailDao.save(creditsDetailDO1);
  927. AccountDO accountDO = accountDao.findOne(creditsDetailDO2.getAccountId());
  928. accountDO.setTotal(accountDO.getTotal()+creditsDetailDO2.getIntegrate());
  929. taskPatientDetailDO.setTotal(taskPatientDetailDO.getTotal()+creditsDetailDO2.getIntegrate());
  930. taskPatientDetailDao.save(taskPatientDetailDO);
  931. creditsDetailDO2.setTotal(accountDO.getTotal());
  932. creditsDetailDOS.add(creditsDetailDO2);
  933. }*/
  934. /* String step = redisTemplate.opsForValue().get(STEP);
  935. if (StringUtils.isEmpty(step)){
  936. throw new Exception("获取步数失败!");
  937. }
  938. JSONObject object = JSONObject.parseObject(step);
  939. int step1 = object.getInteger("step1");
  940. int step2 = object.getInteger("step2");
  941. */
  942. try{
  943. activeRecordService.insert("dev",creditsDetailDOS.get(0).getTransactionId(),null,null,null,creditsDetailDOS.get(0).getPatientId());
  944. }catch (Exception e){
  945. logger.error("插入活跃出错:"+e.getMessage());
  946. }
  947. MixEnvelop<CreditsDetailDO, CreditsDetailDO> envelop = new MixEnvelop<>();
  948. envelop.setDetailModelList(creditsDetailDOS);
  949. return envelop;
  950. }
  951. }catch (Exception e){
  952. e.printStackTrace();
  953. MixEnvelop<CreditsDetailDO, CreditsDetailDO> envelop = new MixEnvelop<>();
  954. return envelop;
  955. }
  956. }
  957. public MixEnvelop doctorDescreaseIntegrate(String ruleId,String patientId,String doctorId,String hospital,String hospitalName,Integer integrate,String reason) throws Exception {
  958. MixEnvelop envelop = new MixEnvelop<>();
  959. envelop.setObj(true);
  960. TaskDO taskDO = taskDao.selectByTaskRuleId(ruleId);
  961. String sql = "select * from wlyy_health_bank_account where status = 1 and patient_id = '"+patientId+"'";
  962. List<AccountDO> accountDOs = jdbcTemplate.query(sql,new BeanPropertyRowMapper(AccountDO.class));
  963. AccountDO accountDO = accountDOs.get(0);
  964. if (taskDO == null){
  965. TaskRuleDO taskRuleDO = taskRuleDao.findByCode(ruleId);
  966. TaskDO taskDO1 = new TaskDO();
  967. taskDO1.setTitle(taskRuleDO.getName());
  968. taskDO1.setContent(taskRuleDO.getDescription());
  969. taskDO1.setSaasId("dev");
  970. taskDO1.setTaskCode("RULE");
  971. taskDO1.setType("RULE_TASK");
  972. taskDO1.setTransactionId(ruleId);
  973. taskDO1.setCreateTime(new Date());
  974. taskDO1.setUpdateTime(new Date());
  975. taskDO1.setRuleCode(taskRuleDO.getId());
  976. taskDO1.setStatus(1);
  977. taskDO = taskDao.save(taskDO1);
  978. }
  979. TaskPatientDetailDO patientDetailDO = taskPatientDetailDao.selectByTaskIdAndPatientId(taskDO.getId(),patientId);
  980. if (patientDetailDO == null){
  981. TaskPatientDetailDO taskPatientDetailDO = new TaskPatientDetailDO();
  982. taskPatientDetailDO.setSaasId("dev");
  983. taskPatientDetailDO.setTaskId(taskDO.getId());
  984. taskPatientDetailDO.setPatientId(patientId);
  985. taskPatientDetailDO.setDoctorId(doctorId);
  986. taskPatientDetailDO.setPatientIdcard(accountDO.getIdCard());
  987. taskPatientDetailDO.setCreateTime(new Date());
  988. taskPatientDetailDO.setUpdateTime(new Date());
  989. taskPatientDetailDO.setStatus(1);
  990. taskPatientDetailDao.save(taskPatientDetailDO);
  991. }
  992. if (accountDO.getTotal().compareTo(integrate)>=0){
  993. CreditsDetailDO creditsDetailDO = new CreditsDetailDO();
  994. creditsDetailDO.setAccountId(accountDO.getId());
  995. creditsDetailDO.setIdCard(accountDO.getIdCard());
  996. creditsDetailDO.setSaasId("dev");
  997. creditsDetailDO.setTradeType("ACTIVITY_TASK");
  998. creditsDetailDO.setTradeDirection(-1);
  999. creditsDetailDO.setIntegrate(integrate);
  1000. creditsDetailDO.setDescription(reason);
  1001. creditsDetailDO.setStatus(1);
  1002. creditsDetailDO.setHospital(hospital);
  1003. creditsDetailDO.setHospitalName(hospitalName);
  1004. creditsDetailDO.setCreateTime(new Date());
  1005. creditsDetailDO.setUpdateTime(new Date());
  1006. creditsDetailDO.setTransactionId(taskDO.getId());
  1007. creditsDetailDO.setPatientId(patientId);
  1008. creditsDetailDO.setHospitalName(hospitalName);
  1009. credittsLogDetailDao.save(creditsDetailDO);
  1010. accountDO.setTotal(accountDO.getTotal()-integrate);
  1011. accountDao.save(accountDO);
  1012. }else {
  1013. envelop.setMessage("积分不足!");
  1014. throw new Exception("积分不足!");
  1015. }
  1016. return envelop;
  1017. }
  1018. /*public JSONObject getStepNumber(){
  1019. String step = redisTemplate.·().get(STEP);
  1020. logger.info("redis数据:"+step);
  1021. String sql = ""
  1022. String step1 = systemDictDao.
  1023. logger.info("数据库的数据:"+step1);
  1024. if (step != null && step.equalsIgnoreCase(step1)){
  1025. JSONObject jsonObject = JSONObject.parseObject(step);
  1026. logger.info("数据不一致:"+jsonObject.toString());
  1027. return jsonObject;
  1028. }else {
  1029. JSONObject jsonObject = JSONObject.parseObject(step);
  1030. redisTemplate.opsForValue().set(STEP,step1);
  1031. logger.info("数据一致:"+jsonObject.toString());
  1032. return jsonObject;
  1033. }
  1034. }*/
  1035. public MixEnvelop<CreditsDetailDO, CreditsDetailDO> weekReward(CreditsDetailDO creditsDetailDO) {
  1036. try {
  1037. synchronized (creditsDetailDO.getPatientId()) {
  1038. String sqlAccount = "select * from wlyy_health_bank_account ba where ba.patient_id = '" + creditsDetailDO.getPatientId() + "'";
  1039. List<AccountDO> accountDOList = jdbcTemplate.query(sqlAccount, new BeanPropertyRowMapper(AccountDO.class));
  1040. if (accountDOList != null && accountDOList.size() != 0) {
  1041. creditsDetailDO.setAccountId(accountDOList.get(0).getId());
  1042. }
  1043. String creditsSql = "select * from wlyy_health_bank_credits_detail where patient_id = '" + creditsDetailDO.getPatientId() + "' and " +
  1044. "DATE_FORMAT(create_time,'%Y-%m-%d') IN " + creditsDetailDO.getWeekTimes()+" and description = '周奖励'";
  1045. List<CreditsDetailDO> creditsDetailDOS1 = jdbcTemplate.query(creditsSql, new BeanPropertyRowMapper(CreditsDetailDO.class));
  1046. List<CreditsDetailDO> creditsDetailDOList = new ArrayList<>();
  1047. MixEnvelop<CreditsDetailDO, CreditsDetailDO> envelop = new MixEnvelop<>();
  1048. if (getWeekOfDate(new Date()).equalsIgnoreCase("星期五")||getWeekOfDate(new Date()).equalsIgnoreCase("星期六")||getWeekOfDate(new Date()).equalsIgnoreCase("星期日")){
  1049. String sql = "select sum(integrate) as total from wlyy_health_bank_credits_detail where patient_id = '" + creditsDetailDO.getPatientId() + "' and description = '周奖励'";
  1050. List<Map<String,Object>> rstotal = jdbcTemplate.queryForList(sql);
  1051. Long count = 0L;
  1052. if(rstotal!=null&&rstotal.size()>0){
  1053. Object object = rstotal.get(0).get("total");
  1054. if (object != null){
  1055. count = Long.parseLong(object.toString());
  1056. }
  1057. }
  1058. if (count > 12){
  1059. envelop.setMessage("奖励积分已达到12分。不能再奖励了!");
  1060. return envelop;
  1061. }else{
  1062. if (creditsDetailDOS1 == null || creditsDetailDOS1.size() == 0) {
  1063. creditsDetailDO.setTradeType("ACTIVITY_TASK");
  1064. creditsDetailDO.setSaasId("dev");
  1065. creditsDetailDO.setStatus(1);
  1066. creditsDetailDO.setTransactionId(creditsDetailDO.getTransactionId());
  1067. creditsDetailDO.setCreateTime(new Date());
  1068. creditsDetailDO.setUpdateTime(new Date());
  1069. creditsDetailDO.setTradeDirection(1);
  1070. CreditsDetailDO creditsDetailDO1 = credittsLogDetailDao.save(creditsDetailDO);
  1071. creditsDetailDOList.add(creditsDetailDO1);
  1072. TaskPatientDetailDO taskPatientDetailDO = new TaskPatientDetailDO();
  1073. taskPatientDetailDO.setPatientId(creditsDetailDO1.getPatientId());
  1074. taskPatientDetailDO.setTaskId(creditsDetailDO1.getTransactionId());
  1075. String taskSql1 = ISqlUtils.getAllSql(taskPatientDetailDO);
  1076. List<TaskPatientDetailDO> taskPatientDetailDOS1 = jdbcTemplate.query(taskSql1, new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  1077. TaskPatientDetailDO taskPatientDetailDO1 = taskPatientDetailDOS1.get(0);
  1078. if (creditsDetailDO1.getTradeDirection() == 1) {
  1079. taskPatientDetailDO1.setTotal(taskPatientDetailDO1.getTotal() + creditsDetailDO1.getIntegrate());
  1080. } else if (creditsDetailDO.getTradeDirection() == -1) {
  1081. taskPatientDetailDO1.setTotal(taskPatientDetailDO1.getTotal() - creditsDetailDO1.getIntegrate());
  1082. }
  1083. taskPatientDetailDao.save(taskPatientDetailDO1);
  1084. AccountDO accountDO = accountDao.findOne(creditsDetailDO1.getAccountId());
  1085. if (creditsDetailDO1.getTradeDirection() == 1) {
  1086. accountDO.setTotal(accountDO.getTotal() + creditsDetailDO1.getIntegrate());
  1087. } else if (creditsDetailDO.getTradeDirection() == -1) {
  1088. accountDO.setTotal(accountDO.getTotal() - creditsDetailDO1.getIntegrate());
  1089. }
  1090. AccountDO accountDO1 = accountDao.save(accountDO);
  1091. List<CreditsDetailDO> creditsDetailDOS = new ArrayList<>();
  1092. for (CreditsDetailDO creditsDetailDO2 : creditsDetailDOList) {
  1093. creditsDetailDO2.setTotal(accountDO1.getTotal());
  1094. creditsDetailDO2.setFlag("1");
  1095. creditsDetailDOS.add(creditsDetailDO2);
  1096. }
  1097. envelop.setDetailModelList(creditsDetailDOS);
  1098. }else {
  1099. for (CreditsDetailDO creditsDetailDO1 : creditsDetailDOS1){
  1100. creditsDetailDO1.setFlag("2");
  1101. }
  1102. envelop.setDetailModelList(creditsDetailDOS1);
  1103. }
  1104. return envelop;
  1105. }
  1106. }else{
  1107. CreditsDetailDO creditsDetailDO1 = new CreditsDetailDO();
  1108. creditsDetailDO1.setFlag("0");
  1109. creditsDetailDOList.add(creditsDetailDO1);
  1110. envelop.setDetailModelList(creditsDetailDOList);
  1111. return envelop;
  1112. }
  1113. }
  1114. } catch (Exception e) {
  1115. e.printStackTrace();
  1116. MixEnvelop<CreditsDetailDO, CreditsDetailDO> envelop = new MixEnvelop<>();
  1117. return envelop;
  1118. }
  1119. }
  1120. public String getWeekOfDate(Date dt) {
  1121. String[] weekDays = {"星期日", "星期一", "星期二", "星期三", "星期四", "星期五", "星期六"};
  1122. Calendar cal = Calendar.getInstance();
  1123. cal.setTime(dt);
  1124. int w = cal.get(Calendar.DAY_OF_WEEK) - 1;
  1125. if (w < 0)
  1126. w = 0;
  1127. return weekDays[w];
  1128. }
  1129. /**
  1130. * 健康问答添加积分
  1131. *
  1132. * @param creditsDetailDO
  1133. * @return
  1134. * @throws Exception
  1135. */
  1136. public MixEnvelop<CreditsDetailDO,CreditsDetailDO> patientGetInteger(CreditsDetailDO creditsDetailDO) throws Exception {
  1137. MixEnvelop<CreditsDetailDO,CreditsDetailDO> envelop = new MixEnvelop<>();
  1138. TaskDO taskDO = taskDao.selectById(creditsDetailDO.getTransactionId());
  1139. ActivityRuleDO ruleDO = activityRuleDao.selectByActivityId(taskDO.getTransactionId());
  1140. JSONObject object = JSONObject.parseObject(ruleDO.getValue1());
  1141. Integer type = object.getInteger("type");
  1142. AccountDO accountDO = accountDao.selectByPatientId(creditsDetailDO.getPatientId());
  1143. creditsDetailDO.setUpdateTime(new Date());
  1144. creditsDetailDO.setCreateTime(new Date());
  1145. creditsDetailDO.setStatus(1);
  1146. if (type == 2){
  1147. creditsDetailDO.setCoupon(creditsDetailDO.getCoupon());
  1148. creditsDetailDO.setIntegrate(null);
  1149. }else if (type==1){
  1150. creditsDetailDO.setIntegrate(creditsDetailDO.getCoupon());
  1151. creditsDetailDO.setCoupon(null);
  1152. }
  1153. creditsDetailDO.setSaasId("dev");
  1154. creditsDetailDO.setTradeType("ACTIVITY_TASK");
  1155. creditsDetailDO.setTradeDirection(1);
  1156. creditsDetailDO.setAccountId(accountDO.getId());
  1157. CreditsDetailDO creditsDetailDO1 = credittsLogDetailDao.save(creditsDetailDO);
  1158. if (creditsDetailDO1 == null){
  1159. throw new Exception("积分添加失败!");
  1160. }
  1161. TaskPatientDetailDO patientDetailDO = taskPatientDetailDao.selectByTaskIdAndPatientId(creditsDetailDO.getTransactionId(),creditsDetailDO.getPatientId());
  1162. patientDetailDO.setUpdateTime(new Date());
  1163. patientDetailDO.setCreateTime(new Date());
  1164. if (type == 2){
  1165. patientDetailDO.setCouponTotal(patientDetailDO.getCouponTotal()+creditsDetailDO.getCoupon());
  1166. }else if (type==1||type==3){
  1167. patientDetailDO.setTotal(patientDetailDO.getTotal()+creditsDetailDO.getIntegrate());
  1168. }
  1169. patientDetailDO.setStatus(1);
  1170. TaskPatientDetailDO taskPatientDetailDO = taskPatientDetailDao.save(patientDetailDO);
  1171. if (taskPatientDetailDO == null){
  1172. throw new Exception("修改活动状态和积分失败!");
  1173. }
  1174. if (type == 2){
  1175. accountDO.setCouponTotal(accountDO.getCouponTotal()+creditsDetailDO.getCoupon());
  1176. }else if (type==1||type==3){
  1177. accountDO.setTotal(accountDO.getTotal()+creditsDetailDO.getIntegrate());
  1178. }
  1179. accountDO.setUpdateTime(new Date());
  1180. AccountDO accountDO1 = accountDao.save(accountDO);
  1181. if (accountDO1 == null){
  1182. throw new Exception("修改银行账户积分失败!");
  1183. }
  1184. envelop.setObj(creditsDetailDO);
  1185. return envelop;
  1186. }
  1187. /**
  1188. * 健康问答--获取当日积分
  1189. *
  1190. * @param patient
  1191. * @param transactionId
  1192. * @return
  1193. */
  1194. public MixEnvelop<CreditsDetailDO,CreditsDetailDO> selectByDate(String patient,String transactionId){
  1195. MixEnvelop<CreditsDetailDO,CreditsDetailDO> envelop = new MixEnvelop<>();
  1196. String sql ="select * from wlyy_health_bank_credits_detail where patient_id = '"+patient+"' and " +
  1197. "transaction_id = '"+transactionId+"' and create_time >='"+ DateUtils.getDayBegin()+"' and " +
  1198. "create_time <= '"+DateUtils.getDayEnd()+"'";
  1199. List<CreditsDetailDO> creditsDetailDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper<>(CreditsDetailDO.class));
  1200. CreditsDetailDO creditsDetailDO = new CreditsDetailDO();
  1201. if (creditsDetailDOS != null && creditsDetailDOS.size()!=0){
  1202. creditsDetailDO = creditsDetailDOS.get(0);
  1203. }
  1204. TaskDO taskDO = taskDao.selectById(transactionId);
  1205. ActivityRuleDO ruleDO = activityRuleDao.selectByActivityId(taskDO.getTransactionId());
  1206. //活动总积分排名
  1207. String rankingSql1 = "SELECT count(1)+1 AS total FROM (SELECT " +
  1208. " SUM(total) AS sum , " +
  1209. " patient_id, " +
  1210. " activity_id " +
  1211. "FROM " +
  1212. " wlyy_health_bank_task_patient_detail btpd WHERE btpd.patient_id !='"+patient+"' " +
  1213. " AND btpd.activity_id = '"+taskDO.getTransactionId()+"' " +
  1214. "GROUP BY btpd.patient_id )btpd1 " +
  1215. "WHERE " +
  1216. " btpd1.sum >= (SELECT SUM(s.total) as total " +
  1217. "FROM wlyy_health_bank_task_patient_detail s WHERE s.patient_id ='"+patient+"' AND s.activity_id='"+taskDO.getTransactionId()+"')" ;
  1218. List<Map<String,Object>> rstotal1 = jdbcTemplate.queryForList(rankingSql1);
  1219. Long count = 0L;
  1220. if(rstotal1!=null&&rstotal1.size()>0){
  1221. count = (Long) rstotal1.get(0).get("total");
  1222. }
  1223. //总活动劵的排名
  1224. String rankingSql2 = "SELECT count(1)+1 AS total FROM (SELECT " +
  1225. " SUM(coupon_total) AS sum , " +
  1226. " patient_id, " +
  1227. " activity_id " +
  1228. "FROM " +
  1229. " wlyy_health_bank_task_patient_detail btpd WHERE btpd.patient_id !='"+patient+"' " +
  1230. " AND btpd.activity_id = '"+taskDO.getTransactionId()+"' "+
  1231. "GROUP BY btpd.patient_id )btpd1 " +
  1232. "WHERE " +
  1233. " btpd1.sum >= (SELECT SUM(s.coupon_total) as couponTotal " +
  1234. "FROM wlyy_health_bank_task_patient_detail s WHERE s.patient_id ='"+patient+"' AND s.activity_id='"+taskDO.getTransactionId()+"')" ;
  1235. List<Map<String,Object>> rstotal2 = jdbcTemplate.queryForList(rankingSql2);
  1236. Long count2 = 0L;
  1237. if(rstotal2!=null&&rstotal2.size()>0){
  1238. count2 = (Long) rstotal2.get(0).get("total");
  1239. }
  1240. JSONObject object = JSONObject.parseObject(ruleDO.getValue1());
  1241. Integer type = object.getInteger("type");
  1242. if (type == 2){
  1243. creditsDetailDO.setActivityRanking(count2);
  1244. creditsDetailDO.setMark(1);
  1245. }else if (type==1||type==3){
  1246. creditsDetailDO.setActivityRanking(count);
  1247. creditsDetailDO.setMark(2);
  1248. }
  1249. envelop.setObj(creditsDetailDO);
  1250. return envelop;
  1251. }
  1252. /**
  1253. * 分享获取积分
  1254. *
  1255. * @param creditsDetailDO
  1256. * @return
  1257. */
  1258. public MixEnvelop<CreditsDetailDO, CreditsDetailDO> shareIntegrate(CreditsDetailDO creditsDetailDO) {
  1259. try {
  1260. synchronized (creditsDetailDO.getPatientId()) {
  1261. String sqlAccount = "select * from wlyy_health_bank_account ba where ba.patient_id = '" + creditsDetailDO.getPatientId() + "'";
  1262. List<AccountDO> accountDOList = jdbcTemplate.query(sqlAccount, new BeanPropertyRowMapper(AccountDO.class));
  1263. if (accountDOList != null && accountDOList.size() != 0) {
  1264. creditsDetailDO.setAccountId(accountDOList.get(0).getId());
  1265. }
  1266. String creditsSql = "select * from wlyy_health_bank_credits_detail where patient_id = '" + creditsDetailDO.getPatientId() + "' and description = '分享'";
  1267. List<CreditsDetailDO> creditsDetailDOS1 = jdbcTemplate.query(creditsSql, new BeanPropertyRowMapper(CreditsDetailDO.class));
  1268. List<CreditsDetailDO> creditsDetailDOList = new ArrayList<>();
  1269. MixEnvelop<CreditsDetailDO, CreditsDetailDO> envelop = new MixEnvelop<>();
  1270. if (creditsDetailDOS1 == null || creditsDetailDOS1.size() == 0) {
  1271. creditsDetailDO.setTradeType("ACTIVITY_TASK");
  1272. creditsDetailDO.setDescription("分享");
  1273. creditsDetailDO.setSaasId("dev");
  1274. creditsDetailDO.setStatus(1);
  1275. creditsDetailDO.setTransactionId(creditsDetailDO.getTransactionId());
  1276. creditsDetailDO.setCreateTime(new Date());
  1277. creditsDetailDO.setUpdateTime(new Date());
  1278. creditsDetailDO.setTradeDirection(1);
  1279. CreditsDetailDO creditsDetailDO1 = credittsLogDetailDao.save(creditsDetailDO);
  1280. creditsDetailDO1.setFlag("1");
  1281. creditsDetailDOList.add(creditsDetailDO1);
  1282. TaskPatientDetailDO taskPatientDetailDO = new TaskPatientDetailDO();
  1283. taskPatientDetailDO.setPatientId(creditsDetailDO1.getPatientId());
  1284. taskPatientDetailDO.setTaskId(creditsDetailDO1.getTransactionId());
  1285. String taskSql1 = ISqlUtils.getAllSql(taskPatientDetailDO);
  1286. List<TaskPatientDetailDO> taskPatientDetailDOS1 = jdbcTemplate.query(taskSql1, new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  1287. TaskPatientDetailDO taskPatientDetailDO1 = taskPatientDetailDOS1.get(0);
  1288. if (creditsDetailDO1.getTradeDirection() == 1) {
  1289. taskPatientDetailDO1.setTotal(taskPatientDetailDO1.getTotal() + creditsDetailDO1.getIntegrate());
  1290. } else if (creditsDetailDO.getTradeDirection() == -1) {
  1291. taskPatientDetailDO1.setTotal(taskPatientDetailDO1.getTotal() - creditsDetailDO1.getIntegrate());
  1292. }
  1293. taskPatientDetailDao.save(taskPatientDetailDO1);
  1294. AccountDO accountDO = accountDao.findOne(creditsDetailDO1.getAccountId());
  1295. if (creditsDetailDO1.getTradeDirection() == 1) {
  1296. accountDO.setTotal(accountDO.getTotal() + creditsDetailDO1.getIntegrate());
  1297. } else if (creditsDetailDO.getTradeDirection() == -1) {
  1298. accountDO.setTotal(accountDO.getTotal() - creditsDetailDO1.getIntegrate());
  1299. }
  1300. accountDao.save(accountDO);
  1301. envelop.setDetailModelList(creditsDetailDOList);
  1302. }else {
  1303. for (CreditsDetailDO creditsDetailDO1:creditsDetailDOS1){
  1304. creditsDetailDO1.setFlag("2");
  1305. creditsDetailDOList.add(creditsDetailDO1);
  1306. }
  1307. envelop.setDetailModelList(creditsDetailDOList);
  1308. }
  1309. return envelop;
  1310. }
  1311. } catch (Exception e) {
  1312. e.printStackTrace();
  1313. MixEnvelop<CreditsDetailDO, CreditsDetailDO> envelop = new MixEnvelop<>();
  1314. return envelop;
  1315. }
  1316. }
  1317. public List<CreditsDetailDO> share(CreditsDetailDO creditsDetailDO) throws Exception {
  1318. synchronized (creditsDetailDO.getPatientId()) {
  1319. String activityId= creditsDetailDO.getActivityId();
  1320. ActivityRuleDO activityRuleDO = activityRuleDao.selectByActivityId(activityId);
  1321. String sql = "select * from wlyy_health_bank_credits_detail where patient_id ='"+creditsDetailDO.getPatientId()+"' " +
  1322. "and description ='分享' and status =1 AND transaction_id = '"+creditsDetailDO.getTransactionId()+"'";
  1323. List<CreditsDetailDO> creditsDetailDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper<>(CreditsDetailDO.class));
  1324. List<CreditsDetailDO> creditsDetailDOList = new ArrayList<>();
  1325. if (activityRuleDO != null){
  1326. JSONObject jsonObject = JSONObject.parseObject(activityRuleDO.getValue1());
  1327. Boolean isShare = jsonObject.getBoolean("isshare");
  1328. if (isShare){
  1329. JSONObject object = jsonObject.getJSONObject("shareData");
  1330. String sqlAccount = "select * from wlyy_health_bank_account ba where ba.patient_id = '" + creditsDetailDO.getPatientId() + "'";
  1331. List<AccountDO> accountDOList = jdbcTemplate.query(sqlAccount, new BeanPropertyRowMapper(AccountDO.class));
  1332. CreditsDetailDO creditsDetailDO1 = new CreditsDetailDO();
  1333. if (accountDOList != null && accountDOList.size() != 0) {
  1334. creditsDetailDO1.setAccountId(accountDOList.get(0).getId());
  1335. }
  1336. if (creditsDetailDOS!=null&&creditsDetailDOS.size()>=object.getInteger("frequency")){
  1337. throw new Exception("分享超过"+creditsDetailDOS.size()+"次");
  1338. }else {
  1339. creditsDetailDO1.setHospitalName(creditsDetailDO.getHospitalName());
  1340. creditsDetailDO1.setHospital(creditsDetailDO.getHospital());
  1341. creditsDetailDO1.setPatientId(creditsDetailDO.getPatientId());
  1342. creditsDetailDO1.setTradeType("ACTIVITY_TASK");
  1343. creditsDetailDO1.setDescription("分享");
  1344. creditsDetailDO1.setSaasId("dev");
  1345. creditsDetailDO1.setStatus(1);
  1346. creditsDetailDO1.setCoupon(0);
  1347. creditsDetailDO1.setTransactionId(creditsDetailDO.getTransactionId());
  1348. creditsDetailDO1.setCreateTime(new Date());
  1349. creditsDetailDO1.setUpdateTime(new Date());
  1350. creditsDetailDO1.setTradeDirection(1);
  1351. creditsDetailDO1.setIntegrate(object.getInteger("integrate"));
  1352. CreditsDetailDO creditsDetailDO2 = credittsLogDetailDao.save(creditsDetailDO1);
  1353. creditsDetailDOList.add(creditsDetailDO2);
  1354. TaskPatientDetailDO taskPatientDetailDO = new TaskPatientDetailDO();
  1355. taskPatientDetailDO.setPatientId(creditsDetailDO1.getPatientId());
  1356. taskPatientDetailDO.setTaskId(creditsDetailDO1.getTransactionId());
  1357. String taskSql1 = ISqlUtils.getAllSql(taskPatientDetailDO);
  1358. List<TaskPatientDetailDO> taskPatientDetailDOS1 = jdbcTemplate.query(taskSql1, new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  1359. TaskPatientDetailDO taskPatientDetailDO1 = taskPatientDetailDOS1.get(0);
  1360. if (creditsDetailDO1.getTradeDirection() == 1) {
  1361. taskPatientDetailDO1.setTotal(taskPatientDetailDO1.getTotal() + creditsDetailDO2.getIntegrate());
  1362. } else if (creditsDetailDO1.getTradeDirection() == -1) {
  1363. taskPatientDetailDO1.setTotal(taskPatientDetailDO1.getTotal() - creditsDetailDO2.getIntegrate());
  1364. }
  1365. taskPatientDetailDao.save(taskPatientDetailDO1);
  1366. AccountDO accountDO = accountDao.findOne(creditsDetailDO2.getAccountId());
  1367. if (creditsDetailDO1.getTradeDirection() == 1) {
  1368. accountDO.setTotal(accountDO.getTotal() + creditsDetailDO2.getIntegrate());
  1369. } else if (creditsDetailDO1.getTradeDirection() == -1) {
  1370. accountDO.setTotal(accountDO.getTotal() - creditsDetailDO2.getIntegrate());
  1371. }
  1372. accountDao.save(accountDO);
  1373. }
  1374. }
  1375. }
  1376. return creditsDetailDOList;
  1377. }
  1378. }
  1379. /**
  1380. * 商城积分支付
  1381. * @param patient
  1382. * @param total
  1383. * @param hospital
  1384. * @param hospitalName
  1385. * @param array
  1386. * @return
  1387. * @throws Exception
  1388. */
  1389. public MixEnvelop<CreditsDetailDO,CreditsDetailDO> payIntegrate(String patient,Double total,String hospital,String hospitalName,JSONArray array) throws Exception {
  1390. MixEnvelop<CreditsDetailDO,CreditsDetailDO> envelop = new MixEnvelop<>();
  1391. AccountDO accountDO = accountDao.selectByPatientId(patient);
  1392. Integer total1 = total.intValue();
  1393. if (accountDO == null){
  1394. envelop.setMessage("银行账户不存在!");
  1395. throw new Exception("银行账户不存在!");
  1396. }else {
  1397. if (total1>accountDO.getTotal()){
  1398. envelop.setMessage("积分余额不足!");
  1399. throw new Exception("积分余额不足!");
  1400. }else{
  1401. for (int i=0;i<array.size();i++){
  1402. JSONObject object = array.getJSONObject(i);
  1403. CreditsDetailDO creditsDetailDO = new CreditsDetailDO();
  1404. creditsDetailDO.setPatientId(patient);
  1405. creditsDetailDO.setAccountId(accountDO.getId());
  1406. creditsDetailDO.setHospital(hospital);
  1407. creditsDetailDO.setTradeType("SHOPPING_PAY");
  1408. creditsDetailDO.setTradeDirection(-1);
  1409. creditsDetailDO.setTransactionId(object.getString("orderId"));
  1410. creditsDetailDO.setIntegrate(object.getDouble("integrate").intValue());
  1411. creditsDetailDO.setCreateTime(new Date());
  1412. creditsDetailDO.setUpdateTime(new Date());
  1413. creditsDetailDO.setHospitalName(hospitalName);
  1414. creditsDetailDO.setSaasId("dev");
  1415. creditsDetailDO.setId(getCode());
  1416. creditsDetailDO.setCoupon(0);
  1417. creditsDetailDO.setStatus(1);
  1418. credittsLogDetailDao.save(creditsDetailDO);
  1419. }
  1420. accountDO.setTotal(accountDO.getTotal()-total1);
  1421. accountDao.save(accountDO);
  1422. }
  1423. }
  1424. return envelop;
  1425. }
  1426. public MixEnvelop<CreditsDetailDO,CreditsDetailDO> refundIntegrate(JSONArray array) throws Exception {
  1427. MixEnvelop<CreditsDetailDO, CreditsDetailDO> envelop = new MixEnvelop<>();
  1428. for (int i=0;i<array.size();i++){
  1429. JSONObject object = array.getJSONObject(i);
  1430. CreditsDetailDO creditsDetailDO1 = credittsLogDetailDao.selectByTransactionId(object.getString("orderId"),"SHOPPING_PAY");
  1431. CreditsDetailDO creditsDetailDO = new CreditsDetailDO();
  1432. creditsDetailDO.setPatientId(creditsDetailDO1.getPatientId());
  1433. creditsDetailDO.setAccountId(creditsDetailDO1.getAccountId());
  1434. creditsDetailDO.setHospital(creditsDetailDO1.getHospital());
  1435. creditsDetailDO.setTradeType("REFUND");
  1436. creditsDetailDO.setTradeDirection(1);
  1437. creditsDetailDO.setTransactionId(object.getString("orderId"));
  1438. creditsDetailDO.setIntegrate(object.getDouble("integrate").intValue());
  1439. creditsDetailDO.setCreateTime(new Date());
  1440. creditsDetailDO.setUpdateTime(new Date());
  1441. creditsDetailDO.setHospitalName(creditsDetailDO1.getHospitalName());
  1442. creditsDetailDO.setSaasId("dev");
  1443. creditsDetailDO.setId(getCode());
  1444. creditsDetailDO.setCoupon(0);
  1445. creditsDetailDO.setStatus(1);
  1446. credittsLogDetailDao.save(creditsDetailDO);
  1447. AccountDO accountDO = accountDao.selectByPatientId(creditsDetailDO1.getPatientId());
  1448. accountDO.setTotal(accountDO.getTotal()+object.getDouble("integrate").intValue());
  1449. accountDao.save(accountDO);
  1450. }
  1451. return envelop;
  1452. }
  1453. /**
  1454. *
  1455. * @param creditsDetailDO
  1456. * @param flag 1连续2间断
  1457. * @return
  1458. */
  1459. public MixEnvelop<CreditsDetailDO, CreditsDetailDO> weekRewardAndIntegrate(CreditsDetailDO creditsDetailDO,Integer flag) {
  1460. synchronized (creditsDetailDO.getPatientId()) {
  1461. MixEnvelop<CreditsDetailDO, CreditsDetailDO> envelop = new MixEnvelop<>();
  1462. String sqlAccount = "select * from wlyy_health_bank_account ba where ba.patient_id = '" + creditsDetailDO.getPatientId() + "'";
  1463. List<AccountDO> accountDOList = jdbcTemplate.query(sqlAccount, new BeanPropertyRowMapper(AccountDO.class));
  1464. if (accountDOList != null && accountDOList.size() != 0) {
  1465. creditsDetailDO.setAccountId(accountDOList.get(0).getId());
  1466. }
  1467. if (flag == 1) {
  1468. String creditsSql = "select * from wlyy_health_bank_credits_detail where patient_id = '" + creditsDetailDO.getPatientId() + "' and " +
  1469. "update_time >= '" + creditsDetailDO.getMonday() + "' AND update_time<='" + creditsDetailDO.getSunday() + "' and description = '周奖励-连续' AND transaction_id = '"+creditsDetailDO.getTransactionId()+"'";
  1470. List<CreditsDetailDO> creditsDetailDOS1 = jdbcTemplate.query(creditsSql, new BeanPropertyRowMapper(CreditsDetailDO.class));
  1471. List<CreditsDetailDO> creditsDetailDOList = new ArrayList<>();
  1472. if (creditsDetailDOS1 == null || creditsDetailDOS1.size() == 0) {
  1473. creditsDetailDO.setTradeType("ACTIVITY_TASK");
  1474. creditsDetailDO.setSaasId("dev");
  1475. creditsDetailDO.setStatus(1);
  1476. creditsDetailDO.setTransactionId(creditsDetailDO.getTransactionId());
  1477. creditsDetailDO.setCreateTime(new Date());
  1478. creditsDetailDO.setUpdateTime(DateUtil.strToDateLong(creditsDetailDO.getSunday()));
  1479. creditsDetailDO.setTradeDirection(1);
  1480. creditsDetailDO.setDescription("周奖励-连续");
  1481. creditsDetailDO.setCoupon(0);
  1482. CreditsDetailDO creditsDetailDO1 = credittsLogDetailDao.save(creditsDetailDO);
  1483. creditsDetailDOList.add(creditsDetailDO1);
  1484. TaskPatientDetailDO taskPatientDetailDO = new TaskPatientDetailDO();
  1485. taskPatientDetailDO.setPatientId(creditsDetailDO1.getPatientId());
  1486. taskPatientDetailDO.setTaskId(creditsDetailDO1.getTransactionId());
  1487. String taskSql1 = ISqlUtils.getAllSql(taskPatientDetailDO);
  1488. List<TaskPatientDetailDO> taskPatientDetailDOS1 = jdbcTemplate.query(taskSql1, new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  1489. TaskPatientDetailDO taskPatientDetailDO1 = taskPatientDetailDOS1.get(0);
  1490. if (creditsDetailDO1.getTradeDirection() == 1) {
  1491. taskPatientDetailDO1.setTotal(taskPatientDetailDO1.getTotal() + creditsDetailDO1.getIntegrate());
  1492. } else if (creditsDetailDO1.getTradeDirection() == -1) {
  1493. taskPatientDetailDO1.setTotal(taskPatientDetailDO1.getTotal() - creditsDetailDO1.getIntegrate());
  1494. }
  1495. taskPatientDetailDao.save(taskPatientDetailDO1);
  1496. AccountDO accountDO = accountDao.findOne(creditsDetailDO1.getAccountId());
  1497. if (creditsDetailDO1.getTradeDirection() == 1) {
  1498. accountDO.setTotal(accountDO.getTotal() + creditsDetailDO1.getIntegrate());
  1499. } else if (creditsDetailDO1.getTradeDirection() == -1) {
  1500. accountDO.setTotal(accountDO.getTotal() - creditsDetailDO1.getIntegrate());
  1501. }
  1502. AccountDO accountDO1 = accountDao.save(accountDO);
  1503. List<CreditsDetailDO> creditsDetailDOS = new ArrayList<>();
  1504. for (CreditsDetailDO creditsDetailDO2 : creditsDetailDOList) {
  1505. creditsDetailDO2.setTotal(accountDO1.getTotal());
  1506. creditsDetailDO2.setFlag("1");
  1507. creditsDetailDOS.add(creditsDetailDO2);
  1508. }
  1509. envelop.setDetailModelList(creditsDetailDOS);
  1510. return envelop;
  1511. }else {
  1512. logger.info("居民:"+creditsDetailDO.getPatientId()+"已领取周奖励-连续");
  1513. }
  1514. }else if (flag==2){
  1515. String creditsSql = "select * from wlyy_health_bank_credits_detail where patient_id = '" + creditsDetailDO.getPatientId() + "' and " +
  1516. "update_time >= '" +creditsDetailDO.getMonday()+"' AND update_time<='" +creditsDetailDO.getSunday() + "' and description = '周奖励-间断' AND transaction_id = '"+creditsDetailDO.getTransactionId()+"'";
  1517. List<CreditsDetailDO> creditsDetailDOS1 = jdbcTemplate.query(creditsSql, new BeanPropertyRowMapper(CreditsDetailDO.class));
  1518. List<CreditsDetailDO> creditsDetailDOList = new ArrayList<>();
  1519. if (creditsDetailDOS1 == null || creditsDetailDOS1.size() == 0) {
  1520. creditsDetailDO.setTradeType("ACTIVITY_TASK");
  1521. creditsDetailDO.setSaasId("dev");
  1522. creditsDetailDO.setStatus(1);
  1523. creditsDetailDO.setTransactionId(creditsDetailDO.getTransactionId());
  1524. creditsDetailDO.setCreateTime(new Date());
  1525. creditsDetailDO.setUpdateTime(DateUtil.strToDateLong(creditsDetailDO.getSunday()));
  1526. creditsDetailDO.setTradeDirection(1);
  1527. creditsDetailDO.setDescription("周奖励-间断");
  1528. CreditsDetailDO creditsDetailDO1 = credittsLogDetailDao.save(creditsDetailDO);
  1529. creditsDetailDOList.add(creditsDetailDO1);
  1530. TaskPatientDetailDO taskPatientDetailDO = new TaskPatientDetailDO();
  1531. taskPatientDetailDO.setPatientId(creditsDetailDO1.getPatientId());
  1532. taskPatientDetailDO.setTaskId(creditsDetailDO1.getTransactionId());
  1533. String taskSql1 = ISqlUtils.getAllSql(taskPatientDetailDO);
  1534. List<TaskPatientDetailDO> taskPatientDetailDOS1 = jdbcTemplate.query(taskSql1, new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  1535. TaskPatientDetailDO taskPatientDetailDO1 = taskPatientDetailDOS1.get(0);
  1536. if (creditsDetailDO1.getTradeDirection() == 1) {
  1537. taskPatientDetailDO1.setTotal(taskPatientDetailDO1.getTotal() + creditsDetailDO1.getIntegrate());
  1538. } else if (creditsDetailDO.getTradeDirection() == -1) {
  1539. taskPatientDetailDO1.setTotal(taskPatientDetailDO1.getTotal() - creditsDetailDO1.getIntegrate());
  1540. }
  1541. taskPatientDetailDao.save(taskPatientDetailDO1);
  1542. AccountDO accountDO = accountDao.findOne(creditsDetailDO1.getAccountId());
  1543. if (creditsDetailDO1.getTradeDirection() == 1) {
  1544. accountDO.setTotal(accountDO.getTotal() + creditsDetailDO1.getIntegrate());
  1545. } else if (creditsDetailDO.getTradeDirection() == -1) {
  1546. accountDO.setTotal(accountDO.getTotal() - creditsDetailDO1.getIntegrate());
  1547. }
  1548. AccountDO accountDO1 = accountDao.save(accountDO);
  1549. List<CreditsDetailDO> creditsDetailDOS = new ArrayList<>();
  1550. for (CreditsDetailDO creditsDetailDO2 : creditsDetailDOList) {
  1551. creditsDetailDO2.setTotal(accountDO1.getTotal());
  1552. creditsDetailDO2.setFlag("1");
  1553. creditsDetailDOS.add(creditsDetailDO2);
  1554. }
  1555. envelop.setDetailModelList(creditsDetailDOS);
  1556. return envelop;
  1557. }else {
  1558. logger.info("居民:"+creditsDetailDO.getPatientId()+"已领取周奖励-间断");
  1559. envelop.setMessage("居民:"+creditsDetailDO.getPatientId()+"已领取周奖励-间断");
  1560. }
  1561. }
  1562. return envelop;
  1563. }
  1564. }
  1565. public List<CreditsDetailDO> selectWeekReward(String patient,String taskId,String monday,String sunday){
  1566. String creditsSql = "select * from wlyy_health_bank_credits_detail where patient_id = '" + patient + "' and " +
  1567. "update_time >= '" +monday+"' AND update_time<='" + sunday+ "' and ( description = '周奖励-间断' OR description = '周奖励-连续') AND transaction_id = '"+taskId+"'";
  1568. List<CreditsDetailDO> creditsDetailDOS = jdbcTemplate.query(creditsSql,new BeanPropertyRowMapper<>(CreditsDetailDO.class));
  1569. return creditsDetailDOS;
  1570. }
  1571. }