feat(wms): 添加考勤记录管理功能
- 新增 AttendanceRecords 实体类定义数据库表结构 - 创建 AttendanceRecordsBo 业务对象用于数据传输 - 实现 AttendanceRecordsController 提供 REST API 接口 - 开发 AttendanceRecordsMapper 数据访问层接口 - 实现 AttendanceRecordsServiceImpl 业务逻辑服务 - 定义 AttendanceRecordsVo 视图对象用于数据展示 - 集成 Excel 导出功能支持考勤数据批量导出 - 添加分页查询、条件筛选等数据检索功能
This commit is contained in:
@@ -0,0 +1,84 @@
|
||||
package com.klp.service.impl;
|
||||
|
||||
import cn.hutool.core.bean.BeanUtil;
|
||||
import com.klp.common.core.page.TableDataInfo;
|
||||
import com.klp.common.core.domain.PageQuery;
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
||||
import com.klp.common.utils.StringUtils;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.springframework.stereotype.Service;
|
||||
import com.klp.domain.bo.AttendanceRecordsBo;
|
||||
import com.klp.domain.vo.AttendanceRecordsVo;
|
||||
import com.klp.domain.AttendanceRecords;
|
||||
import com.klp.mapper.AttendanceRecordsMapper;
|
||||
import com.klp.service.IAttendanceRecordsService;
|
||||
|
||||
import java.util.List;
|
||||
import java.util.Collection;
|
||||
|
||||
@RequiredArgsConstructor
|
||||
@Service
|
||||
public class AttendanceRecordsServiceImpl implements IAttendanceRecordsService {
|
||||
|
||||
private final AttendanceRecordsMapper baseMapper;
|
||||
|
||||
@Override
|
||||
public AttendanceRecordsVo queryById(Integer id) {
|
||||
AttendanceRecords entity = baseMapper.selectById(id);
|
||||
return BeanUtil.toBean(entity, AttendanceRecordsVo.class);
|
||||
}
|
||||
|
||||
@Override
|
||||
public TableDataInfo<AttendanceRecordsVo> queryPageList(AttendanceRecordsBo bo, PageQuery pageQuery) {
|
||||
LambdaQueryWrapper<AttendanceRecords> lqw = buildQueryWrapper(bo);
|
||||
Page<AttendanceRecords> page = baseMapper.selectPage(pageQuery.build(), lqw);
|
||||
List<AttendanceRecordsVo> voList = BeanUtil.copyToList(page.getRecords(), AttendanceRecordsVo.class);
|
||||
Page<AttendanceRecordsVo> voPage = new Page<>(page.getCurrent(), page.getSize(), page.getTotal());
|
||||
voPage.setRecords(voList);
|
||||
return TableDataInfo.build(voPage);
|
||||
}
|
||||
|
||||
@Override
|
||||
public List<AttendanceRecordsVo> queryList(AttendanceRecordsBo bo) {
|
||||
LambdaQueryWrapper<AttendanceRecords> lqw = buildQueryWrapper(bo);
|
||||
List<AttendanceRecords> list = baseMapper.selectList(lqw);
|
||||
return BeanUtil.copyToList(list, AttendanceRecordsVo.class);
|
||||
}
|
||||
|
||||
private LambdaQueryWrapper<AttendanceRecords> buildQueryWrapper(AttendanceRecordsBo bo) {
|
||||
LambdaQueryWrapper<AttendanceRecords> lqw = Wrappers.lambdaQuery();
|
||||
lqw.eq(bo.getId() != null, AttendanceRecords::getId, bo.getId());
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getPin()), AttendanceRecords::getPin, bo.getPin());
|
||||
lqw.like(StringUtils.isNotBlank(bo.getEname()), AttendanceRecords::getEname, bo.getEname());
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getDeptname()), AttendanceRecords::getDeptname, bo.getDeptname());
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getSn()), AttendanceRecords::getSn, bo.getSn());
|
||||
lqw.ge(bo.getChecktimeStart() != null, AttendanceRecords::getChecktime, bo.getChecktimeStart());
|
||||
lqw.le(bo.getChecktimeEnd() != null, AttendanceRecords::getChecktime, bo.getChecktimeEnd());
|
||||
lqw.eq(bo.getVerify() != null, AttendanceRecords::getVerify, bo.getVerify());
|
||||
lqw.eq(bo.getStateno() != null, AttendanceRecords::getStateno, bo.getStateno());
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getState()), AttendanceRecords::getState, bo.getState());
|
||||
lqw.orderByDesc(AttendanceRecords::getChecktime);
|
||||
return lqw;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Boolean insertByBo(AttendanceRecordsBo bo) {
|
||||
AttendanceRecords add = BeanUtil.toBean(bo, AttendanceRecords.class);
|
||||
return baseMapper.insert(add) > 0;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Boolean updateByBo(AttendanceRecordsBo bo) {
|
||||
AttendanceRecords update = BeanUtil.toBean(bo, AttendanceRecords.class);
|
||||
return baseMapper.updateById(update) > 0;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Boolean deleteWithValidByIds(Collection<Integer> ids, Boolean isValid) {
|
||||
if (isValid) {
|
||||
}
|
||||
return baseMapper.deleteBatchIds(ids) > 0;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user