xiangpei
2025-04-18 ccadf9480d4e6a9dcc227a2a0b1f9ae0612e36fd
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
package com.monkeylessey.sys.service.impl;
 
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.conditions.query.LambdaQueryChainWrapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.monkeylessey.sys.domain.entity.SysDictData;
import com.monkeylessey.sys.domain.form.SysDictDataForm;
import com.monkeylessey.sys.domain.query.SysDictDataQuery;
import com.monkeylessey.sys.domain.vo.SysDictDataVO;
import com.monkeylessey.sys.mapper.SysDictDataMapper;
import com.monkeylessey.response.Result;
import com.monkeylessey.sys.service.SysDictDataService;
import com.monkeylessey.framework.utils.SecurityUtil;
import com.monkeylessey.utils.PageUtil;
import lombok.RequiredArgsConstructor;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.BeanUtils;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
 
import java.util.ArrayList;
import java.util.List;
import java.util.Objects;
import java.util.stream.Collectors;
 
/**
 * 字典数据表 服务实现类
 *
 * @author 向培
 * @since 2022-05-29
 */
@Service
@RequiredArgsConstructor
public class SysDictDataServiceImpl extends ServiceImpl<SysDictDataMapper, SysDictData> implements SysDictDataService {
 
    private final SysDictDataMapper sysDictDataMapper;
 
    @Override
    public Result addSysDictData(SysDictDataForm form) {
        SysDictData entity = SysDictDataForm.getSysDictData(null, form);
        String s = SecurityUtil.getCurrentUserName();
        entity.setCreateBy(s);
        try {
            int insert = baseMapper.insert(entity);
            return Result.ok("添加成功").data(insert);
        } catch (Exception e) {
            e.printStackTrace();
            return Result.error("添加失败");
        }
    }
 
    @Override
    public Result editSysDictData(SysDictDataForm form) {
        SysDictData entity = SysDictDataForm.getSysDictData(null, form);
        String s = SecurityUtil.getCurrentUserName();
        entity.setUpdateBy(s);
        try {
            int i = baseMapper.updateById(entity);
            return Result.ok("修改成功").data(i);
        } catch (Exception e) {
            e.printStackTrace();
            return Result.error("修改失败");
        }
    }
 
    @Override
    public Result deleteSysDictDataById(String id) {
        try {
            int i = baseMapper.deleteById(id);
            return Result.ok("删除成功").data(i);
        } catch (Exception e) {
            e.printStackTrace();
            return Result.error("删除失败");
        }
    }
 
    @Override
    @Transactional(rollbackFor = Exception.class)
    public Result deleteSysDictDataByIds(List<String> ids) {
        return Result.ok("操作成功").data(baseMapper.deleteBatchIds(ids));
    }
 
    @Override
    public Result getSysDictDataByPage(SysDictDataQuery query) {
        List<SysDictDataVO> vos = new ArrayList<>();
        Long total = 0L;
        try {
            IPage<SysDictData> page = PageUtil.getPage(query, SysDictData.class);
            new LambdaQueryChainWrapper<>(this.baseMapper).page(page);
            vos = page.getRecords().stream()
                    .map(sysDictData -> SysDictDataVO.getVoByEntity(sysDictData, null))
                    .collect(Collectors.toList());
            total = page.getTotal();
        } catch (Exception e) {
            e.printStackTrace();
        }
        return Result.ok().data(vos).total(total);
    }
 
    @Override
    public Result getSysDictDataById(String id) {
        SysDictData entity = baseMapper.selectById(id);
        SysDictDataVO vo = new SysDictDataVO();
        BeanUtils.copyProperties(entity, vo);
        return Result.ok("").data(vo);
    }
 
    @Override
    public Result getSysDictDataByType(Integer dictTypeId, Page page, String keyword) {
        new LambdaQueryChainWrapper<>(this.baseMapper)
                .eq(Objects.nonNull(dictTypeId), SysDictData::getDictTypeId, dictTypeId)
                .like(StringUtils.isNotEmpty(keyword), SysDictData::getDictLabel, keyword)
                .page(page);
        return Result.ok().data(page.getRecords()).total(page.getTotal());
    }
}