beb7d917ca7d8a48e61cd6ca53b13887411233b4.svn-base 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. package cn.com.goldenwater.dcproj.service.impl.fjpjmgdp;
  2. import cn.com.goldenwater.dcproj.dao.BisInspFjpjmgdpAmDao;
  3. import cn.com.goldenwater.dcproj.dao.BisInspFjpjmgdpDao;
  4. import cn.com.goldenwater.dcproj.model.BisInspFjpjlgl;
  5. import cn.com.goldenwater.dcproj.model.BisInspFjpjlglAm;
  6. import cn.com.goldenwater.dcproj.model.BisInspFjpjmgdp;
  7. import cn.com.goldenwater.dcproj.model.BisInspFjpjmgdpAm;
  8. import cn.com.goldenwater.dcproj.param.BisInspFjpjmgdpAmParam;
  9. import cn.com.goldenwater.dcproj.service.BisInspFjpjmgdpAmService;
  10. import cn.com.goldenwater.core.service.AbstractCrudService;
  11. import cn.com.goldenwater.target.CheckException;
  12. import com.github.pagehelper.PageHelper;
  13. import org.springframework.beans.factory.annotation.Autowired;
  14. import org.springframework.stereotype.Service;
  15. import org.springframework.transaction.annotation.Transactional;
  16. import cn.com.goldenwater.id.util.UuidUtil;
  17. import java.util.List;
  18. import java.util.Date;
  19. import java.util.Objects;
  20. /**
  21. * @author lhc
  22. * @date 2023-11-8
  23. */
  24. @Service
  25. @Transactional
  26. public class BisInspFjpjmgdpAmServiceImpl extends AbstractCrudService<BisInspFjpjmgdpAm, BisInspFjpjmgdpAmParam> implements BisInspFjpjmgdpAmService {
  27. @Autowired
  28. private BisInspFjpjmgdpAmDao bisInspFjpjmgdpAmDao;
  29. @Autowired
  30. private BisInspFjpjmgdpDao bisInspFjpjmgdpDao;
  31. public BisInspFjpjmgdpAmServiceImpl(BisInspFjpjmgdpAmDao bisInspFjpjmgdpAmDao) {
  32. super(bisInspFjpjmgdpAmDao);
  33. this.bisInspFjpjmgdpAmDao = bisInspFjpjmgdpAmDao;
  34. }
  35. @Override
  36. public int insert(BisInspFjpjmgdpAm bisInspFjpjmgdpAm) {
  37. String uuid = UuidUtil.uuid(); // 生成uuid
  38. bisInspFjpjmgdpAm.setId(uuid);
  39. bisInspFjpjmgdpAm.setIntm(new Date());
  40. bisInspFjpjmgdpAm.setUptm(new Date());
  41. bisInspFjpjmgdpAm.setDataStat("0");
  42. int insert = this.bisInspFjpjmgdpAmDao.insert(bisInspFjpjmgdpAm);
  43. scoreProcessing(bisInspFjpjmgdpAm);
  44. return insert;
  45. }
  46. @Override
  47. public int update(BisInspFjpjmgdpAm bisInspFjpjmgdpAm) {
  48. bisInspFjpjmgdpAm.setUptm(new Date());
  49. scoreProcessing(bisInspFjpjmgdpAm);
  50. return this.bisInspFjpjmgdpAmDao.update(bisInspFjpjmgdpAm);
  51. }
  52. @Override
  53. public int delete(String id) {
  54. return this.bisInspFjpjmgdpAmDao.delete(id);
  55. }
  56. /**
  57. * 分数处理
  58. *
  59. * @param obj 对象
  60. */
  61. private void scoreProcessing(BisInspFjpjmgdpAm obj) {
  62. Double total1 = 0.0;//合计
  63. Double lac1 = 0.0;//缺项合计
  64. if(obj.getF711()==null){
  65. lac1 = lac1 + 3.0;
  66. }else{
  67. total1= total1+obj.getF711();
  68. }
  69. if(obj.getF712()==null){
  70. lac1 = lac1 + 3.0;
  71. }else{
  72. total1= total1+obj.getF712();
  73. }
  74. if(obj.getF721()==null){
  75. lac1 = lac1 + 4.0;
  76. }else{
  77. total1= total1+obj.getF721();
  78. }
  79. if(obj.getF722()==null){
  80. lac1 = lac1 + 7.0;
  81. }else{
  82. total1= total1+obj.getF722();
  83. }
  84. if(obj.getF723()==null){
  85. lac1 = lac1 + 3.0;
  86. }else{
  87. total1= total1+obj.getF723();
  88. }
  89. if(obj.getF724()==null){
  90. lac1 = lac1 + 4.0;
  91. }else{
  92. total1= total1+obj.getF724();
  93. }
  94. if(obj.getF725()==null){
  95. lac1 = lac1 + 3.0;
  96. }else{
  97. total1= total1+obj.getF725();
  98. }
  99. if(obj.getF731()==null){
  100. lac1 = lac1 + 3.0;
  101. }else{
  102. total1= total1+obj.getF731();
  103. }
  104. BisInspFjpjmgdp rgstr = bisInspFjpjmgdpDao.get(obj.getRgstrId());
  105. if (rgstr == null) {
  106. throw new CheckException("未找到此登记表");
  107. }
  108. //算总分和缺项、评分率
  109. Double tatl = judge(total1)+
  110. judge(rgstr.getSystemTatl())+judge(rgstr.getTrgtTatl())+judge(rgstr.getTvetTatl())
  111. + judge(rgstr.getImgrTatl())+judge(rgstr.getSafdlTatl())+judge(rgstr.getEmTatl())+judge(rgstr.getCimtTatl());
  112. Double lacSoc = judge(lac1)+
  113. judge(rgstr.getSystemLac())+judge(rgstr.getTrgtLac())+judge(rgstr.getTvetLac())
  114. + judge(rgstr.getImgrLac())+judge(rgstr.getSafdlLac())+judge(rgstr.getEmLac())+judge(rgstr.getCimtLac());
  115. BisInspFjpjmgdp bisInspFjpjlgl = new BisInspFjpjmgdp();
  116. bisInspFjpjlgl.setId(rgstr.getId());
  117. bisInspFjpjlgl.setAmTatl(total1);
  118. bisInspFjpjlgl.setAmLac(lac1);
  119. bisInspFjpjlgl.setAmStat(obj.getState());
  120. //设置总分和评定得分
  121. if(tatl!=null || tatl != 0){
  122. bisInspFjpjlgl.setTatl(Math.round(tatl*10.0)/10.0);
  123. Double soc = 1000-lacSoc;
  124. if(soc!=null && soc != 0){
  125. Double ratSoc = tatl/(1000-lacSoc)*100;
  126. bisInspFjpjlgl.setRatSoc(Math.round(ratSoc*10.0)/10.0);
  127. }
  128. }
  129. bisInspFjpjlgl.setState("1");
  130. bisInspFjpjlgl.setUptm(new Date());
  131. bisInspFjpjmgdpDao.update(bisInspFjpjlgl);
  132. }
  133. private Double judge(Double value) {
  134. if (Objects.isNull(value)) {
  135. return 0.0;
  136. }
  137. return value;
  138. }
  139. }