| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293 |
- package cn.com.goldenwater.dcproj.service.impl;
- import cn.com.goldenwater.dcproj.dao.BisInspKeychkqhUnitDao;
- import cn.com.goldenwater.dcproj.dao.BisInspPblmDao;
- import cn.com.goldenwater.dcproj.model.BisInspKeychkqhRegister;
- import cn.com.goldenwater.dcproj.model.BisInspKeychkqhSection;
- import cn.com.goldenwater.dcproj.model.BisInspKeychkqhUnit;
- import cn.com.goldenwater.dcproj.model.BisInspPblm;
- import cn.com.goldenwater.dcproj.param.BisInspKeychkqhUnitParam;
- import cn.com.goldenwater.dcproj.param.BisInspPblmParam;
- import cn.com.goldenwater.dcproj.service.BisInspKeychkqhRegisterService;
- import cn.com.goldenwater.dcproj.service.BisInspKeychkqhSectionService;
- import cn.com.goldenwater.dcproj.service.BisInspKeychkqhUnitService;
- import cn.com.goldenwater.core.service.AbstractCrudService;
- import cn.com.goldenwater.dcproj.service.BisInspPblmService;
- import cn.com.goldenwater.dcproj.utils.Builder;
- import cn.com.goldenwater.dcproj.utils.Constant;
- import cn.com.goldenwater.target.CheckException;
- import com.github.pagehelper.PageHelper;
- import org.apache.commons.collections.MapUtils;
- import org.apache.commons.lang.StringUtils;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.stereotype.Service;
- import org.springframework.transaction.annotation.Transactional;
- import cn.com.goldenwater.id.util.UuidUtil;
- import java.util.*;
- /**
- * @author lhc
- * @date 2021-6-25
- */
- @Service
- @Transactional
- public class BisInspKeychkqhUnitServiceImpl extends AbstractCrudService<BisInspKeychkqhUnit, BisInspKeychkqhUnitParam> implements BisInspKeychkqhUnitService {
- @Autowired
- private BisInspKeychkqhUnitDao bisInspKeychkqhUnitDao;
- @Autowired
- private BisInspKeychkqhRegisterService bisInspKeychkqhRegisterService;
- @Autowired
- private BisInspKeychkqhSectionService bisInspKeychkqhSectionService;
- @Autowired
- private BisInspPblmService bisInspPblmService;
- @Autowired
- private BisInspPblmDao bisInspPblmDao;
- public BisInspKeychkqhUnitServiceImpl(BisInspKeychkqhUnitDao bisInspKeychkqhUnitDao) {
- super(bisInspKeychkqhUnitDao);
- this.bisInspKeychkqhUnitDao = bisInspKeychkqhUnitDao;
- }
- @Override
- public int insert(BisInspKeychkqhUnit bisInspKeychkqhUnit) {
- if (StringUtils.isBlank(bisInspKeychkqhUnit.getSecId())){
- throw new CheckException("标段ID为空");
- }
- if(StringUtils.isBlank(bisInspKeychkqhUnit.getNm())){
- throw new CheckException("单位名称为空");
- }
- if(StringUtils.isBlank(bisInspKeychkqhUnit.getNature())){
- throw new CheckException("单位性质为空");
- }
- BisInspKeychkqhSection section = bisInspKeychkqhSectionService.get(bisInspKeychkqhUnit.getSecId());
- if (section == null ){
- throw new CheckException("标段ID有误");
- }
- String uuid = UuidUtil.uuid(); // 生成uuid
- bisInspKeychkqhUnit.setId(uuid);
- bisInspKeychkqhUnit.setIntm(new Date());
- bisInspKeychkqhUnit.setUptm(new Date());
- bisInspKeychkqhUnit.setDataStat("0");
- int ret = this.bisInspKeychkqhUnitDao.insert(bisInspKeychkqhUnit);
- updateRgstrState(bisInspKeychkqhUnit.getId());
- return ret;
- }
- private void updateRgstrState(String id) {
- BisInspKeychkqhRegister rgstr = bisInspKeychkqhUnitDao.getRgstrById(id);
- Optional.ofNullable(rgstr).ifPresent(r ->{
- if(!Constant.STRING_TWO.equals(r.getState())&&
- !Constant.STRING_ONE.equals(r.getState())){
- r.setUptm(new Date());
- r.setState(Constant.STRING_ONE);
- bisInspKeychkqhRegisterService.update(r);
- }
- });
- }
- @Override
- public int update(BisInspKeychkqhUnit bisInspKeychkqhUnit) {
- bisInspKeychkqhUnit.setUptm(new Date());
- int ret = this.bisInspKeychkqhUnitDao.update(bisInspKeychkqhUnit);
- updateRgstrState(bisInspKeychkqhUnit.getId());
- return ret;
- }
- @Override
- public int delete(String id) {
- BisInspKeychkqhRegister bisInspKeychkqhRegister = bisInspKeychkqhUnitDao.getRgstrById(id);
- if(bisInspKeychkqhRegister != null){
- bisInspPblmService.deleteBy(Builder.of(BisInspPblmParam::new)
- .with(BisInspPblmParam::setObjId,bisInspKeychkqhRegister.getOrgId())
- .with(BisInspPblmParam::setRegid,id)
- .build());
- }
- return this.bisInspKeychkqhUnitDao.delete(id);
- }
- @Override
- public List<BisInspKeychkqhUnit> listBySecId(String secId) {
- return bisInspKeychkqhUnitDao.findList(Builder.of(BisInspKeychkqhUnitParam::new).with(BisInspKeychkqhUnitParam::setSecId,secId).build());
- }
- @Override
- public List<Map<String, Object>> getResponsibility(String id) {
- BisInspKeychkqhUnit unit = get(id);
- BisInspKeychkqhSection section = bisInspKeychkqhSectionService.get(unit.getSecId());
- List<BisInspPblm> bisInspPblmList = bisInspPblmDao.list(Builder.of(BisInspPblmParam::new)
- .with(BisInspPblmParam::setObjId, section.getObjId())
- .with(BisInspPblmParam::setRegid, id).build());
- List<Map<String,Object>> res = new ArrayList<>();
- int index = 0;
- while (index < 3){
- int finalIndex = index;
- Long yibanCount = bisInspPblmList.stream().filter(p -> String.valueOf(finalIndex).equals(p.getInspPblmCate())).count();
- Map<String, Object> map = new HashMap(5);
- map.put("level", String.valueOf(finalIndex));
- map.put("count", yibanCount);
- zhenggai(map, unit.getNature());
- res.add(map);
- index++;
- }
- return res;
- }
- private void zhenggai(Map<String, Object> map, String type) {
- if("1".equals(type)){
- xiangmufaren(map);
- }else{
- sjg(map);
- }
- }
- private void sjg(Map<String, Object> map) {
- String level = MapUtils.getString(map, "level");
- int count = MapUtils.getIntValue(map, "count");
- if (count == 0) {
- return;
- }
- String max = "";
- String chose = "";
- Set<String> set = new HashSet<>();
- switch (level) {
- case "0":
- if (count <= 20) {
- max = "责令整改";
- set.add("8");
- } else {
- max = "约谈";
- chose = "责令整改";
- set.add("9");
- set.add("8");
- }
- break;
- case "1":
- if (count <= 6) {
- max = "责令整改";
- set.add("8");
- } else if (count <= 12) {
- max = "约谈";
- chose = "责令整改";
- set.add("9");
- set.add("8");
- } else if (count <= 20) {
- max = "停工整改";
- chose = "责令整改、约谈";
- set.add("3");
- set.add("8");
- set.add("9");
- } else {
- max = "通报批评";
- chose = "责令整改、停工整改、经济责任";
- set.add("10");
- set.add("8");
- set.add("3");
- set.add("4");
- }
- break;
- case "2":
- if (count <= 5) {
- max = "责令整改";
- set.add("8");
- } else if (count <= 10) {
- max = "约谈";
- chose = "责令整改";
- set.add("9");
- set.add("8");
- } else if (count <= 15) {
- max = "停工整改";
- chose = "责令整改";
- set.add("3");
- set.add("8");
- } else if (count <= 20) {
- max = "通报批评";
- chose = "责令整改、经济责任";
- set.add("10");
- set.add("8");
- set.add("4");
- } else {
- max = "建议解除合同";
- chose = "责令整改、经济责任、通报批评、降低资质";
- set.add("6");
- set.add("8");
- set.add("4");
- set.add("10");
- set.add("7");
- }
- default:
- }
- map.put("chose", chose);
- map.put("max", max);
- map.put("set", set);
- }
- private void xiangmufaren(Map<String, Object> map) {
- String level = MapUtils.getString(map, "level");
- int count = MapUtils.getIntValue(map, "count");
- if (count == 0) {
- return;
- }
- String max = "";
- String chose = "";
- Set<String> set = new HashSet<>();
- switch (level) {
- case "0":
- if (count <= 15) {
- max = "责令整改";
- set.add("8");
- } else {
- max = "约谈";
- chose = "责令整改";
- set.add("9");
- set.add("8");
- }
- break;
- case "1":
- if (count <= 10) {
- max = "责令整改";
- set.add("8");
- } else if (count <= 20) {
- max = "约谈";
- chose = "责令整改";
- set.add("9");
- set.add("8");
- } else {
- max = "通报批评";
- chose = "责令整改、约谈";
- set.add("10");
- set.add("8");
- set.add("9");
- }
- break;
- case "2":
- if (count <= 7) {
- max = "责令整改";
- set.add("8");
- } else if (count <= 15) {
- max = "约谈";
- chose = "责令整改";
- set.add("9");
- set.add("8");
- } else {
- max = "通报批评";
- chose = "责令整改、约谈";
- set.add("10");
- set.add("8");
- set.add("9");
- }
- default:
- }
- map.put("chose", chose);
- map.put("max", max);
- map.put("set", set);
- }
- }
|