CreditsDetailService.java 74 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330
  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. creditsDetailDO.setTransactionId(taskDO.getId());
  979. creditsDetailDO.setPatientId(patientId);
  980. creditsDetailDO.setHospitalName(hospitalName);
  981. credittsLogDetailDao.save(creditsDetailDO);
  982. accountDO.setTotal(accountDO.getTotal()-integrate);
  983. accountDao.save(accountDO);
  984. }else {
  985. envelop.setMessage("积分不足!");
  986. throw new Exception("积分不足!");
  987. }
  988. return envelop;
  989. }
  990. /*public JSONObject getStepNumber(){
  991. String step = redisTemplate.·().get(STEP);
  992. logger.info("redis数据:"+step);
  993. String sql = ""
  994. String step1 = systemDictDao.
  995. logger.info("数据库的数据:"+step1);
  996. if (step != null && step.equalsIgnoreCase(step1)){
  997. JSONObject jsonObject = JSONObject.parseObject(step);
  998. logger.info("数据不一致:"+jsonObject.toString());
  999. return jsonObject;
  1000. }else {
  1001. JSONObject jsonObject = JSONObject.parseObject(step);
  1002. redisTemplate.opsForValue().set(STEP,step1);
  1003. logger.info("数据一致:"+jsonObject.toString());
  1004. return jsonObject;
  1005. }
  1006. }*/
  1007. public MixEnvelop<CreditsDetailDO, CreditsDetailDO> weekReward(CreditsDetailDO creditsDetailDO) {
  1008. try {
  1009. synchronized (creditsDetailDO.getPatientId()) {
  1010. String sqlAccount = "select * from wlyy_health_bank_account ba where ba.patient_id = '" + creditsDetailDO.getPatientId() + "'";
  1011. List<AccountDO> accountDOList = jdbcTemplate.query(sqlAccount, new BeanPropertyRowMapper(AccountDO.class));
  1012. if (accountDOList != null && accountDOList.size() != 0) {
  1013. creditsDetailDO.setAccountId(accountDOList.get(0).getId());
  1014. }
  1015. String creditsSql = "select * from wlyy_health_bank_credits_detail where patient_id = '" + creditsDetailDO.getPatientId() + "' and " +
  1016. "DATE_FORMAT(create_time,'%Y-%m-%d') IN " + creditsDetailDO.getWeekTimes()+" and description = '周奖励'";
  1017. List<CreditsDetailDO> creditsDetailDOS1 = jdbcTemplate.query(creditsSql, new BeanPropertyRowMapper(CreditsDetailDO.class));
  1018. List<CreditsDetailDO> creditsDetailDOList = new ArrayList<>();
  1019. MixEnvelop<CreditsDetailDO, CreditsDetailDO> envelop = new MixEnvelop<>();
  1020. if (getWeekOfDate(new Date()).equalsIgnoreCase("星期五")||getWeekOfDate(new Date()).equalsIgnoreCase("星期六")||getWeekOfDate(new Date()).equalsIgnoreCase("星期日")){
  1021. String sql = "select sum(integrate) as total from wlyy_health_bank_credits_detail where patient_id = '" + creditsDetailDO.getPatientId() + "' and description = '周奖励'";
  1022. List<Map<String,Object>> rstotal = jdbcTemplate.queryForList(sql);
  1023. Long count = 0L;
  1024. if(rstotal!=null&&rstotal.size()>0){
  1025. Object object = rstotal.get(0).get("total");
  1026. if (object != null){
  1027. count = Long.parseLong(object.toString());
  1028. }
  1029. }
  1030. if (count > 12){
  1031. envelop.setMessage("奖励积分已达到12分。不能再奖励了!");
  1032. return envelop;
  1033. }else{
  1034. if (creditsDetailDOS1 == null || creditsDetailDOS1.size() == 0) {
  1035. creditsDetailDO.setTradeType("ACTIVITY_TASK");
  1036. creditsDetailDO.setSaasId("dev");
  1037. creditsDetailDO.setStatus(1);
  1038. creditsDetailDO.setTransactionId(creditsDetailDO.getTransactionId());
  1039. creditsDetailDO.setCreateTime(new Date());
  1040. creditsDetailDO.setUpdateTime(new Date());
  1041. creditsDetailDO.setTradeDirection(1);
  1042. CreditsDetailDO creditsDetailDO1 = credittsLogDetailDao.save(creditsDetailDO);
  1043. creditsDetailDOList.add(creditsDetailDO1);
  1044. TaskPatientDetailDO taskPatientDetailDO = new TaskPatientDetailDO();
  1045. taskPatientDetailDO.setPatientId(creditsDetailDO1.getPatientId());
  1046. taskPatientDetailDO.setTaskId(creditsDetailDO1.getTransactionId());
  1047. String taskSql1 = ISqlUtils.getAllSql(taskPatientDetailDO);
  1048. List<TaskPatientDetailDO> taskPatientDetailDOS1 = jdbcTemplate.query(taskSql1, new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  1049. TaskPatientDetailDO taskPatientDetailDO1 = taskPatientDetailDOS1.get(0);
  1050. if (creditsDetailDO1.getTradeDirection() == 1) {
  1051. taskPatientDetailDO1.setTotal(taskPatientDetailDO1.getTotal() + creditsDetailDO1.getIntegrate());
  1052. } else if (creditsDetailDO.getTradeDirection() == -1) {
  1053. taskPatientDetailDO1.setTotal(taskPatientDetailDO1.getTotal() - creditsDetailDO1.getIntegrate());
  1054. }
  1055. taskPatientDetailDao.save(taskPatientDetailDO1);
  1056. AccountDO accountDO = accountDao.findOne(creditsDetailDO1.getAccountId());
  1057. if (creditsDetailDO1.getTradeDirection() == 1) {
  1058. accountDO.setTotal(accountDO.getTotal() + creditsDetailDO1.getIntegrate());
  1059. } else if (creditsDetailDO.getTradeDirection() == -1) {
  1060. accountDO.setTotal(accountDO.getTotal() - creditsDetailDO1.getIntegrate());
  1061. }
  1062. AccountDO accountDO1 = accountDao.save(accountDO);
  1063. List<CreditsDetailDO> creditsDetailDOS = new ArrayList<>();
  1064. for (CreditsDetailDO creditsDetailDO2 : creditsDetailDOList) {
  1065. creditsDetailDO2.setTotal(accountDO1.getTotal());
  1066. creditsDetailDO2.setFlag("1");
  1067. creditsDetailDOS.add(creditsDetailDO2);
  1068. }
  1069. envelop.setDetailModelList(creditsDetailDOS);
  1070. }else {
  1071. for (CreditsDetailDO creditsDetailDO1 : creditsDetailDOS1){
  1072. creditsDetailDO1.setFlag("2");
  1073. }
  1074. envelop.setDetailModelList(creditsDetailDOS1);
  1075. }
  1076. return envelop;
  1077. }
  1078. }else{
  1079. CreditsDetailDO creditsDetailDO1 = new CreditsDetailDO();
  1080. creditsDetailDO1.setFlag("0");
  1081. creditsDetailDOList.add(creditsDetailDO1);
  1082. envelop.setDetailModelList(creditsDetailDOList);
  1083. return envelop;
  1084. }
  1085. }
  1086. } catch (Exception e) {
  1087. e.printStackTrace();
  1088. MixEnvelop<CreditsDetailDO, CreditsDetailDO> envelop = new MixEnvelop<>();
  1089. return envelop;
  1090. }
  1091. }
  1092. public String getWeekOfDate(Date dt) {
  1093. String[] weekDays = {"星期日", "星期一", "星期二", "星期三", "星期四", "星期五", "星期六"};
  1094. Calendar cal = Calendar.getInstance();
  1095. cal.setTime(dt);
  1096. int w = cal.get(Calendar.DAY_OF_WEEK) - 1;
  1097. if (w < 0)
  1098. w = 0;
  1099. return weekDays[w];
  1100. }
  1101. /**
  1102. * 健康问答添加积分
  1103. *
  1104. * @param creditsDetailDO
  1105. * @return
  1106. * @throws Exception
  1107. */
  1108. public MixEnvelop<CreditsDetailDO,CreditsDetailDO> patientGetInteger(CreditsDetailDO creditsDetailDO) throws Exception {
  1109. MixEnvelop<CreditsDetailDO,CreditsDetailDO> envelop = new MixEnvelop<>();
  1110. TaskDO taskDO = taskDao.selectById(creditsDetailDO.getTransactionId());
  1111. ActivityRuleDO ruleDO = activityRuleDao.selectByActivityId(taskDO.getTransactionId());
  1112. JSONObject object = JSONObject.parseObject(ruleDO.getValue1());
  1113. Integer type = object.getInteger("type");
  1114. AccountDO accountDO = accountDao.selectByPatientId(creditsDetailDO.getPatientId());
  1115. creditsDetailDO.setUpdateTime(new Date());
  1116. creditsDetailDO.setCreateTime(new Date());
  1117. creditsDetailDO.setStatus(1);
  1118. if (type == 2){
  1119. creditsDetailDO.setCoupon(creditsDetailDO.getCoupon());
  1120. creditsDetailDO.setIntegrate(null);
  1121. }else if (type==1){
  1122. creditsDetailDO.setIntegrate(creditsDetailDO.getCoupon());
  1123. creditsDetailDO.setCoupon(null);
  1124. }
  1125. creditsDetailDO.setSaasId("dev");
  1126. creditsDetailDO.setTradeType("ACTIVITY_TASK");
  1127. creditsDetailDO.setTradeDirection(1);
  1128. creditsDetailDO.setAccountId(accountDO.getId());
  1129. CreditsDetailDO creditsDetailDO1 = credittsLogDetailDao.save(creditsDetailDO);
  1130. if (creditsDetailDO1 == null){
  1131. throw new Exception("积分添加失败!");
  1132. }
  1133. TaskPatientDetailDO patientDetailDO = taskPatientDetailDao.selectByTaskIdAndPatientId(creditsDetailDO.getTransactionId(),creditsDetailDO.getPatientId());
  1134. patientDetailDO.setUpdateTime(new Date());
  1135. patientDetailDO.setCreateTime(new Date());
  1136. if (type == 2){
  1137. patientDetailDO.setCouponTotal(patientDetailDO.getCouponTotal()+creditsDetailDO.getCoupon());
  1138. }else if (type==1||type==3){
  1139. patientDetailDO.setTotal(patientDetailDO.getTotal()+creditsDetailDO.getIntegrate());
  1140. }
  1141. patientDetailDO.setStatus(1);
  1142. TaskPatientDetailDO taskPatientDetailDO = taskPatientDetailDao.save(patientDetailDO);
  1143. if (taskPatientDetailDO == null){
  1144. throw new Exception("修改活动状态和积分失败!");
  1145. }
  1146. if (type == 2){
  1147. accountDO.setCouponTotal(accountDO.getCouponTotal()+creditsDetailDO.getCoupon());
  1148. }else if (type==1||type==3){
  1149. accountDO.setTotal(accountDO.getTotal()+creditsDetailDO.getIntegrate());
  1150. }
  1151. accountDO.setUpdateTime(new Date());
  1152. AccountDO accountDO1 = accountDao.save(accountDO);
  1153. if (accountDO1 == null){
  1154. throw new Exception("修改银行账户积分失败!");
  1155. }
  1156. envelop.setObj(creditsDetailDO);
  1157. return envelop;
  1158. }
  1159. /**
  1160. * 健康问答--获取当日积分
  1161. *
  1162. * @param patient
  1163. * @param transactionId
  1164. * @return
  1165. */
  1166. public MixEnvelop<CreditsDetailDO,CreditsDetailDO> selectByDate(String patient,String transactionId){
  1167. MixEnvelop<CreditsDetailDO,CreditsDetailDO> envelop = new MixEnvelop<>();
  1168. String sql ="select * from wlyy_health_bank_credits_detail where patient_id = '"+patient+"' and " +
  1169. "transaction_id = '"+transactionId+"' and create_time >='"+ DateUtils.getDayBegin()+"' and " +
  1170. "create_time <= '"+DateUtils.getDayEnd()+"'";
  1171. List<CreditsDetailDO> creditsDetailDOS = jdbcTemplate.query(sql,new BeanPropertyRowMapper<>(CreditsDetailDO.class));
  1172. CreditsDetailDO creditsDetailDO = new CreditsDetailDO();
  1173. if (creditsDetailDOS != null && creditsDetailDOS.size()!=0){
  1174. creditsDetailDO = creditsDetailDOS.get(0);
  1175. }
  1176. TaskDO taskDO = taskDao.selectById(transactionId);
  1177. ActivityRuleDO ruleDO = activityRuleDao.selectByActivityId(taskDO.getTransactionId());
  1178. //活动总积分排名
  1179. String rankingSql1 = "SELECT count(1)+1 AS total FROM (SELECT " +
  1180. " SUM(total) AS sum , " +
  1181. " patient_id, " +
  1182. " activity_id " +
  1183. "FROM " +
  1184. " wlyy_health_bank_task_patient_detail " +
  1185. "GROUP BY patient_id )btpd1 " +
  1186. "WHERE " +
  1187. " btpd1.activity_id = '"+taskDO.getTransactionId()+"' AND btpd1.sum >= (SELECT SUM(s.total) as total " +
  1188. "FROM wlyy_health_bank_task_patient_detail s WHERE s.patient_id ='"+patient+"' AND s.activity_id='"+taskDO.getTransactionId()+"')" ;
  1189. List<Map<String,Object>> rstotal1 = jdbcTemplate.queryForList(rankingSql1);
  1190. Long count = 0L;
  1191. if(rstotal1!=null&&rstotal1.size()>0){
  1192. count = (Long) rstotal1.get(0).get("total");
  1193. }
  1194. //总活动劵的排名
  1195. String rankingSql2 = "SELECT count(1)+1 AS total FROM (SELECT " +
  1196. " SUM(coupon_total) AS sum , " +
  1197. " patient_id, " +
  1198. " activity_id " +
  1199. "FROM " +
  1200. " wlyy_health_bank_task_patient_detail " +
  1201. "GROUP BY patient_id )btpd1 " +
  1202. "WHERE " +
  1203. " btpd1.activity_id = '"+taskDO.getTransactionId()+"' AND btpd1.sum >= (SELECT SUM(s.coupon_total) as couponTotal " +
  1204. "FROM wlyy_health_bank_task_patient_detail s WHERE s.patient_id ='"+patient+"' AND s.activity_id='"+taskDO.getTransactionId()+"')" ;
  1205. List<Map<String,Object>> rstotal2 = jdbcTemplate.queryForList(rankingSql2);
  1206. Long count2 = 0L;
  1207. if(rstotal2!=null&&rstotal2.size()>0){
  1208. count2 = (Long) rstotal2.get(0).get("total");
  1209. }
  1210. JSONObject object = JSONObject.parseObject(ruleDO.getValue1());
  1211. Integer type = object.getInteger("type");
  1212. if (type == 2){
  1213. creditsDetailDO.setActivityRanking(count2);
  1214. creditsDetailDO.setMark(1);
  1215. }else if (type==1||type==3){
  1216. creditsDetailDO.setActivityRanking(count);
  1217. creditsDetailDO.setMark(2);
  1218. }
  1219. envelop.setObj(creditsDetailDO);
  1220. return envelop;
  1221. }
  1222. /**
  1223. * 分享获取积分
  1224. *
  1225. * @param creditsDetailDO
  1226. * @return
  1227. */
  1228. public MixEnvelop<CreditsDetailDO, CreditsDetailDO> shareIntegrate(CreditsDetailDO creditsDetailDO) {
  1229. try {
  1230. synchronized (creditsDetailDO.getPatientId()) {
  1231. String sqlAccount = "select * from wlyy_health_bank_account ba where ba.patient_id = '" + creditsDetailDO.getPatientId() + "'";
  1232. List<AccountDO> accountDOList = jdbcTemplate.query(sqlAccount, new BeanPropertyRowMapper(AccountDO.class));
  1233. if (accountDOList != null && accountDOList.size() != 0) {
  1234. creditsDetailDO.setAccountId(accountDOList.get(0).getId());
  1235. }
  1236. String creditsSql = "select * from wlyy_health_bank_credits_detail where patient_id = '" + creditsDetailDO.getPatientId() + "' and description = '分享'";
  1237. List<CreditsDetailDO> creditsDetailDOS1 = jdbcTemplate.query(creditsSql, new BeanPropertyRowMapper(CreditsDetailDO.class));
  1238. List<CreditsDetailDO> creditsDetailDOList = new ArrayList<>();
  1239. MixEnvelop<CreditsDetailDO, CreditsDetailDO> envelop = new MixEnvelop<>();
  1240. if (creditsDetailDOS1 == null || creditsDetailDOS1.size() == 0) {
  1241. creditsDetailDO.setTradeType("ACTIVITY_TASK");
  1242. creditsDetailDO.setDescription("分享");
  1243. creditsDetailDO.setSaasId("dev");
  1244. creditsDetailDO.setStatus(1);
  1245. creditsDetailDO.setTransactionId(creditsDetailDO.getTransactionId());
  1246. creditsDetailDO.setCreateTime(new Date());
  1247. creditsDetailDO.setUpdateTime(new Date());
  1248. creditsDetailDO.setTradeDirection(1);
  1249. CreditsDetailDO creditsDetailDO1 = credittsLogDetailDao.save(creditsDetailDO);
  1250. creditsDetailDO1.setFlag("1");
  1251. creditsDetailDOList.add(creditsDetailDO1);
  1252. TaskPatientDetailDO taskPatientDetailDO = new TaskPatientDetailDO();
  1253. taskPatientDetailDO.setPatientId(creditsDetailDO1.getPatientId());
  1254. taskPatientDetailDO.setTaskId(creditsDetailDO1.getTransactionId());
  1255. String taskSql1 = ISqlUtils.getAllSql(taskPatientDetailDO);
  1256. List<TaskPatientDetailDO> taskPatientDetailDOS1 = jdbcTemplate.query(taskSql1, new BeanPropertyRowMapper(TaskPatientDetailDO.class));
  1257. TaskPatientDetailDO taskPatientDetailDO1 = taskPatientDetailDOS1.get(0);
  1258. if (creditsDetailDO1.getTradeDirection() == 1) {
  1259. taskPatientDetailDO1.setTotal(taskPatientDetailDO1.getTotal() + creditsDetailDO1.getIntegrate());
  1260. } else if (creditsDetailDO.getTradeDirection() == -1) {
  1261. taskPatientDetailDO1.setTotal(taskPatientDetailDO1.getTotal() - creditsDetailDO1.getIntegrate());
  1262. }
  1263. taskPatientDetailDao.save(taskPatientDetailDO1);
  1264. AccountDO accountDO = accountDao.findOne(creditsDetailDO1.getAccountId());
  1265. if (creditsDetailDO1.getTradeDirection() == 1) {
  1266. accountDO.setTotal(accountDO.getTotal() + creditsDetailDO1.getIntegrate());
  1267. } else if (creditsDetailDO.getTradeDirection() == -1) {
  1268. accountDO.setTotal(accountDO.getTotal() - creditsDetailDO1.getIntegrate());
  1269. }
  1270. accountDao.save(accountDO);
  1271. envelop.setDetailModelList(creditsDetailDOList);
  1272. }else {
  1273. for (CreditsDetailDO creditsDetailDO1:creditsDetailDOS1){
  1274. creditsDetailDO1.setFlag("2");
  1275. creditsDetailDOList.add(creditsDetailDO1);
  1276. }
  1277. envelop.setDetailModelList(creditsDetailDOList);
  1278. }
  1279. return envelop;
  1280. }
  1281. } catch (Exception e) {
  1282. e.printStackTrace();
  1283. MixEnvelop<CreditsDetailDO, CreditsDetailDO> envelop = new MixEnvelop<>();
  1284. return envelop;
  1285. }
  1286. }
  1287. }