ludc
2023-06-02 f39675fad28f66dd32aee1d3ee805ad99007bce5
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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
package com.vci.ubcs.omd.controller;
 
import com.alibaba.cloud.commons.lang.StringUtils;
import com.alibaba.nacos.api.exception.NacosException;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
import com.vci.ubcs.omd.constant.OmdCacheConstant;
import com.vci.ubcs.omd.dto.BtmTypeDTO;
import com.vci.ubcs.omd.entity.BtmType;
import com.vci.ubcs.omd.repeater.DomainRepeater;
import com.vci.ubcs.omd.service.IBtmTypeService;
import com.vci.ubcs.omd.vo.BtmTreeVO;
import com.vci.ubcs.omd.vo.BtmTypeVO;
import com.vci.ubcs.omd.vo.DomainVO;
import com.vci.ubcs.omd.wrapper.BtmTypeWrapper;
import io.swagger.annotations.*;
import lombok.AllArgsConstructor;
import org.springblade.core.boot.ctrl.BladeController;
import org.springblade.core.cache.utils.CacheUtil;
import org.springblade.core.mp.support.Condition;
import org.springblade.core.mp.support.Query;
import org.springblade.core.tenant.annotation.NonDS;
import org.springblade.core.tool.api.R;
import org.springblade.core.tool.utils.BeanUtil;
import org.springblade.core.tool.utils.Func;
import org.springblade.core.tool.utils.StringPool;
import org.springframework.web.bind.annotation.*;
import springfox.documentation.annotations.ApiIgnore;
 
import javax.validation.Valid;
import java.util.*;
import java.util.stream.Collectors;
 
/**
 * Description: 业务类型控制器
 *
 * @author LiHang
 * @date 2023/4/23
 */
@NonDS
@RestController
@AllArgsConstructor
@RequestMapping("/btm-type")
@Api(value = "业务类型控制器", tags = "业务类型控制器")
public class BtmTypeController extends BladeController {
 
    /**
     * 业务类型服务
     */
    private final IBtmTypeService btmTypeService;
 
    /**
     * 查看详情
     *
     * @param oid 主键
     * @return 执行结果
     */
    @GetMapping("/detail")
    @ApiOperationSupport(order = 1)
    @ApiOperation(value = "查看详情", notes = "传入主键")
    public R<BtmTypeVO> detail(String oid) {
        return R.data(btmTypeService.getBtmTypeByOid(oid));
    }
 
    /**
     * 列表
     *
     * @param condition 查询条件
     * @return 执行结果
     */
    @GetMapping("/list")
    @ApiImplicitParams({
        @ApiImplicitParam(name = "oid", value = "主键", paramType = "query", dataType = "string"),
        @ApiImplicitParam(name = "id", value = "业务类型英文名称", paramType = "query", dataType = "string"),
        @ApiImplicitParam(name = "name", value = "业务类型中文名称", paramType = "query", dataType = "string"),
        @ApiImplicitParam(name = "tableName", value = "业务类型数据库表名", paramType = "query", dataType = "string"),
    })
    @ApiOperationSupport(order = 2)
    @ApiOperation(value = "查询列表", notes = "传入查询")
    public R<List<BtmTypeVO>> list(@ApiIgnore @RequestParam Map<String, Object> condition) {
        return R.data(BtmTypeWrapper.build().listEntityVO(btmTypeService.list(Condition.getQueryWrapper(condition, BtmType.class).lambda().orderByAsc(BtmType::getId))));
    }
 
    /**
     * 分页列表
     *
     * @param condition 查询条件
     */
    @GetMapping("/page")
    @ApiImplicitParams({
        @ApiImplicitParam(name = "oid", value = "主键", paramType = "query", dataType = "string"),
        @ApiImplicitParam(name = "id", value = "业务类型英文名称", paramType = "query", dataType = "string"),
        @ApiImplicitParam(name = "name", value = "业务类型中文名称", paramType = "query", dataType = "string"),
        @ApiImplicitParam(name = "tableName", value = "业务类型数据库表名", paramType = "query", dataType = "string"),
    })
    @ApiOperationSupport(order = 3)
    @ApiOperation(value = "查询列表", notes = "传入查询")
    public R<IPage<BtmTypeVO>> parentList(@ApiIgnore @RequestParam Map<String, Object> condition, Query query) {
        IPage<BtmTypeVO> pageVO = new Page<>();
        IPage<BtmType> page = btmTypeService.page(Condition.getPage(query), Condition.getQueryWrapper(condition, BtmType.class).lambda().orderByAsc(BtmType::getId));
        BeanUtil.copy(page, pageVO);
        pageVO.setRecords(BtmTypeWrapper.build().listEntityVO(page.getRecords()));
        return R.data(pageVO);
    }
 
 
    /**
     * 新增或修改
     *
     * @param dto 元数据页面传输对象
     * @return 执行结果
     */
    @PostMapping("/submit/{auto}")
    @ApiOperationSupport(order = 4)
    @ApiOperation(value = "新增或修改", notes = "传入业务类型对象")
    public R submit(@Valid @RequestBody BtmTypeDTO dto,@PathVariable(value = "auto") boolean auto) {
        CacheUtil.clear(OmdCacheConstant.BTM_CACHE);
        return btmTypeService.submit(dto,auto);
    }
 
