CreditsDetailService.java 73 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322
  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. /**
  58. * find creditsLogInfo
  59. *
  60. * @return
  61. * @throws ParseException
  62. */
  63. public MixEnvelop<CreditsDetailDO, CreditsDetailDO> findByCondition(CreditsDetailDO creditsDetailDO, Integer page, Integer size) throws ParseException {
  64. String sql = new ISqlUtils().getSql(creditsDetailDO,page,size,"*");
  65. List<CreditsDetailDO> creditsDetailDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper(CreditsDetailDO.class));
  66. for (CreditsDetailDO creditsDetailDO1 : creditsDetailDOS){
  67. if (creditsDetailDO1.getTradeType() != null && creditsDetailDO1.getTradeType().equalsIgnoreCase("ACTIVITY_TASK")){
  68. TaskDO taskDO = taskDao.findOne(creditsDetailDO1.getTransactionId());
  69. creditsDetailDO1.setTaskDO(taskDO);
  70. }
  71. }
  72. String sqlcount = new ISqlUtils().getSql(creditsDetailDO,0,0,"count");
  73. List<Map<String,Object>> rstotal = jdbcTemplate.queryForList(sqlcount);
  74. Long count = 0L;
  75. if(rstotal!=null&&rstotal.size()>0){
  76. count = (Long) rstotal.get(0).get("total");
  77. }
  78. return MixEnvelop.getSuccessListWithPage(HealthBankMapping.api_success, creditsDetailDOS,page,size,count);
  79. }
  80. /**
  81. * 获取账户信息
  82. *
  83. * @param creditsDetailDO
  84. * @return
  85. */
  86. public MixEnvelop<AccountDO, AccountDO> findByTradeDirection(CreditsDetailDO creditsDetailDO){
  87. AccountDO accountDO1 = new AccountDO();
  88. accountDO1.setPatientId(creditsDetailDO.getPatientId());
  89. String sql1 = ISqlUtils.getAllSql(accountDO1);
  90. List<AccountDO> accountDOS = jdbcTemplate.query(sql1,new BeanPropertyRowMapper(AccountDO.class));
  91. if (accountDOS == null || accountDOS.size() == 0){
  92. accountDO1.setTotal(0);
  93. accountDO1.setAccountName(creditsDetailDO.getName());
  94. if(creditsDetailDO.getIdCard().length()>=4){// 判断是否长度大于等于4
  95. String cardNumber=creditsDetailDO.getIdCard().substring(creditsDetailDO.getIdCard().length()- 4,creditsDetailDO.getIdCard().length());//截取两个数字之间的部分
  96. int random = (int)((Math.random()*9+1)*100000);
  97. accountDO1.setCardNumber(cardNumber+Integer.toString(random));
  98. }
  99. accountDO1.setHospital(creditsDetailDO.getHospital());
  100. accountDO1.setPassword("123456");
  101. accountDO1.setHospitalName(creditsDetailDO.getHospitalName());
  102. accountDO1.setStatus(1);
  103. accountDO1.setSaasId("dev");
  104. accountDO1.setCreateTime(new Date());
  105. accountDO1.setUpdateTime(new Date());
  106. accountDao.save(accountDO1);
  107. }
  108. List<AccountDO> accountDOS1 = jdbcTemplate.query(sql1,new BeanPropertyRowMapper(AccountDO.class));
  109. AccountDO accountDO = accountDOS1.get(0);
  110. 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()+"'";
  111. List<Map<String,Object>> rstotal = jdbcTemplate.queryForList(sql);
  112. if (rstotal!= null && rstotal.size()>0){
  113. if (rstotal.get(0).get("total") == null){
  114. accountDO.setUsedTotal(0);
  115. }else {
  116. accountDO.setUsedTotal(Integer.parseInt(rstotal.get(0).get("total").toString()));
  117. }
  118. }
  119. return MixEnvelop.getSuccess(HealthBankMapping.api_success,accountDO);
  120. }
  121. /*
  122. public Envelop<Boolean> exchangeGoods(GoodsDO goodsDO){
  123. CreditsDetailDO creditsLogDetailDO = new CreditsDetailDO();
  124. Envelop<Boolean> envelop = new Envelop<>();
  125. envelop.setObj(true);
  126. return envelop;
  127. }
  128. */
  129. public MixEnvelop<AccountDO, AccountDO> selectByRanking(List<String> patientIds, Integer page, Integer size){
  130. StringBuffer buffer = new StringBuffer();
  131. buffer.append(" ba.patient_id in(");
  132. if (patientIds == null || patientIds.size() == 0){
  133. buffer.append("''");
  134. }else {
  135. for (int i=0;i<patientIds.size();i++){
  136. buffer.append("'"+patientIds.get(i)+"'").append(",");
  137. }
  138. buffer.deleteCharAt(buffer.length()-1);
  139. }
  140. buffer.append(") ");
  141. String sql =
  142. "SELECT ba1.patient_id AS patient_id," +
  143. "ba1.account_name AS account_name," +
  144. "ba1.hospital AS hospital," +
  145. "ba1.total AS total," +
  146. "ba1.create_time AS create_time," +
  147. "ba1.sum AS sum" +
  148. " FROM" +
  149. "( SELECT " +
  150. "ba.patient_id AS patient_id," +
  151. "ba.account_name AS account_name," +
  152. "ba.hospital AS hospital," +
  153. "ba.total AS total," +
  154. "ba.create_time AS create_time," +
  155. " if(ba.total=0,ba.total,(ba.total +COALESCE((cd1.total),0))) AS sum" +
  156. " FROM" +
  157. " wlyy_health_bank_account ba" +
  158. " LEFT JOIN ( " +
  159. "SELECT" +
  160. " SUM(cd.integrate) AS total," +
  161. " cd.patient_id AS patient_id" +
  162. " FROM" +
  163. " wlyy_health_bank_credits_detail cd" +
  164. " WHERE " +
  165. "cd.trade_direction = - 1" +
  166. " GROUP BY " +
  167. " cd.patient_id ) cd1 ON cd1.patient_id = ba.patient_id " +
  168. " WHERE " + buffer +
  169. " ORDER BY" +
  170. " ba.create_time DESC )ba1" +
  171. " ORDER BY " +
  172. " ba1.total DESC"+
  173. " LIMIT "+(page-1)*size+","+size ;
  174. List<AccountDO> accountDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper(AccountDO.class));
  175. String sqlCount = "SELECT count(1) AS total"+
  176. " FROM " +
  177. " wlyy_health_bank_account ba LEFT JOIN " +
  178. " ( " +
  179. " SELECT " +
  180. " SUM(cd.integrate) AS total, " +
  181. " cd.patient_id AS patient_id " +
  182. " FROM " +
  183. " wlyy_health_bank_credits_detail cd " +
  184. " WHERE " +
  185. " cd.trade_direction = - 1 " +
  186. " GROUP BY " +
  187. " cd.patient_id " +
  188. " ) cd1 ON cd1.patient_id = ba.patient_id " +
  189. "WHERE " + buffer +
  190. " ORDER BY " +
  191. " ba.create_time, " +
  192. " (ba.total + COALESCE(cd1.total,0)) DESC ";
  193. List<Map<String,Object>> rstotal = jdbcTemplate.queryForList(sqlCount);
  194. Long count = 0L;
  195. if(rstotal!=null&&rstotal.size()>0){
  196. count = (Long) rstotal.get(0).get("total");
  197. }
  198. return MixEnvelop.getSuccessListWithPage(HealthBankMapping.api_success, accountDOS,page,size,count);
  199. }
  200. /**
  201. * 添加积分
  202. *
  203. * @param creditsDetailDO
  204. * @return
  205. */
  206. public MixEnvelop<CreditsDetailDO, CreditsDetailDO> insert(CreditsDetailDO creditsDetailDO){
  207. try {
  208. synchronized (creditsDetailDO.getPatientId()){
  209. String sqlAccount = "select * from wlyy_health_bank_account ba where ba.patient_id = '"+creditsDetailDO.getPatientId() +"'";
  210. List<AccountDO> accountDOList = jdbcTemplate.query(sqlAccount,new BeanPropertyRowMapper(AccountDO.class));
  211. if (accountDOList != null && accountDOList.size() != 0){
  212. creditsDetailDO.setAccountId(accountDOList.get(0).getId());
  213. }else {
  214. AccountDO accountDO1 = new AccountDO();
  215. accountDO1.setPatientId(creditsDetailDO.getPatientId());
  216. accountDO1.setTotal(0);
  217. accountDO1.setCouponTotal(0L);
  218. accountDO1.setAccountName(creditsDetailDO.getName());
  219. if(creditsDetailDO.getIdCard().length()>=4){// 判断是否长度大于等于4
  220. String cardNumber=creditsDetailDO.getIdCard().substring(creditsDetailDO.getIdCard().length()- 4,creditsDetailDO.getIdCard().length());//截取两个数字之间的部分
  221. int random = (int)((Math.random()*9+1)*100000);
  222. accountDO1.setCardNumber(cardNumber+Integer.toString(random));
  223. }
  224. accountDO1.setHospital(creditsDetailDO.getHospital());
  225. accountDO1.setPassword("123456");
  226. accountDO1.setHospitalName(creditsDetailDO.getHospitalName());
  227. accountDO1.setStatus(1);
  228. accountDO1.setCreateTime(new Date());
  229. accountDO1.setUpdateTime(new Date());
  230. accountDao.save(accountDO1);
  231. List<AccountDO> accountDOS = jdbcTemplate.query(sqlAccount,new BeanPropertyRowMapper(AccountDO.class));
  232. creditsDetailDO.setAccountId(accountDOS.get(0).getId());
  233. }
  234. TaskDO taskDO = new TaskDO();
  235. taskDO.setTaskCode(creditsDetailDO.getFlag());
  236. taskDO.setId(creditsDetailDO.getTransactionId());
  237. /*taskDO.setPatientId(creditsDetailDO.getPatientId());*/
  238. String sql = ISqlUtils.getSql(taskDO,1,1,"*");
  239. List<TaskDO> taskDOList = jdbcTemplate.query(sql,new BeanPropertyRowMapper(TaskDO.class));
  240. creditsDetailDO.setTransactionId(taskDOList.get(0).getId());
  241. String ruleSql = "SELECT * FROM wlyy_health_bank_task_rule WHERE id= '"+taskDOList.get(0).getRuleCode()+"'";
  242. List<TaskRuleDO> taskRuleDOS = jdbcTemplate.query(ruleSql,new BeanPropertyRowMapper(TaskRuleDO.class));
  243. TaskRuleDO taskRuleDO = taskRuleDOS.get(0);
  244. creditsDetailDO.setIntegrate(taskRuleDO.getIntegrate());
  245. creditsDetailDO.setTradeDirection(taskRuleDO.getTradeDirection());
  246. String taskSql = "select * from wlyy_health_bank_task_patient_detail where task_id = '"+taskDOList.get(0).getId()+"' and patient_id = '" + creditsDetailDO.getPatientId() +"'";
  247. List<TaskPatientDetailDO> taskPatientDetailDOS = jdbcTemplate.query(taskSql,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  248. if (taskPatientDetailDOS == null || taskPatientDetailDOS.size() ==0){
  249. TaskPatientDetailDO taskPatientDetailDO = new TaskPatientDetailDO();
  250. taskPatientDetailDO.setTaskId(creditsDetailDO.getTransactionId());
  251. taskPatientDetailDO.setSaasId(creditsDetailDO.getSaasId());
  252. taskPatientDetailDO.setPatientId(creditsDetailDO.getPatientId());
  253. taskPatientDetailDO.setPatientIdcard(creditsDetailDO.getIdCard());
  254. taskPatientDetailDO.setPatientOpenid(creditsDetailDO.getOpenId());
  255. taskPatientDetailDO.setUnionId(creditsDetailDO.getUnionId());
  256. taskPatientDetailDO.setStatus(Integer.parseInt("0"));
  257. taskPatientDetailDO.setCreateTime(new Date());
  258. taskPatientDetailDO.setUpdateTime(new Date());
  259. taskPatientDetailDO.setActivityId(taskDOList.get(0).getTransactionId());
  260. taskPatientDetailDO.setTotal(Long.parseLong("0"));
  261. taskPatientDetailDao.save(taskPatientDetailDO);
  262. }else if (taskPatientDetailDOS != null && taskDOList.get(0).getPeriod() == 0){
  263. String taskSql1 = "select * from wlyy_health_bank_task_patient_detail where task_id = '"+taskDOList.get(0).getId()+
  264. "' and patient_id = '"+creditsDetailDO.getPatientId()+"' and create_time > '" + DateUtils.getDayBegin() +"' and create_time < '"+ DateUtils.getDayEnd() +"'";
  265. List<TaskPatientDetailDO> taskPatientDetailDOS1 = jdbcTemplate.query(taskSql1,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  266. if (taskPatientDetailDOS1 == null || taskPatientDetailDOS1.size() == 0){
  267. TaskPatientDetailDO taskPatientDetailDO = new TaskPatientDetailDO();
  268. taskPatientDetailDO.setTaskId(creditsDetailDO.getTransactionId());
  269. taskPatientDetailDO.setSaasId(creditsDetailDO.getSaasId());
  270. taskPatientDetailDO.setPatientId(creditsDetailDO.getPatientId());
  271. taskPatientDetailDO.setPatientIdcard(creditsDetailDO.getIdCard());
  272. taskPatientDetailDO.setPatientOpenid(creditsDetailDO.getOpenId());
  273. taskPatientDetailDO.setActivityId(taskDOList.get(0).getTransactionId());
  274. taskPatientDetailDO.setStatus(Integer.parseInt("0"));
  275. taskPatientDetailDO.setCreateTime(new Date());
  276. taskPatientDetailDO.setUpdateTime(new Date());
  277. taskPatientDetailDO.setTotal(Long.parseLong("0"));
  278. taskPatientDetailDao.save(taskPatientDetailDO);
  279. }
  280. }
  281. creditsDetailDO.setCreateTime(new Date());
  282. creditsDetailDO.setUpdateTime(new Date());
  283. CreditsDetailDO creditsDetailDO1 =credittsLogDetailDao.save(creditsDetailDO);
  284. creditsDetailDO1.setFlag(creditsDetailDO.getFlag());
  285. List<CreditsDetailDO> creditsDetailDOList = new ArrayList<>();
  286. creditsDetailDOList.add(creditsDetailDO1);
  287. TaskPatientDetailDO taskPatientDetailDO = new TaskPatientDetailDO();
  288. taskPatientDetailDO.setPatientId(creditsDetailDO1.getPatientId());
  289. taskPatientDetailDO.setTaskId(creditsDetailDO1.getTransactionId());
  290. String taskSql1 = ISqlUtils.getAllSql(taskPatientDetailDO);
  291. List<TaskPatientDetailDO> taskPatientDetailDOS1 = jdbcTemplate.query(taskSql1,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  292. TaskPatientDetailDO taskPatientDetailDO1 = taskPatientDetailDOS1.get(0);
  293. if (creditsDetailDO1.getTradeDirection() == 1){
  294. taskPatientDetailDO1.setTotal(taskPatientDetailDO1.getTotal()+creditsDetailDO1.getIntegrate());
  295. }else if (creditsDetailDO.getTradeDirection() == -1){
  296. taskPatientDetailDO1.setTotal(taskPatientDetailDO1.getTotal()-creditsDetailDO1.getIntegrate());
  297. }
  298. taskPatientDetailDao.save(taskPatientDetailDO1);
  299. AccountDO accountDO = accountDao.findOne(creditsDetailDO1.getAccountId());
  300. if (creditsDetailDO1.getTradeDirection() == 1){
  301. accountDO.setTotal(accountDO.getTotal()+creditsDetailDO1.getIntegrate());
  302. }else if (creditsDetailDO.getTradeDirection() == -1){
  303. accountDO.setTotal(accountDO.getTotal()-creditsDetailDO1.getIntegrate());
  304. }
  305. AccountDO accountDO1 = accountDao.save(accountDO);
  306. List<CreditsDetailDO> creditsDetailDOS = new ArrayList<>();
  307. for (CreditsDetailDO creditsDetailDO2:creditsDetailDOList){
  308. creditsDetailDO2.setTotal(accountDO1.getTotal());
  309. creditsDetailDOS.add(creditsDetailDO2);
  310. }
  311. MixEnvelop<CreditsDetailDO, CreditsDetailDO> envelop = new MixEnvelop<>();
  312. envelop.setDetailModelList(creditsDetailDOS);
  313. return envelop;
  314. }
  315. }catch (Exception e){
  316. e.printStackTrace();
  317. MixEnvelop<CreditsDetailDO, CreditsDetailDO> envelop = new MixEnvelop<>();
  318. return envelop;
  319. }
  320. }
  321. /**
  322. * 活动排名
  323. *
  324. * @param activityId 活动id
  325. * @param ids 微信编码
  326. *
  327. * @param page 页码
  328. *
  329. * @param size 分页大小
  330. * @return
  331. */
  332. public MixEnvelop<TaskPatientDetailDO, TaskPatientDetailDO> selectByActivityRanking(String activityId, List<String> ids, Integer page, Integer size){
  333. StringBuffer buffer = new StringBuffer();
  334. buffer.append("(");
  335. if (ids == null || ids.size() == 0){
  336. buffer.append("''");
  337. }else {
  338. for (int i=0;i<ids.size();i++){
  339. buffer.append("'"+ids.get(i)+"'").append(",");
  340. }
  341. buffer.deleteCharAt(buffer.length()-1);
  342. }
  343. buffer.append(") ");
  344. String sql = "SELECT " +
  345. " * " +
  346. "FROM " +
  347. " ( " +
  348. " SELECT " +
  349. " SUM(ptpd.total) AS total, " +
  350. " ptpd.patient_openid AS patient_openid, " +
  351. " ptpd.task_id AS task_id, " +
  352. " ptpd.activity_id AS activity_id, " +
  353. " ptpd.create_time as create_time, " +
  354. " ptpd.patient_id AS patient_id " +
  355. " FROM " +
  356. " wlyy_health_bank_task_patient_detail ptpd " +
  357. " WHERE " +
  358. " activity_id = '" + activityId +
  359. "' GROUP BY " +
  360. " patient_id " +
  361. " ORDER BY ptpd.create_time DESC " +
  362. " )btpd1 " +
  363. " WHERE patient_id IN "+buffer+
  364. " ORDER BY btpd1.total DESC "+" LIMIT " + (page-1)*size+","+size;
  365. List<TaskPatientDetailDO> taskPatientDetailDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  366. for (TaskPatientDetailDO taskPatientDetailDO : taskPatientDetailDOS){
  367. String accountSql = "select * from wlyy_health_bank_account where patient_id = '"+taskPatientDetailDO.getPatientId()+"'";
  368. List<AccountDO> accountDOS = jdbcTemplate.query(accountSql,new BeanPropertyRowMapper(AccountDO.class));
  369. taskPatientDetailDO.setAccountDO(accountDOS.get(0));
  370. }
  371. String sqlCount = "SELECT " +
  372. " count(1) AS total " +
  373. "FROM " +
  374. " ( " +
  375. " SELECT " +
  376. " SUM(ptpd.total) AS total, " +
  377. " ptpd.patient_openid AS patient_openid, " +
  378. " ptpd.task_id AS task_id, " +
  379. " ptpd.activity_id AS activity_id, " +
  380. " ptpd.create_time as create_time, " +
  381. " ptpd.patient_id AS patient_id " +
  382. " FROM " +
  383. " wlyy_health_bank_task_patient_detail ptpd " +
  384. " WHERE " +
  385. " activity_id = '" + activityId+
  386. "' GROUP BY " +
  387. " patient_openid " +
  388. " ORDER BY ptpd.create_time DESC " +
  389. " )btpd1 " +
  390. "WHERE patient_openid IN "+buffer+
  391. " ORDER BY btpd1.total DESC ";
  392. List<Map<String,Object>> rstotal = jdbcTemplate.queryForList(sqlCount);
  393. Long count = 0L;
  394. if(rstotal!=null&&rstotal.size()>0){
  395. count = (Long) rstotal.get(0).get("total");
  396. }
  397. return MixEnvelop.getSuccessListWithPage(HealthBankMapping.api_success, taskPatientDetailDOS,page,size,count);
  398. }
  399. /**
  400. * 根据活动查询积分
  401. *
  402. * @param activityId 活动id
  403. *
  404. * @param patientId 居民id
  405. *
  406. * @param page 页码
  407. *
  408. * @param size 分页大小
  409. * @return
  410. */
  411. public MixEnvelop<CreditsDetailDO, CreditsDetailDO> selectByActivity(String activityId, String patientId, Integer page, Integer size){
  412. String sql="SELECT * " +
  413. "FROM " +
  414. " wlyy_health_bank_credits_detail " +
  415. "WHERE" +
  416. " transaction_id IN ( " +
  417. " SELECT " +
  418. " bt.id " +
  419. " FROM " +
  420. " wlyy_health_bank_task bt " +
  421. " WHERE " +
  422. " transaction_id = '"+activityId +"' " +
  423. " ) " +
  424. " and patient_id = '" +patientId+
  425. "' LIMIT "+(page-1)*size +","+size;
  426. List<CreditsDetailDO> creditsDetailDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper(CreditsDetailDO.class));
  427. for (CreditsDetailDO creditsDetailDO : creditsDetailDOS){
  428. TaskDO taskDO = taskDao.findOne(creditsDetailDO.getTransactionId());
  429. creditsDetailDO.setTaskDO(taskDO);
  430. }
  431. String sqlcount = "SELECT count(1) AS" +
  432. " total FROM " +
  433. " wlyy_health_bank_credits_detail " +
  434. "WHERE" +
  435. " transaction_id IN ( " +
  436. " SELECT " +
  437. " bt.id " +
  438. " FROM " +
  439. " wlyy_health_bank_task bt " +
  440. " WHERE " +
  441. " transaction_id = '"+activityId +"' " +
  442. " ) " +
  443. " and patient_id = '" +patientId+
  444. "'";
  445. List<Map<String,Object>> rstotal = jdbcTemplate.queryForList(sqlcount);
  446. Long count = 0L;
  447. if(rstotal!=null&&rstotal.size()>0){
  448. count = (Long) rstotal.get(0).get("total");
  449. }
  450. return MixEnvelop.getSuccessListWithPage(HealthBankMapping.api_success,creditsDetailDOS,page,size,count);
  451. }
  452. /**
  453. * 根据活动查找全部排行
  454. *
  455. * @param activityId 活动id
  456. * @param page 页码
  457. * @param size 分页大小
  458. * @return
  459. */
  460. public MixEnvelop<TaskPatientDetailDO, TaskPatientDetailDO> selectByActivityRanking1(String activityId, String patientId, Integer page, Integer size){
  461. String sql = "SELECT " +
  462. " * " +
  463. "FROM " +
  464. " ( " +
  465. " SELECT " +
  466. " SUM(ptpd.total) AS total, " +
  467. " ptpd.patient_openid AS patient_openid, " +
  468. " ptpd.task_id AS task_id, " +
  469. " ptpd.activity_id AS activity_id, " +
  470. " ptpd.create_time as create_time, " +
  471. " ptpd.patient_id AS patient_id " +
  472. " FROM " +
  473. " wlyy_health_bank_task_patient_detail ptpd " +
  474. " WHERE " +
  475. " activity_id = '" + activityId +
  476. "' GROUP BY " +
  477. " patient_openid " +
  478. " ORDER BY ptpd.create_time DESC " +
  479. " )btpd1 " +
  480. " ORDER BY btpd1.total DESC "+" LIMIT " + (page-1)*size+","+size;
  481. List<TaskPatientDetailDO> taskPatientDetailDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  482. logger.info(taskPatientDetailDOS.toString()+""+taskPatientDetailDOS.size());
  483. for (int i = 0;taskPatientDetailDOS != null&&taskPatientDetailDOS.size()!=0 && i<taskPatientDetailDOS.size();i++){
  484. TaskPatientDetailDO taskPatientDetailDO = taskPatientDetailDOS.get(i);
  485. String accountSql = "select * from wlyy_health_bank_account where patient_id = '"+taskPatientDetailDO.getPatientId()+"'";
  486. List<AccountDO> accountDOS = jdbcTemplate.query(accountSql,new BeanPropertyRowMapper(AccountDO.class));
  487. if (taskPatientDetailDOS.get(i).getPatientId().equalsIgnoreCase(patientId)){
  488. /*String taskSql = "select count(1)+1 as total from (" +
  489. "select * from (SELECT " +
  490. " SUM(ptpd.total) AS total, " +
  491. " ptpd.patient_openid AS patient_openid, " +
  492. " ptpd.task_id AS task_id, " +
  493. " ptpd.activity_id AS activity_id, " +
  494. " ptpd.create_time as create_time, " +
  495. " ptpd.patient_id AS patient_id " +
  496. " FROM " +
  497. " wlyy_health_bank_task_patient_detail ptpd " +
  498. " WHERE " +
  499. " activity_id = '" + activityId + "')ptpd1 where" +
  500. " ptpd1.patient_id = '"+patientId+"' AND ptpd1.total > "+taskPatientDetailDOS.get(i).getTotal()+") ptpd2";
  501. List<Map<String,Object>> rstotal1 = jdbcTemplate.queryForList(taskSql);
  502. Long count = 0L;
  503. if(rstotal1!=null&&rstotal1.size()>0){
  504. count = (Long) rstotal1.get(0).get("total");
  505. }
  506. accountDOS.get(0).setActivityRanking(count);*/
  507. taskPatientDetailDO.setIsFlag(1);
  508. }else {
  509. taskPatientDetailDO.setIsFlag(0);
  510. }
  511. taskPatientDetailDO.setAccountDO(accountDOS.get(0));
  512. }
  513. String sqlCount = "SELECT " +
  514. " count(1) AS total " +
  515. "FROM " +
  516. " ( " +
  517. " SELECT " +
  518. " SUM(ptpd.total) AS total, " +
  519. " ptpd.patient_openid AS patient_openid, " +
  520. " ptpd.task_id AS task_id, " +
  521. " ptpd.activity_id AS activity_id, " +
  522. " ptpd.create_time as create_time, " +
  523. " ptpd.patient_id AS patient_id " +
  524. " FROM " +
  525. " wlyy_health_bank_task_patient_detail ptpd " +
  526. " WHERE " +
  527. " activity_id = '" + activityId+
  528. "' GROUP BY " +
  529. " patient_openid " +
  530. " ORDER BY ptpd.create_time DESC " +
  531. " )btpd1 " +
  532. " ORDER BY btpd1.total DESC ";
  533. List<Map<String,Object>> rstotal = jdbcTemplate.queryForList(sqlCount);
  534. Long count = 0L;
  535. if(rstotal!=null&&rstotal.size()>0){
  536. count = (Long) rstotal.get(0).get("total");
  537. }
  538. return MixEnvelop.getSuccessListWithPage(HealthBankMapping.api_success, taskPatientDetailDOS,page,size,count);
  539. }
  540. /**
  541. * 医生主动加分
  542. *
  543. * @param array 居民信息集合
  544. *
  545. * @param ruleId 规则id
  546. * @return
  547. */
  548. public MixEnvelop<Boolean, Boolean> doctorAddIntegrate(JSONArray array, String ruleId, String description) throws Exception {
  549. MixEnvelop<Boolean, Boolean> envelop = new MixEnvelop<>();
  550. for (int i=0;i<array.size();i++){
  551. TaskRuleDO taskRuleDO = taskRuleDao.findOne(ruleId);
  552. JSONObject object = array.getJSONObject(i);
  553. String patientId = object.getString("code");
  554. String idCard = object.getString("idcard");
  555. String unionId = object.getString("unionid");
  556. String openId = object.getString("openid");
  557. String hospital = object.getString("hospital");
  558. String hospitalName = object.getString("hospitalName");
  559. String taskSql = "select * from wlyy_health_bank_task bt where type = 'RULE_TASK' AND transaction_id = '"+ruleId +"'";
  560. List<TaskDO> taskDOList = jdbcTemplate.query(taskSql,new BeanPropertyRowMapper(TaskDO.class));
  561. TaskDO taskDO1 = new TaskDO();
  562. if (taskDOList.isEmpty() && taskDOList.size() == 0){
  563. TaskDO taskDO = new TaskDO();
  564. taskDO.setTransactionId(taskRuleDO.getId());
  565. taskDO.setTaskCode("RULE");
  566. taskDO.setStatus(1);
  567. taskDO.setRuleCode(taskRuleDO.getId());
  568. taskDO.setType("RULE_TASK");
  569. taskDO.setCreateTime(new Date());
  570. taskDO.setUpdateTime(new Date());
  571. taskDO.setPeriod(taskRuleDO.getPeriod());
  572. taskDO.setSaasId("dev");
  573. taskDO.setTitle(taskRuleDO.getDescription());
  574. taskDO.setContent(taskRuleDO.getDescription());
  575. taskDO1 = taskDao.save(taskDO);
  576. }else {
  577. taskDO1 = taskDOList.get(0);
  578. }
  579. if (taskRuleDO.getPeriod() == 1){
  580. String sql = "select * from wlyy_health_bank_task_patient_detail where patient_id = '"+patientId+"'AND task_id ='"+taskDO1.getId()+"'";
  581. List<TaskPatientDetailDO> taskPatientDetailDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  582. if (taskPatientDetailDOS != null && taskPatientDetailDOS.size() != 0){
  583. throw new Exception("已奖励过");
  584. }
  585. }else if (taskRuleDO.getPeriod() == 0){
  586. SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
  587. Date date = new Date();
  588. String date1 = dateFormat.format(date);
  589. String begin = DateUtils.getMinMonthDate(date1);
  590. String end = DateUtils.getMaxMonthDate(date1);
  591. 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+"'";
  592. List<TaskPatientDetailDO> taskPatientDetailDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  593. if (taskPatientDetailDOS != null && taskPatientDetailDOS.size() != 0){
  594. throw new Exception("已奖励过");
  595. }
  596. }
  597. String sql1 = "select * from wlyy_health_bank_task_patient_detail where task_id = '"+taskDO1.getId()+"' " +
  598. "AND patient_idcard = '"+idCard+"' AND patient_openid = '"+openId+"' AND union_id = '"+unionId+"'";
  599. List<TaskPatientDetailDO> taskPatientDetailDOS = jdbcTemplate.query(sql1,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  600. TaskPatientDetailDO taskPatientDetailDO1 = new TaskPatientDetailDO();
  601. if (taskPatientDetailDOS.isEmpty() && taskPatientDetailDOS.size() == 0){
  602. TaskPatientDetailDO taskPatientDetailDO = new TaskPatientDetailDO();
  603. taskPatientDetailDO.setStatus(1);
  604. taskPatientDetailDO.setTotal(Long.parseLong("0"));
  605. taskPatientDetailDO.setPatientId(patientId);
  606. taskPatientDetailDO.setPatientOpenid(openId);
  607. taskPatientDetailDO.setPatientIdcard(idCard);
  608. taskPatientDetailDO.setUnionId(unionId);
  609. taskPatientDetailDO.setSaasId("dev");
  610. taskPatientDetailDO.setCreateTime(new Date());
  611. taskPatientDetailDO.setUpdateTime(new Date());
  612. taskPatientDetailDO.setTaskId(taskDO1.getId());
  613. taskPatientDetailDO1 = taskPatientDetailDao.save(taskPatientDetailDO);
  614. }else {
  615. taskPatientDetailDO1 = taskPatientDetailDOS.get(0);
  616. }
  617. String sql = "select * from wlyy_health_bank_account where patient_id = '"+patientId+"'";
  618. List<AccountDO> accountDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper(AccountDO.class));
  619. if (taskRuleDO.getTradeDirection() == -1 && taskRuleDO.getIntegrate() == 0){
  620. String integrateSql = "select * from wlyy_health_bank_credits_detail where patient_id = '"+patientId+"' " +
  621. "AND transaction_id IN (SELECT id FROM wlyy_health_bank_task WHERE task_code IN ('BP_BIND','GLU_BIND','BP_MEASURE','GLU_MEASURE','RULE'))";
  622. List<CreditsDetailDO> creditsDetailDOS = jdbcTemplate.query(integrateSql,new BeanPropertyRowMapper(CreditsDetailDO.class));
  623. for (CreditsDetailDO creditsDetailDO:creditsDetailDOS){
  624. if (creditsDetailDO.getTradeDirection()==1&&creditsDetailDO.getStatus()!=0){
  625. AccountDO accountDO = accountDOS.get(0);
  626. int total = accountDO.getTotal() - creditsDetailDO.getIntegrate();
  627. creditsDetailDO.setStatus(0);
  628. creditsDetailDO.setDescription(description);
  629. credittsLogDetailDao.save(creditsDetailDO);
  630. accountDO.setTotal(total);
  631. accountDao.save(accountDO);
  632. }
  633. }
  634. CreditsDetailDO creditsDetailDO1 = new CreditsDetailDO();
  635. creditsDetailDO1.setStatus(1);
  636. creditsDetailDO1.setSaasId("dev");
  637. creditsDetailDO1.setAccountId(accountDOS.get(0).getId());
  638. creditsDetailDO1.setHospital(hospital);
  639. creditsDetailDO1.setHospitalName(hospitalName);
  640. creditsDetailDO1.setPatientId(patientId);
  641. creditsDetailDO1.setIntegrate(taskRuleDO.getIntegrate());
  642. creditsDetailDO1.setTradeDirection(taskRuleDO.getTradeDirection());
  643. creditsDetailDO1.setDescription(description);
  644. creditsDetailDO1.setCreateTime(new Date());
  645. creditsDetailDO1.setUpdateTime(new Date());
  646. creditsDetailDO1.setTransactionId(taskDO1.getId());
  647. creditsDetailDO1.setTradeType("ACTIVITY_TASK");
  648. credittsLogDetailDao.save(creditsDetailDO1);
  649. }else{
  650. CreditsDetailDO creditsDetailDO = new CreditsDetailDO();
  651. creditsDetailDO.setStatus(1);
  652. creditsDetailDO.setSaasId("dev");
  653. creditsDetailDO.setAccountId(accountDOS.get(0).getId());
  654. creditsDetailDO.setHospital(hospital);
  655. creditsDetailDO.setHospitalName(hospitalName);
  656. creditsDetailDO.setPatientId(patientId);
  657. creditsDetailDO.setIntegrate(taskRuleDO.getIntegrate());
  658. creditsDetailDO.setTradeDirection(taskRuleDO.getTradeDirection());
  659. creditsDetailDO.setDescription(description);
  660. creditsDetailDO.setCreateTime(new Date());
  661. creditsDetailDO.setUpdateTime(new Date());
  662. creditsDetailDO.setTransactionId(taskDO1.getId());
  663. creditsDetailDO.setTradeType("ACTIVITY_TASK");
  664. credittsLogDetailDao.save(creditsDetailDO);
  665. if (taskRuleDO.getTradeDirection() == -1){
  666. String integrateSql = "select * from wlyy_health_bank_credits_detail where patient_id = '"+patientId+"' " +
  667. "AND transaction_id IN (SELECT id FROM wlyy_health_bank_task WHERE task_code IN ('BP_BIND','GLU_BIND','BP_MEASURE','GLU_MEASURE','RULE'))";
  668. List<CreditsDetailDO> creditsDetailDOS = jdbcTemplate.query(integrateSql,new BeanPropertyRowMapper(CreditsDetailDO.class));
  669. for (CreditsDetailDO creditsDetailDO1:creditsDetailDOS){
  670. if (creditsDetailDO1.getTradeDirection()==1&&creditsDetailDO1.getStatus()!=0){
  671. AccountDO accountDO = accountDOS.get(0);
  672. int total = accountDO.getTotal() - creditsDetailDO1.getIntegrate();
  673. creditsDetailDO1.setStatus(0);
  674. creditsDetailDO1.setDescription(description);
  675. credittsLogDetailDao.save(creditsDetailDO1);
  676. accountDO.setTotal(total);
  677. accountDao.save(accountDO);
  678. }
  679. }
  680. }else if (taskRuleDO.getTradeDirection() == 1){
  681. AccountDO accountDO = accountDOS.get(0);
  682. accountDO.setTotal(accountDO.getTotal() + taskRuleDO.getIntegrate());
  683. accountDao.save(accountDO);
  684. }
  685. }
  686. }
  687. envelop.setObj(true);
  688. return envelop;
  689. }
  690. /**
  691. * 固定数据
  692. *
  693. * @param
  694. * @return
  695. *//*
  696. public List<TaskDO> getTasks(String patientId){
  697. List<TaskDO> taskDOList = new ArrayList<>();
  698. TaskDO taskDO = new TaskDO();
  699. *//*taskDO.setPatientId(patientId);*//*
  700. taskDO.setTaskCode("BIND");
  701. taskDO.setPeriod(1);
  702. taskDO.setTaskTitle("首次绑定");
  703. taskDO.setTaskContent("(绑定社区登记发放的设备,可获得各类型设备的首绑奖励。)");
  704. taskDO.setTradeType("activity");
  705. taskDO.setTransactionId("402885e96324a409016324c0a45a0006");
  706. taskDO.setCreateTime(new Date());
  707. taskDO.setUpdateTime(new Date());
  708. taskDOList.add(taskDO);
  709. TaskDO taskDO1 = new TaskDO();
  710. *//*taskDO1.setPatientId(patientId);*//*
  711. taskDO1.setTaskCode("MEASURE");
  712. taskDO1.setPeriod(0);
  713. taskDO1.setTaskTitle("每日测量");
  714. taskDO1.setTaskContent("(使用社区发放的已关联您身份信息的设备,绑定后每天完成测量)");
  715. taskDO1.setTradeType("activity");
  716. taskDO1.setTransactionId("402885e96324a409016324c0a45a0006");
  717. taskDO1.setCreateTime(new Date());
  718. taskDO1.setUpdateTime(new Date());
  719. taskDOList.add(taskDO1);
  720. return taskDOList;
  721. }
  722. */
  723. public MixEnvelop<CreditsDetailDO, CreditsDetailDO> stepAddIntegrate(CreditsDetailDO creditsDetailDO){
  724. try {
  725. synchronized (creditsDetailDO.getPatientId()){
  726. String sqlAccount = "select * from wlyy_health_bank_account ba where ba.patient_id = '"+creditsDetailDO.getPatientId() +"'";
  727. List<AccountDO> accountDOList = jdbcTemplate.query(sqlAccount,new BeanPropertyRowMapper(AccountDO.class));
  728. if (accountDOList != null && accountDOList.size() != 0){
  729. creditsDetailDO.setAccountId(accountDOList.get(0).getId());
  730. }else {
  731. AccountDO accountDO1 = new AccountDO();
  732. accountDO1.setPatientId(creditsDetailDO.getPatientId());
  733. accountDO1.setSaasId("dev");
  734. accountDO1.setTotal(0);
  735. accountDO1.setCouponTotal(0L);
  736. accountDO1.setAccountName(creditsDetailDO.getName());
  737. if(creditsDetailDO.getIdCard().length()>=4){// 判断是否长度大于等于4
  738. String cardNumber=creditsDetailDO.getIdCard().substring(creditsDetailDO.getIdCard().length()- 4,creditsDetailDO.getIdCard().length());//截取两个数字之间的部分
  739. int random = (int)((Math.random()*9+1)*100000);
  740. accountDO1.setCardNumber(cardNumber+Integer.toString(random));
  741. }
  742. accountDO1.setHospital(creditsDetailDO.getHospital());
  743. accountDO1.setPassword("123456");
  744. accountDO1.setHospitalName(creditsDetailDO.getHospitalName());
  745. accountDO1.setStatus(1);
  746. accountDO1.setCreateTime(new Date());
  747. accountDO1.setUpdateTime(new Date());
  748. accountDao.save(accountDO1);
  749. List<AccountDO> accountDOS = jdbcTemplate.query(sqlAccount,new BeanPropertyRowMapper(AccountDO.class));
  750. creditsDetailDO.setAccountId(accountDOS.get(0).getId());
  751. }
  752. TaskDO taskDO = taskDao.findOne(creditsDetailDO.getTransactionId());
  753. String sql1 = "select * from wlyy_health_bank_task_patient_detail where "+
  754. " patient_idcard = '"+creditsDetailDO.getIdCard()+"' AND union_id = '"+creditsDetailDO.getUnionId()+"' AND task_id = '"+creditsDetailDO.getTransactionId()+"'";
  755. List<TaskPatientDetailDO> taskPatientDetailDOList = jdbcTemplate.query(sql1,new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  756. if(taskPatientDetailDOList == null || taskPatientDetailDOList.size()==0){
  757. throw new Exception("该居民参与活动查不到!");
  758. }
  759. TaskPatientDetailDO taskPatientDetailDO = taskPatientDetailDOList.get(0);
  760. String sql = "select * from wlyy_health_bank_credits_detail where patient_id = '"+creditsDetailDO.getPatientId()+"' AND " +
  761. "transaction_id = '"+creditsDetailDO.getTransactionId()+"' AND create_time > '"+DateUtils.getDayBegin() +"' AND" +
  762. " create_time < '"+DateUtils.getDayEnd()+"'AND ISNULL(description)";
  763. List<CreditsDetailDO> creditsDetailDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper<>(CreditsDetailDO.class));
  764. ActivityRuleDO activityRuleDO = activityRuleDao.selectByActivityId(taskPatientDetailDO.getActivityId());
  765. if (activityRuleDO.getValue1() != null){
  766. JSONObject object = JSONObject.parseObject(activityRuleDO.getValue1());
  767. //获取步数
  768. JSONArray array = object.getJSONArray("healthStep");
  769. int j = array.size();
  770. int z= 0;
  771. for (int i = 0;i<=array.size();i++){
  772. JSONObject jsonObject = array.getJSONObject(i);
  773. Long step = jsonObject.getLong("step");
  774. int integrate = jsonObject.getInteger("integrate");
  775. if (creditsDetailDOS != null && creditsDetailDOS.size() != 0){
  776. CreditsDetailDO creditsDetailDO1 = creditsDetailDOS.get(0);
  777. TaskRuleDO taskRuleDO = taskRuleDao.findOne(taskDO.getRuleCode());
  778. if (creditsDetailDO.getStepNumber()>0 && creditsDetailDO.getStepNumber()<=step){
  779. int integrate1=creditsDetailDO1.getIntegrate();
  780. creditsDetailDO1.setIntegrate(creditsDetailDO.getIntegrate());
  781. creditsDetailDO1.setTradeDirection(1);
  782. CreditsDetailDO creditsDetailDO2 = credittsLogDetailDao.save(creditsDetailDO1);
  783. AccountDO accountDO = accountDao.findOne(creditsDetailDO2.getAccountId());
  784. accountDO.setTotal(accountDO.getTotal()-integrate1+creditsDetailDO2.getIntegrate());
  785. AccountDO accountDO1 = accountDao.save(accountDO);
  786. creditsDetailDO2.setTotal(accountDO1.getTotal());
  787. taskPatientDetailDO.setTotal(taskPatientDetailDO.getTotal()-integrate1+creditsDetailDO2.getIntegrate());
  788. taskPatientDetailDao.save(taskPatientDetailDO);
  789. creditsDetailDOS.clear();
  790. creditsDetailDOS.add(creditsDetailDO2);
  791. break;
  792. }
  793. }else {
  794. CreditsDetailDO creditsDetailDO1 = new CreditsDetailDO();
  795. if (creditsDetailDO.getStepNumber()>0 && creditsDetailDO.getStepNumber()<=step){
  796. creditsDetailDO1.setIntegrate(creditsDetailDO.getIntegrate());
  797. creditsDetailDO1.setTradeDirection(1);
  798. creditsDetailDO1.setSaasId("dev");
  799. creditsDetailDO1.setTradeType("ACTIVITY_TASK");
  800. creditsDetailDO1.setPatientId(creditsDetailDO.getPatientId());
  801. creditsDetailDO1.setHospital(creditsDetailDO.getHospital());
  802. creditsDetailDO1.setHospitalName(creditsDetailDO.getHospitalName());
  803. creditsDetailDO1.setAccountId(creditsDetailDO.getAccountId());
  804. creditsDetailDO1.setStatus(1);
  805. creditsDetailDO1.setCreateTime(new Date());
  806. creditsDetailDO1.setUpdateTime(new Date());
  807. creditsDetailDO1.setTransactionId(taskPatientDetailDO.getTaskId());
  808. CreditsDetailDO creditsDetailDO2 = credittsLogDetailDao.save(creditsDetailDO1);
  809. AccountDO accountDO = accountDao.findOne(creditsDetailDO2.getAccountId());
  810. accountDO.setTotal(accountDO.getTotal()+creditsDetailDO2.getIntegrate());
  811. taskPatientDetailDO.setTotal(taskPatientDetailDO.getTotal()+creditsDetailDO2.getIntegrate());
  812. taskPatientDetailDao.save(taskPatientDetailDO);
  813. creditsDetailDO2.setTotal(accountDO.getTotal());
  814. creditsDetailDOS.add(creditsDetailDO2);
  815. break;
  816. }
  817. }
  818. }
  819. }
  820. /* for (int i = 0;i<array.size();i++){
  821. JSONObject jsonObject = array.getJSONObject(i);
  822. if (creditsDetailDOS != null && creditsDetailDOS.size() != 0){
  823. CreditsDetailDO creditsDetailDO1 = creditsDetailDOS.get(0);
  824. TaskRuleDO taskRuleDO = taskRuleDao.findOne(taskDO.getRuleCode());
  825. if (creditsDetailDO.getStepNumber() < step1 && creditsDetailDO.getStepNumber() >0){
  826. creditsDetailDO1.setIntegrate(0);
  827. creditsDetailDO1.setTradeDirection(1);
  828. CreditsDetailDO creditsDetailDO2 = credittsLogDetailDao.save(creditsDetailDO1);
  829. AccountDO accountDO = accountDao.findOne(creditsDetailDO2.getAccountId());
  830. accountDO.setTotal(accountDO.getTotal()+creditsDetailDO2.getIntegrate());
  831. AccountDO accountDO1 = accountDao.save(accountDO);
  832. creditsDetailDO2.setTotal(accountDO1.getTotal());
  833. taskPatientDetailDO.setTotal(taskPatientDetailDO.getTotal()+creditsDetailDO2.getIntegrate());
  834. taskPatientDetailDao.save(taskPatientDetailDO);
  835. creditsDetailDOS.clear();
  836. creditsDetailDOS.add(creditsDetailDO2);
  837. }else if (creditsDetailDO.getStepNumber() >= step1 && creditsDetailDO.getStepNumber() < step2){
  838. creditsDetailDO1.setIntegrate(creditsDetailDO1.getIntegrate()+1);
  839. creditsDetailDO1.setTradeDirection(1);
  840. CreditsDetailDO creditsDetailDO2 = credittsLogDetailDao.save(creditsDetailDO1);
  841. AccountDO accountDO = accountDao.findOne(creditsDetailDO2.getAccountId());
  842. accountDO.setTotal(accountDO.getTotal()+(creditsDetailDO2.getIntegrate()));
  843. AccountDO accountDO1 = accountDao.save(accountDO);
  844. creditsDetailDO2.setTotal(accountDO1.getTotal());
  845. taskPatientDetailDO.setTotal(taskPatientDetailDO.getTotal()+(creditsDetailDO2.getIntegrate()));
  846. taskPatientDetailDao.save(taskPatientDetailDO);
  847. creditsDetailDOS.clear();
  848. creditsDetailDOS.add(creditsDetailDO2);
  849. }else if (creditsDetailDO.getStepNumber() >= step2){
  850. if (creditsDetailDO1.getIntegrate() == 1){
  851. creditsDetailDO1.setIntegrate(2);
  852. creditsDetailDO1.setTradeDirection(1);
  853. CreditsDetailDO creditsDetailDO2 = credittsLogDetailDao.save(creditsDetailDO1);
  854. AccountDO accountDO = accountDao.findOne(creditsDetailDO2.getAccountId());
  855. accountDO.setTotal(accountDO.getTotal()+(creditsDetailDO2.getIntegrate()-1));
  856. AccountDO accountDO1 = accountDao.save(accountDO);
  857. creditsDetailDO2.setTotal(accountDO1.getTotal());
  858. taskPatientDetailDO.setTotal(taskPatientDetailDO.getTotal()+(creditsDetailDO2.getIntegrate()-1));
  859. taskPatientDetailDao.save(taskPatientDetailDO);
  860. creditsDetailDOS.clear();
  861. creditsDetailDOS.add(creditsDetailDO2);
  862. }*//*else if(creditsDetailDO1.getIntegrate() == 3){
  863. creditsDetailDO1.setIntegrate(creditsDetailDO1.getIntegrate()+5);
  864. creditsDetailDO1.setTradeDirection(1);
  865. CreditsDetailDO creditsDetailDO2 = credittsLogDetailDao.save(creditsDetailDO1);
  866. AccountDO accountDO = accountDao.findOne(creditsDetailDO2.getAccountId());
  867. accountDO.setTotal(accountDO.getTotal()+(creditsDetailDO2.getIntegrate()-3));
  868. AccountDO accountDO1 = accountDao.save(accountDO);
  869. creditsDetailDO2.setTotal(accountDO1.getTotal());
  870. taskPatientDetailDO.setTotal(taskPatientDetailDO.getTotal()+(creditsDetailDO2.getIntegrate()-3));
  871. taskPatientDetailDao.save(taskPatientDetailDO);
  872. creditsDetailDOS.clear();
  873. creditsDetailDOS.add(creditsDetailDO2);
  874. }*//*
  875. }
  876. }else{
  877. CreditsDetailDO creditsDetailDO1 = new CreditsDetailDO();
  878. if (creditsDetailDO.getStepNumber() < step1 && creditsDetailDO.getStepNumber() >0){
  879. creditsDetailDO1.setIntegrate(0);
  880. creditsDetailDO1.setTradeDirection(1);
  881. }else if (creditsDetailDO.getStepNumber() >= step1 && creditsDetailDO.getStepNumber() < step2){
  882. creditsDetailDO1.setIntegrate(1);
  883. creditsDetailDO1.setTradeDirection(1);
  884. }else if (creditsDetailDO.getStepNumber() >=step2){
  885. creditsDetailDO1.setIntegrate(2);
  886. creditsDetailDO1.setTradeDirection(1);
  887. }
  888. creditsDetailDO1.setSaasId("dev");
  889. creditsDetailDO1.setTradeType("ACTIVITY_TASK");
  890. creditsDetailDO1.setPatientId(creditsDetailDO.getPatientId());
  891. creditsDetailDO1.setHospital(creditsDetailDO.getHospital());
  892. creditsDetailDO1.setHospitalName(creditsDetailDO.getHospitalName());
  893. creditsDetailDO1.setAccountId(creditsDetailDO.getAccountId());
  894. creditsDetailDO1.setStatus(1);
  895. creditsDetailDO1.setCreateTime(new Date());
  896. creditsDetailDO1.setUpdateTime(new Date());
  897. creditsDetailDO1.setTransactionId(taskPatientDetailDO.getTaskId());
  898. CreditsDetailDO creditsDetailDO2 = credittsLogDetailDao.save(creditsDetailDO1);
  899. AccountDO accountDO = accountDao.findOne(creditsDetailDO2.getAccountId());
  900. accountDO.setTotal(accountDO.getTotal()+creditsDetailDO2.getIntegrate());
  901. taskPatientDetailDO.setTotal(taskPatientDetailDO.getTotal()+creditsDetailDO2.getIntegrate());
  902. taskPatientDetailDao.save(taskPatientDetailDO);
  903. creditsDetailDO2.setTotal(accountDO.getTotal());
  904. creditsDetailDOS.add(creditsDetailDO2);
  905. }*/
  906. /* String step = redisTemplate.opsForValue().get(STEP);
  907. if (StringUtils.isEmpty(step)){
  908. throw new Exception("获取步数失败!");
  909. }
  910. JSONObject object = JSONObject.parseObject(step);
  911. int step1 = object.getInteger("step1");
  912. int step2 = object.getInteger("step2");
  913. */
  914. try{
  915. activeRecordService.insert("dev",creditsDetailDOS.get(0).getTransactionId(),null,null,null,creditsDetailDOS.get(0).getPatientId());
  916. }catch (Exception e){
  917. logger.error("插入活跃出错:"+e.getMessage());
  918. }
  919. MixEnvelop<CreditsDetailDO, CreditsDetailDO> envelop = new MixEnvelop<>();
  920. envelop.setDetailModelList(creditsDetailDOS);
  921. return envelop;
  922. }
  923. }catch (Exception e){
  924. e.printStackTrace();
  925. MixEnvelop<CreditsDetailDO, CreditsDetailDO> envelop = new MixEnvelop<>();
  926. return envelop;
  927. }
  928. }
  929. public MixEnvelop doctorDescreaseIntegrate(String ruleId,String patientId,String doctorId,String hospital,String hospitalName,Integer integrate,String reason) throws Exception {
  930. MixEnvelop envelop = new MixEnvelop<>();
  931. envelop.setObj(true);
  932. TaskDO taskDO = taskDao.selectByTaskRuleId(ruleId);
  933. String sql = "select * from wlyy_health_bank_account where status = 1 and patient_id = '"+patientId+"'";
  934. List<AccountDO> accountDOs = jdbcTemplate.query(sql,new BeanPropertyRowMapper(AccountDO.class));
  935. AccountDO accountDO = accountDOs.get(0);
  936. if (taskDO == null){
  937. TaskRuleDO taskRuleDO = taskRuleDao.findByCode(ruleId);
  938. TaskDO taskDO1 = new TaskDO();
  939. taskDO1.setTitle(taskRuleDO.getName());
  940. taskDO1.setContent(taskRuleDO.getDescription());
  941. taskDO1.setSaasId("dev");
  942. taskDO1.setTaskCode("RULE");
  943. taskDO1.setType("RULE_TASK");
  944. taskDO1.setTransactionId(ruleId);
  945. taskDO1.setCreateTime(new Date());
  946. taskDO1.setUpdateTime(new Date());
  947. taskDO1.setRuleCode(taskRuleDO.getId());
  948. taskDO1.setStatus(1);
  949. taskDO = taskDao.save(taskDO1);
  950. }
  951. TaskPatientDetailDO patientDetailDO = taskPatientDetailDao.selectByTaskIdAndPatientId(taskDO.getId(),patientId);
  952. if (patientDetailDO == null){
  953. TaskPatientDetailDO taskPatientDetailDO = new TaskPatientDetailDO();
  954. taskPatientDetailDO.setSaasId("dev");
  955. taskPatientDetailDO.setTaskId(taskDO.getId());
  956. taskPatientDetailDO.setPatientId(patientId);
  957. taskPatientDetailDO.setDoctorId(doctorId);
  958. taskPatientDetailDO.setPatientIdcard(accountDO.getIdCard());
  959. taskPatientDetailDO.setCreateTime(new Date());
  960. taskPatientDetailDO.setUpdateTime(new Date());
  961. taskPatientDetailDO.setStatus(1);
  962. taskPatientDetailDao.save(taskPatientDetailDO);
  963. }
  964. if (accountDO.getTotal().compareTo(integrate)>=1){
  965. CreditsDetailDO creditsDetailDO = new CreditsDetailDO();
  966. creditsDetailDO.setAccountId(accountDO.getId());
  967. creditsDetailDO.setIdCard(accountDO.getIdCard());
  968. creditsDetailDO.setSaasId("dev");
  969. creditsDetailDO.setTradeType("ACTIVITY_TASK");
  970. creditsDetailDO.setTradeDirection(-1);
  971. creditsDetailDO.setIntegrate(integrate);
  972. creditsDetailDO.setDescription(reason);
  973. creditsDetailDO.setStatus(1);
  974. creditsDetailDO.setHospital(hospital);
  975. creditsDetailDO.setHospitalName(hospitalName);
  976. creditsDetailDO.setCreateTime(new Date());
  977. creditsDetailDO.setUpdateTime(new Date());
  978. credittsLogDetailDao.save(creditsDetailDO);
  979. accountDO.setTotal(accountDO.getTotal()-integrate);
  980. accountDao.save(accountDO);
  981. }else {
  982. envelop.setMessage("积分不足!");
  983. throw new Exception("积分不足!");
  984. }
  985. return envelop;
  986. }
  987. /*public JSONObject getStepNumber(){
  988. String step = redisTemplate.·().get(STEP);
  989. logger.info("redis数据:"+step);
  990. String sql = ""
  991. String step1 = systemDictDao.
  992. logger.info("数据库的数据:"+step1);
  993. if (step != null && step.equalsIgnoreCase(step1)){
  994. JSONObject jsonObject = JSONObject.parseObject(step);
  995. logger.info("数据不一致:"+jsonObject.toString());
  996. return jsonObject;
  997. }else {
  998. JSONObject jsonObject = JSONObject.parseObject(step);
  999. redisTemplate.opsForValue().set(STEP,step1);
  1000. logger.info("数据一致:"+jsonObject.toString());
  1001. return jsonObject;
  1002. }
  1003. }*/
  1004. public MixEnvelop<CreditsDetailDO, CreditsDetailDO> weekReward(CreditsDetailDO creditsDetailDO) {
  1005. try {
  1006. synchronized (creditsDetailDO.getPatientId()) {
  1007. String sqlAccount = "select * from wlyy_health_bank_account ba where ba.patient_id = '" + creditsDetailDO.getPatientId() + "'";
  1008. List<AccountDO> accountDOList = jdbcTemplate.query(sqlAccount, new BeanPropertyRowMapper(AccountDO.class));
  1009. if (accountDOList != null && accountDOList.size() != 0) {
  1010. creditsDetailDO.setAccountId(accountDOList.get(0).getId());
  1011. }
  1012. String creditsSql = "select * from wlyy_health_bank_credits_detail where patient_id = '" + creditsDetailDO.getPatientId() + "' and " +
  1013. "DATE_FORMAT(create_time,'%Y-%m-%d') IN " + creditsDetailDO.getWeekTimes()+" and description = '周奖励'";
  1014. List<CreditsDetailDO> creditsDetailDOS1 = jdbcTemplate.query(creditsSql, new BeanPropertyRowMapper(CreditsDetailDO.class));
  1015. List<CreditsDetailDO> creditsDetailDOList = new ArrayList<>();
  1016. MixEnvelop<CreditsDetailDO, CreditsDetailDO> envelop = new MixEnvelop<>();
  1017. if (getWeekOfDate(new Date()).equalsIgnoreCase("星期五")||getWeekOfDate(new Date()).equalsIgnoreCase("星期六")||getWeekOfDate(new Date()).equalsIgnoreCase("星期日")){
  1018. String sql = "select sum(integrate) as total from wlyy_health_bank_credits_detail where patient_id = '" + creditsDetailDO.getPatientId() + "' and description = '周奖励'";
  1019. List<Map<String,Object>> rstotal = jdbcTemplate.queryForList(sql);
  1020. Long count = 0L;
  1021. if(rstotal!=null&&rstotal.size()>0){
  1022. Object object = rstotal.get(0).get("total");
  1023. if (object != null){
  1024. count = Long.parseLong(object.toString());
  1025. }
  1026. }
  1027. if (count > 12){
  1028. envelop.setMessage("奖励积分已达到12分。不能再奖励了!");
  1029. return envelop;
  1030. }else{
  1031. if (creditsDetailDOS1 == null || creditsDetailDOS1.size() == 0) {
  1032. creditsDetailDO.setTradeType("ACTIVITY_TASK");
  1033. creditsDetailDO.setSaasId("dev");
  1034. creditsDetailDO.setStatus(1);
  1035. creditsDetailDO.setTransactionId(creditsDetailDO.getTransactionId());
  1036. creditsDetailDO.setCreateTime(new Date());
  1037. creditsDetailDO.setUpdateTime(new Date());
  1038. creditsDetailDO.setTradeDirection(1);
  1039. CreditsDetailDO creditsDetailDO1 = credittsLogDetailDao.save(creditsDetailDO);
  1040. creditsDetailDOList.add(creditsDetailDO1);
  1041. TaskPatientDetailDO taskPatientDetailDO = new TaskPatientDetailDO();
  1042. taskPatientDetailDO.setPatientId(creditsDetailDO1.getPatientId());
  1043. taskPatientDetailDO.setTaskId(creditsDetailDO1.getTransactionId());
  1044. String taskSql1 = ISqlUtils.getAllSql(taskPatientDetailDO);
  1045. List<TaskPatientDetailDO> taskPatientDetailDOS1 = jdbcTemplate.query(taskSql1, new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  1046. TaskPatientDetailDO taskPatientDetailDO1 = taskPatientDetailDOS1.get(0);
  1047. if (creditsDetailDO1.getTradeDirection() == 1) {
  1048. taskPatientDetailDO1.setTotal(taskPatientDetailDO1.getTotal() + creditsDetailDO1.getIntegrate());
  1049. } else if (creditsDetailDO.getTradeDirection() == -1) {
  1050. taskPatientDetailDO1.setTotal(taskPatientDetailDO1.getTotal() - creditsDetailDO1.getIntegrate());
  1051. }
  1052. taskPatientDetailDao.save(taskPatientDetailDO1);
  1053. AccountDO accountDO = accountDao.findOne(creditsDetailDO1.getAccountId());
  1054. if (creditsDetailDO1.getTradeDirection() == 1) {
  1055. accountDO.setTotal(accountDO.getTotal() + creditsDetailDO1.getIntegrate());
  1056. } else if (creditsDetailDO.getTradeDirection() == -1) {
  1057. accountDO.setTotal(accountDO.getTotal() - creditsDetailDO1.getIntegrate());
  1058. }
  1059. AccountDO accountDO1 = accountDao.save(accountDO);
  1060. List<CreditsDetailDO> creditsDetailDOS = new ArrayList<>();
  1061. for (CreditsDetailDO creditsDetailDO2 : creditsDetailDOList) {
  1062. creditsDetailDO2.setTotal(accountDO1.getTotal());
  1063. creditsDetailDO2.setFlag("1");
  1064. creditsDetailDOS.add(creditsDetailDO2);
  1065. }
  1066. envelop.setDetailModelList(creditsDetailDOS);
  1067. }else {
  1068. for (CreditsDetailDO creditsDetailDO1 : creditsDetailDOS1){
  1069. creditsDetailDO1.setFlag("2");
  1070. }
  1071. envelop.setDetailModelList(creditsDetailDOS1);
  1072. }
  1073. return envelop;
  1074. }
  1075. }else{
  1076. CreditsDetailDO creditsDetailDO1 = new CreditsDetailDO();
  1077. creditsDetailDO1.setFlag("0");
  1078. creditsDetailDOList.add(creditsDetailDO1);
  1079. envelop.setDetailModelList(creditsDetailDOList);
  1080. return envelop;
  1081. }
  1082. }
  1083. } catch (Exception e) {
  1084. e.printStackTrace();
  1085. MixEnvelop<CreditsDetailDO, CreditsDetailDO> envelop = new MixEnvelop<>();
  1086. return envelop;
  1087. }
  1088. }
  1089. public String getWeekOfDate(Date dt) {
  1090. String[] weekDays = {"星期日", "星期一", "星期二", "星期三", "星期四", "星期五", "星期六"};
  1091. Calendar cal = Calendar.getInstance();
  1092. cal.setTime(dt);
  1093. int w = cal.get(Calendar.DAY_OF_WEEK) - 1;
  1094. if (w < 0)
  1095. w = 0;
  1096. return weekDays[w];
  1097. }
  1098. /**
  1099. * 健康问答添加积分
  1100. *
  1101. * @param creditsDetailDO
  1102. * @return
  1103. * @throws Exception
  1104. */
  1105. public MixEnvelop<CreditsDetailDO,CreditsDetailDO> patientGetInteger(CreditsDetailDO creditsDetailDO) throws Exception {
  1106. MixEnvelop<CreditsDetailDO,CreditsDetailDO> envelop = new MixEnvelop<>();
  1107. TaskDO taskDO = taskDao.selectById(creditsDetailDO.getTransactionId());
  1108. ActivityRuleDO ruleDO = activityRuleDao.selectByActivityId(taskDO.getTransactionId());
  1109. JSONObject object = JSONObject.parseObject(ruleDO.getValue1());
  1110. Integer type = object.getInteger("type");
  1111. AccountDO accountDO = accountDao.selectByPatientId(creditsDetailDO.getPatientId());
  1112. creditsDetailDO.setUpdateTime(new Date());
  1113. creditsDetailDO.setCreateTime(new Date());
  1114. creditsDetailDO.setStatus(1);
  1115. if (type == 2){
  1116. creditsDetailDO.setCoupon(creditsDetailDO.getCoupon());
  1117. creditsDetailDO.setIntegrate(null);
  1118. }else if (type==1){
  1119. creditsDetailDO.setIntegrate(creditsDetailDO.getCoupon());
  1120. creditsDetailDO.setCoupon(null);
  1121. }
  1122. creditsDetailDO.setSaasId("dev");
  1123. creditsDetailDO.setTradeType("ACTIVITY_TASK");
  1124. creditsDetailDO.setTradeDirection(1);
  1125. creditsDetailDO.setAccountId(accountDO.getId());
  1126. CreditsDetailDO creditsDetailDO1 = credittsLogDetailDao.save(creditsDetailDO);
  1127. if (creditsDetailDO1 == null){
  1128. throw new Exception("积分添加失败!");
  1129. }
  1130. TaskPatientDetailDO patientDetailDO = taskPatientDetailDao.selectByTaskIdAndPatientId(creditsDetailDO.getTransactionId(),creditsDetailDO.getPatientId());
  1131. patientDetailDO.setUpdateTime(new Date());
  1132. patientDetailDO.setCreateTime(new Date());
  1133. if (type == 2){
  1134. patientDetailDO.setCouponTotal(patientDetailDO.getCouponTotal()+creditsDetailDO.getCoupon());
  1135. }else if (type==1||type==3){
  1136. patientDetailDO.setTotal(patientDetailDO.getTotal()+creditsDetailDO.getIntegrate());
  1137. }
  1138. patientDetailDO.setStatus(1);
  1139. TaskPatientDetailDO taskPatientDetailDO = taskPatientDetailDao.save(patientDetailDO);
  1140. if (taskPatientDetailDO == null){
  1141. throw new Exception("修改活动状态和积分失败!");
  1142. }
  1143. if (type == 2){
  1144. accountDO.setCouponTotal(accountDO.getCouponTotal()+creditsDetailDO.getCoupon());
  1145. }else if (type==1||type==3){
  1146. accountDO.setTotal(accountDO.getTotal()+creditsDetailDO.getIntegrate());
  1147. }
  1148. accountDO.setUpdateTime(new Date());
  1149. AccountDO accountDO1 = accountDao.save(accountDO);
  1150. if (accountDO1 == null){
  1151. throw new Exception("修改银行账户积分失败!");
  1152. }
  1153. envelop.setObj(creditsDetailDO);
  1154. return envelop;
  1155. }
  1156. /**
  1157. * 健康问答--获取当日积分
  1158. *
  1159. * @param patient
  1160. * @param transactionId
  1161. * @return
  1162. */
  1163. public MixEnvelop<CreditsDetailDO,CreditsDetailDO> selectByDate(String patient,String transactionId){
  1164. MixEnvelop<CreditsDetailDO,CreditsDetailDO> envelop = new MixEnvelop<>();
  1165. String sql ="select * from wlyy_health_bank_credits_detail where patient_id = '"+patient+"' and " +
  1166. "transaction_id = '"+transactionId+"' and create_time >='"+ DateUtils.getDayBegin()+"' and " +
  1167. "create_time <= '"+DateUtils.getDayEnd()+"'";
  1168. List<CreditsDetailDO> creditsDetailDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper<>(CreditsDetailDO.class));
  1169. CreditsDetailDO creditsDetailDO = new CreditsDetailDO();
  1170. if (creditsDetailDOS != null && creditsDetailDOS.size()!=0){
  1171. creditsDetailDO = creditsDetailDOS.get(0);
  1172. }
  1173. TaskDO taskDO = taskDao.selectById(transactionId);
  1174. ActivityRuleDO ruleDO = activityRuleDao.selectByActivityId(taskDO.getTransactionId());
  1175. //活动总积分排名
  1176. String rankingSql1 = "SELECT count(1)+1 AS total FROM (SELECT " +
  1177. " SUM(total) AS sum , " +
  1178. " patient_id, " +
  1179. " activity_id " +
  1180. "FROM " +
  1181. " wlyy_health_bank_task_patient_detail " +
  1182. "GROUP BY patient_id )btpd1 " +
  1183. "WHERE " +
  1184. " btpd1.activity_id = '"+taskDO.getTransactionId()+"' AND btpd1.sum >= (SELECT SUM(s.total) as total " +
  1185. "FROM wlyy_health_bank_task_patient_detail s WHERE s.patient_id ='"+patient+"' AND s.activity_id='"+taskDO.getTransactionId()+"')" ;
  1186. List<Map<String,Object>> rstotal1 = jdbcTemplate.queryForList(rankingSql1);
  1187. Long count = 0L;
  1188. if(rstotal1!=null&&rstotal1.size()>0){
  1189. count = (Long) rstotal1.get(0).get("total");
  1190. }
  1191. //总活动劵的排名
  1192. String rankingSql2 = "SELECT count(1)+1 AS total FROM (SELECT " +
  1193. " SUM(coupon_total) AS sum , " +
  1194. " patient_id, " +
  1195. " activity_id " +
  1196. "FROM " +
  1197. " wlyy_health_bank_task_patient_detail " +
  1198. "GROUP BY patient_id )btpd1 " +
  1199. "WHERE " +
  1200. " btpd1.activity_id = '"+taskDO.getTransactionId()+"' AND btpd1.sum >= (SELECT SUM(s.coupon_total) as couponTotal " +
  1201. "FROM wlyy_health_bank_task_patient_detail s WHERE s.patient_id ='"+patient+"' AND s.activity_id='"+taskDO.getTransactionId()+"')" ;
  1202. List<Map<String,Object>> rstotal2 = jdbcTemplate.queryForList(rankingSql2);
  1203. Long count2 = 0L;
  1204. if(rstotal2!=null&&rstotal2.size()>0){
  1205. count2 = (Long) rstotal2.get(0).get("total");
  1206. }
  1207. JSONObject object = JSONObject.parseObject(ruleDO.getValue1());
  1208. Integer type = object.getInteger("type");
  1209. if (type == 2){
  1210. creditsDetailDO.setActivityRanking(count2);
  1211. creditsDetailDO.setMark(1);
  1212. }else if (type==1||type==3){
  1213. creditsDetailDO.setActivityRanking(count);
  1214. creditsDetailDO.setMark(2);
  1215. }
  1216. envelop.setObj(creditsDetailDO);
  1217. return envelop;
  1218. }
  1219. /**
  1220. * 分享获取积分
  1221. *
  1222. * @param creditsDetailDO
  1223. * @return
  1224. */
  1225. public MixEnvelop<CreditsDetailDO, CreditsDetailDO> shareIntegrate(CreditsDetailDO creditsDetailDO) {
  1226. try {
  1227. synchronized (creditsDetailDO.getPatientId()) {
  1228. String sqlAccount = "select * from wlyy_health_bank_account ba where ba.patient_id = '" + creditsDetailDO.getPatientId() + "'";
  1229. List<AccountDO> accountDOList = jdbcTemplate.query(sqlAccount, new BeanPropertyRowMapper(AccountDO.class));
  1230. if (accountDOList != null && accountDOList.size() != 0) {
  1231. creditsDetailDO.setAccountId(accountDOList.get(0).getId());
  1232. }
  1233. String creditsSql = "select * from wlyy_health_bank_credits_detail where patient_id = '" + creditsDetailDO.getPatientId() + "' and description = '周奖励'";
  1234. List<CreditsDetailDO> creditsDetailDOS1 = jdbcTemplate.query(creditsSql, new BeanPropertyRowMapper(CreditsDetailDO.class));
  1235. List<CreditsDetailDO> creditsDetailDOList = new ArrayList<>();
  1236. MixEnvelop<CreditsDetailDO, CreditsDetailDO> envelop = new MixEnvelop<>();
  1237. if (creditsDetailDOS1 == null || creditsDetailDOS1.size() == 0) {
  1238. creditsDetailDO.setTradeType("ACTIVITY_TASK");
  1239. creditsDetailDO.setDescription("分享");
  1240. creditsDetailDO.setSaasId("dev");
  1241. creditsDetailDO.setStatus(1);
  1242. creditsDetailDO.setTransactionId(creditsDetailDO.getTransactionId());
  1243. creditsDetailDO.setCreateTime(new Date());
  1244. creditsDetailDO.setUpdateTime(new Date());
  1245. creditsDetailDO.setTradeDirection(1);
  1246. CreditsDetailDO creditsDetailDO1 = credittsLogDetailDao.save(creditsDetailDO);
  1247. creditsDetailDOList.add(creditsDetailDO1);
  1248. TaskPatientDetailDO taskPatientDetailDO = new TaskPatientDetailDO();
  1249. taskPatientDetailDO.setPatientId(creditsDetailDO1.getPatientId());
  1250. taskPatientDetailDO.setTaskId(creditsDetailDO1.getTransactionId());
  1251. String taskSql1 = ISqlUtils.getAllSql(taskPatientDetailDO);
  1252. List<TaskPatientDetailDO> taskPatientDetailDOS1 = jdbcTemplate.query(taskSql1, new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  1253. TaskPatientDetailDO taskPatientDetailDO1 = taskPatientDetailDOS1.get(0);
  1254. if (creditsDetailDO1.getTradeDirection() == 1) {
  1255. taskPatientDetailDO1.setTotal(taskPatientDetailDO1.getTotal() + creditsDetailDO1.getIntegrate());
  1256. } else if (creditsDetailDO.getTradeDirection() == -1) {
  1257. taskPatientDetailDO1.setTotal(taskPatientDetailDO1.getTotal() - creditsDetailDO1.getIntegrate());
  1258. }
  1259. taskPatientDetailDao.save(taskPatientDetailDO1);
  1260. AccountDO accountDO = accountDao.findOne(creditsDetailDO1.getAccountId());
  1261. if (creditsDetailDO1.getTradeDirection() == 1) {
  1262. accountDO.setTotal(accountDO.getTotal() + creditsDetailDO1.getIntegrate());
  1263. } else if (creditsDetailDO.getTradeDirection() == -1) {
  1264. accountDO.setTotal(accountDO.getTotal() - creditsDetailDO1.getIntegrate());
  1265. }
  1266. accountDao.save(accountDO);
  1267. envelop.setDetailModelList(creditsDetailDOList);
  1268. }else {
  1269. envelop.setDetailModelList(creditsDetailDOS1);
  1270. }
  1271. return envelop;
  1272. }
  1273. } catch (Exception e) {
  1274. e.printStackTrace();
  1275. MixEnvelop<CreditsDetailDO, CreditsDetailDO> envelop = new MixEnvelop<>();
  1276. return envelop;
  1277. }
  1278. }
  1279. }