mitao
2025-01-17 922d7aa03200fa293bbce565d43c58995ec58548
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
package com.zzg.web.controller.system;
 
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.zzg.common.core.controller.BaseController;
import com.zzg.common.core.domain.AjaxResult;
import com.zzg.common.utils.SecurityUtils;
import com.zzg.system.domain.SysCity;
import com.zzg.system.service.system.ISysCityService;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.web.bind.annotation.*;
 
import javax.annotation.Resource;
import java.util.List;
 
@RestController
@Api(tags = "镇村组数据")
@RequestMapping("/system/city")
public class SysCityController extends BaseController {
 
    @Resource
    ISysCityService sysCityService;
 
    private static Integer DEFAULT_LEVEl = 1;
 
    @PostMapping("/add")
    @ApiOperation("新增数据")
    @PreAuthorize("@ss.hasPermi('system:city:add')")
    public AjaxResult add(@RequestBody SysCity sysCity) {
        if (sysCity.getId() != null) {
            SysCity group = sysCityService.getById(sysCity.getId());
            if (group.getState().equals(1)) {
                return AjaxResult.error("撤销/合并的数据不能修改!");
            }
            sysCityService.updateById(sysCity);
        } else {
            SysCity group = sysCityService.getOne(new LambdaQueryWrapper<SysCity>()
                    .eq(sysCity.getPid() != null && !sysCity.getPid().isEmpty(), SysCity::getPid, sysCity.getPid())
                    .eq(SysCity::getName, sysCity.getName()));
            if (group != null) {
                return AjaxResult.error("当前级别下" + sysCity.getName() + "已存在!");
            }
            //设置级别
            if (sysCity.getPid() != null && !sysCity.getPid().equals("")) {
                group = sysCityService.getOne(new LambdaQueryWrapper<SysCity>()
                        .eq(SysCity::getId, sysCity.getPid()));
                sysCity.setLevel(group.getLevel() + 1);
            } else {
                sysCity.setLevel(DEFAULT_LEVEl);
            }
            sysCity.setCreateName(SecurityUtils.getUsername());
        }
        sysCityService.saveOrUpdate(sysCity);
        return AjaxResult.success(sysCity);
    }
 
    @GetMapping("/getListTree")
    @ApiOperation("树形列表")
    @PreAuthorize("@ss.hasPermi('system:city:getListTree')")
    public AjaxResult getListTree() {
        return AjaxResult.success(sysCityService.getListTree());
    }
 
    /**
     * 通过ID向上查询整个镇村组名称
     *
     * @param id
     * @return
     */
    @GetMapping("/getUpwardById/{id}")
    @ApiOperation("通过ID向上查询整个镇村组名称")
    public AjaxResult getUpwardById(@PathVariable("id") String id) {
        return AjaxResult.success(sysCityService.getUpwardById(id));
    }
 
    /**
     * 获取所有乡镇
     *
     * @return
     */
    @GetMapping("/getTowns")
    @ApiOperation("获取所有乡镇")
//    @PreAuthorize("@ss.hasPermi('system:city:getTowns')")
    public AjaxResult getTowns() {
        List<SysCity> list;
        try {
            list = sysCityService.getTowns();
        } catch (Exception e) {
            return AjaxResult.error(e.getMessage());
        }
        return AjaxResult.success(list);
    }
 
    /**
     * 原始表
     *
     * @param pid
     * @return
     */
    @GetMapping("/getNextTree/{pid}")
    @ApiOperation("通过上级ID获取下面的树形")
    @PreAuthorize("@ss.hasPermi('system:city:getNextTree')")
    public AjaxResult getNextTree(@PathVariable("pid") String pid) {
        return AjaxResult.success(sysCityService.getNextTree(pid));
    }
 
}