111
k94314517
2023-10-16 ca73a173f008c8d7a9d700bad897ca24fe2d2203
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
package doumeemes.service.business.impl;
 
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import doumeemes.core.model.PageData;
import doumeemes.core.model.PageWrap;
import doumeemes.core.utils.Utils;
import doumeemes.dao.business.CompanyLogMapper;
import doumeemes.dao.business.model.CompanyLog;
import doumeemes.dao.ext.CompanyLogExtMapper;
import doumeemes.service.business.CompanyLogService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.util.CollectionUtils;
 
import java.util.List;
 
/**
 * 企业信息变更记录Service实现
 * @author 江蹄蹄
 * @since 2023/06/15 13:49
 */
@Service
public class CompanyLogServiceImpl implements CompanyLogService {
 
    @Autowired
    private CompanyLogMapper companyLogMapper;
 
    @Autowired
    private CompanyLogExtMapper companyLogExtMapper;
 
    @Override
    public Integer create(CompanyLog companyLog) {
        companyLogMapper.insert(companyLog);
        return companyLog.getId();
    }
 
    @Override
    public void deleteById(Integer id) {
        companyLogMapper.deleteById(id);
    }
 
    @Override
    public void delete(CompanyLog companyLog) {
        UpdateWrapper<CompanyLog> deleteWrapper = new UpdateWrapper<>(companyLog);
        companyLogMapper.delete(deleteWrapper);
    }
 
    @Override
    public void deleteByIdInBatch(List<Integer> ids) {
        if (CollectionUtils.isEmpty(ids)) {
            return;
        }
        companyLogMapper.deleteBatchIds(ids);
    }
 
    @Override
    public void updateById(CompanyLog companyLog) {
        companyLogMapper.updateById(companyLog);
    }
 
    @Override
    public void updateByIdInBatch(List<CompanyLog> companyLogs) {
        if (CollectionUtils.isEmpty(companyLogs)) {
            return;
        }
        for (CompanyLog companyLog: companyLogs) {
            this.updateById(companyLog);
        }
    }
 
    @Override
    public CompanyLog findById(Integer id) {
        return companyLogMapper.selectById(id);
    }
 
    @Override
    public CompanyLog findOne(CompanyLog companyLog) {
        QueryWrapper<CompanyLog> wrapper = new QueryWrapper<>(companyLog);
        return companyLogMapper.selectOne(wrapper);
    }
 
    @Override
    public List<CompanyLog> findList(CompanyLog companyLog) {
        QueryWrapper<CompanyLog> wrapper = new QueryWrapper<>(companyLog);
        return companyLogMapper.selectList(wrapper);
    }
 
    @Override
    public PageData<CompanyLog> findPage(PageWrap<CompanyLog> pageWrap) {
        IPage<CompanyLog> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity());
        QueryWrapper<CompanyLog> queryWrapper = new QueryWrapper<>();
        Utils.MP.blankToNull(pageWrap.getModel());
        queryWrapper.lambda()
                .eq(pageWrap.getModel().getId() != null, CompanyLog::getId, pageWrap.getModel().getId())
                .eq(pageWrap.getModel().getDeleted() != null, CompanyLog::getDeleted, pageWrap.getModel().getDeleted())
                .eq(pageWrap.getModel().getCreateUser() != null, CompanyLog::getCreateUser, pageWrap.getModel().getCreateUser())
                .ge(pageWrap.getModel().getCreateTime() != null, CompanyLog::getCreateTime, Utils.Date.getStart(pageWrap.getModel().getCreateTime()))
                .le(pageWrap.getModel().getCreateTime() != null, CompanyLog::getCreateTime, Utils.Date.getEnd(pageWrap.getModel().getCreateTime()))
                .eq(pageWrap.getModel().getUpdateUser() != null, CompanyLog::getUpdateUser, pageWrap.getModel().getUpdateUser())
                .ge(pageWrap.getModel().getUpdateTime() != null, CompanyLog::getUpdateTime, Utils.Date.getStart(pageWrap.getModel().getUpdateTime()))
                .le(pageWrap.getModel().getUpdateTime() != null, CompanyLog::getUpdateTime, Utils.Date.getEnd(pageWrap.getModel().getUpdateTime()))
                .eq(pageWrap.getModel().getRemark() != null, CompanyLog::getRemark, pageWrap.getModel().getRemark())
                .eq(pageWrap.getModel().getCompanyId() != null, CompanyLog::getCompanyId, pageWrap.getModel().getCompanyId())
                .eq(pageWrap.getModel().getUpdateType() != null, CompanyLog::getUpdateType, pageWrap.getModel().getUpdateType())
                .eq(pageWrap.getModel().getDetail() != null, CompanyLog::getDetail, pageWrap.getModel().getDetail())
        ;
        for(PageWrap.SortData sortData: pageWrap.getSorts()) {
            if (sortData.getDirection().equalsIgnoreCase(PageWrap.DESC)) {
                queryWrapper.orderByDesc(sortData.getProperty());
            } else {
                queryWrapper.orderByAsc(sortData.getProperty());
            }
        }
        return PageData.from(companyLogMapper.selectPage(page, queryWrapper));
    }
 
 
    @Override
    public PageData<CompanyLog> findCompanyLogPage(PageWrap<CompanyLog> pageWrap) {
 
        IPage<CompanyLog> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity());
        Utils.MP.blankToNull(pageWrap.getModel());
        IPage<CompanyLog> companyLogIPage = companyLogExtMapper.selectPage(page, pageWrap.getModel().getUserName(), pageWrap.getModel().getUpdateType());
 
        if (!CollectionUtils.isEmpty(companyLogIPage.getRecords())){
            companyLogIPage.getRecords().forEach(s->s.setShortName(s.getCompanyName()));
        }
        return PageData.from(companyLogIPage);
    }
 
    @Override
    public long count(CompanyLog companyLog) {
        QueryWrapper<CompanyLog> wrapper = new QueryWrapper<>(companyLog);
        return companyLogMapper.selectCount(wrapper);
    }
}