zhubaomin
2024-09-19 4a33b783168846bd71eb849e1a922ae864237fbe
pipIrr-platform/pipIrr-web/pipIrr-web-base/src/main/java/com/dy/pipIrrBase/district/DistrictSv.java
@@ -1,27 +1,34 @@
package com.dy.pipIrrBase.district;
import com.dy.pipIrrBase.district.qo.DistrictQO;
import com.dy.pipIrrGlobal.daoBa.AreaCode2023Mapper;
import com.dy.pipIrrGlobal.daoBa.BaDistrictMapper;
import com.dy.pipIrrGlobal.pojoBa.BaDistrict;
import com.dy.pipIrrGlobal.util.DistrictLevel;
import com.dy.pipIrrGlobal.voBa.VoDistrict;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import java.util.List;
import java.util.Map;
@Slf4j
@Service
public class DistrictSv {
    private BaDistrictMapper baDistrictMapper ;
    private BaDistrictMapper dao;
    private AreaCode2023Mapper areaCode2023Dao;
    @Autowired
    private void setBaDistrictMapper(BaDistrictMapper baDistrictMapper){
        this.baDistrictMapper = baDistrictMapper ;
    private void setDao(BaDistrictMapper dao){
        this.dao = dao;
    }
    public int save(BaDistrict po){
        return this.baDistrictMapper.insert(po) ;
    @Autowired
    private void setDao(AreaCode2023Mapper areaCode2023Dao){
        this.areaCode2023Dao = areaCode2023Dao;
    }
    /**
@@ -29,14 +36,55 @@
     * @param firstLevel 第一级行下区 level
     * @return 所有行政区划集合
     */
    public List<BaDistrict> getAll(byte firstLevel){
        List<BaDistrict> list = this.baDistrictMapper.selectByLevel(firstLevel) ;
    public List<BaDistrict> selectAllByLevel(byte firstLevel){
        List<BaDistrict> list = this.dao.selectByLevel(firstLevel) ;
        if(list != null && list.size() > 0){
            for(BaDistrict po : list){
                po.canDelete = false ;
                po.canAdd = true ;
                getSubDistrict(po) ;
            }
        }
        return list ;
    }
    /**
     * 得到一个行政区
     * @param id 行政区ID
     * @return 行政区实体
     */
    public BaDistrict selectById(Long id){
        return this.dao.selectByPrimaryKey(id) ;
    }
    /**
     * 保存实体
     * @param po 实体
     * @return 数量
     */
    @Transactional
    public int save(BaDistrict po){
        return this.dao.putin(po) ;
    }
    /**
     * 保存修改实体
     * @param po 实体
     * @return 数量
     */
    @Transactional
    public int update(BaDistrict po){
        return this.dao.updateByPrimaryKeySelective(po) ;
    }
    /**
     * 保存修改实体
     * @param id 实体ID
     * @return 数量
     */
    @Transactional
    public int delete(Long id){
        return this.dao.deleteByPrimaryKey(id) ;
    }
    /**
@@ -45,12 +93,46 @@
     */
    private void getSubDistrict(BaDistrict po){
        if(po != null && po.id != null){
            po.subDistricts = this.baDistrictMapper.selectBySupperId(po.id) ;
            po.subDistricts = this.dao.selectBySupperId(po.id) ;
            if(po.subDistricts != null && po.subDistricts.size() > 0){
                for(BaDistrict subPo : po.subDistricts){
                    getSubDistrict(subPo) ;
                }
            }else{
                //没有下级了,可以删除
                po.canDelete = false ;
                if(po.level.code.byteValue() == DistrictLevel.Village.code.byteValue()){
                    //到村级了,不可以再添加行政区了
                    po.canAdd = false ;
                }
            }
        }
    }
    /**
     * 根据级别获取行政区划列表
     * @param level
     * @return
     */
    public List<Map<String, Object>> getDistrictgsByLevel(Integer level) {
        return dao.getDistrictgsByLevel(level);
    }
    /**
     * 根据父ID获取行政区划列表
     * @param supperId
     * @return
     */
    public List<Map<String, Object>> getDistrictsBySupperId(Long supperId) {
        return dao.getDistrictsBySupperId(supperId);
    }
    /**
     * 根据区划代码查询指定级别行政区划
     * @param qo
     * @return
     */
    public List<VoDistrict> getDistrictS(DistrictQO qo) {
        return areaCode2023Dao.getDistrictS(qo.getAredCode(), qo.getLevel());
    }
}