    /**
     * 删除
     *
     * @param ids 主键集合
     * @return 执行结果
     */
    @PostMapping("/remove")
    @ApiOperationSupport(order = 5)
    @ApiOperation(value = "删除", notes = "主键集合")
    public R remove(@ApiParam(value = "主键集合", required = true) @RequestParam String ids) {
        CacheUtil.clear(OmdCacheConstant.BTM_CACHE);
        List<String> oidList = new ArrayList<>();
        if (ids.contains(",")) {
            oidList.addAll(Func.toStrList(",", ids));
        } else {
            oidList.add(ids);
        }
        return R.status(btmTypeService.removeBatchByIds(oidList));
    }
 
    /**
     * 获取领域值
     */
    @GetMapping("/domain")
    @ApiOperationSupport(order = 6)
    @ApiOperation(value = "获取领域值")
    public R<List<DomainVO>> getDomain(){
        try {
            return R.data(DomainRepeater.getDomain());
        } catch (NacosException e) {
            return R.fail(e.getErrMsg());
        }
    }
 
    /**
     * 按domain分组,查询业务类型的树形结构
     */
    @GetMapping("/tree-domain")
    @ApiOperationSupport(order = 7)
    @ApiOperation(value = "业务类型树形结构", notes = "业务类型树形结构")
    public R<List<BtmTreeVO>> treeDomain(){
        return R.data(btmTypeService.treeDomain());
    }
 
    /**
     * 从数据库表中获取
     * @param domain 领域值
     * @return 读取结果
     */
    @GetMapping("/get-from-table")
    @ApiOperation(value = "从数据库表中读取",notes = "从数据库表中读取")
    @ApiOperationSupport(order = 8)
    public R<List<BtmTypeVO>> getFromTable(String domain){
        return R.data(btmTypeService.getFromTable(domain));
    }
 
    /**
     * 数据库选择的表保存为业务类型
     * @param btmTypeDTOList 页面传输对象
     * @return 执行结果
     */
    @PostMapping("/save-from-table/{domain}")
    @ApiOperation(value = "从数据库中保存",notes = "从数据库中保存")
    @ApiOperationSupport(order = 9)
    public R saveFromTable(@RequestBody List<BtmTypeDTO> btmTypeDTOList,@PathVariable(value = "domain") String domain){
        // 数据库表不能重复
        Set<String> tableNames = btmTypeDTOList.stream().map(BtmTypeDTO::getTableName).filter(StringUtils::isNotBlank).collect(Collectors.toSet());
        long count = btmTypeService.count(Wrappers.<BtmType>query().lambda().in(BtmType::getTableName,tableNames));
        if (count > 0){
            return R.fail("所选表在业务类型中已存在");
        }
        // 业务类型不能重复
        btmTypeDTOList = btmTypeDTOList.stream().peek(s -> {
            String id;
            String tableName = s.getTableName();
            if (tableName.contains(StringPool.UNDERSCORE)) {
                List<String> strList = Arrays.asList(tableName.split(StringPool.UNDERSCORE));
                id = strList.get(strList.size() - 1);
            } else {
                id = tableName;
            }
            s.setId(id.toLowerCase());
        }).collect(Collectors.toList());
        List<String> btmTypeIdList = btmTypeDTOList.stream().map(BtmTypeDTO::getId).collect(Collectors.toList());
 
        long countId = btmTypeService.count(Wrappers.<BtmType>query().lambda().in(BtmType::getId, btmTypeIdList));
        if (countId > 0){
            return R.fail("所选表与已存在业务类型冲突");
        }
        return R.data(btmTypeService.saveFromTable(btmTypeDTOList,domain));
    }
}