feat(wms): 添加考勤记录管理功能
- 新增 AttendanceRecords 实体类定义数据库表结构 - 创建 AttendanceRecordsBo 业务对象用于数据传输 - 实现 AttendanceRecordsController 提供 REST API 接口 - 开发 AttendanceRecordsMapper 数据访问层接口 - 实现 AttendanceRecordsServiceImpl 业务逻辑服务 - 定义 AttendanceRecordsVo 视图对象用于数据展示 - 集成 Excel 导出功能支持考勤数据批量导出 - 添加分页查询、条件筛选等数据检索功能
This commit is contained in:
@@ -0,0 +1,71 @@
|
||||
package com.klp.controller;
|
||||
|
||||
import java.util.List;
|
||||
import java.util.Arrays;
|
||||
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import javax.servlet.http.HttpServletResponse;
|
||||
import javax.validation.constraints.*;
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import com.klp.common.annotation.RepeatSubmit;
|
||||
import com.klp.common.annotation.Log;
|
||||
import com.klp.common.core.controller.BaseController;
|
||||
import com.klp.common.core.domain.PageQuery;
|
||||
import com.klp.common.core.domain.R;
|
||||
import com.klp.common.core.validate.AddGroup;
|
||||
import com.klp.common.core.validate.EditGroup;
|
||||
import com.klp.common.enums.BusinessType;
|
||||
import com.klp.common.utils.poi.ExcelUtil;
|
||||
import com.klp.domain.vo.AttendanceRecordsVo;
|
||||
import com.klp.domain.bo.AttendanceRecordsBo;
|
||||
import com.klp.service.IAttendanceRecordsService;
|
||||
import com.klp.common.core.page.TableDataInfo;
|
||||
|
||||
@Validated
|
||||
@RequiredArgsConstructor
|
||||
@RestController
|
||||
@RequestMapping("/wms/attendanceRecords")
|
||||
public class AttendanceRecordsController extends BaseController {
|
||||
|
||||
private final IAttendanceRecordsService iAttendanceRecordsService;
|
||||
|
||||
@GetMapping("/list")
|
||||
public TableDataInfo<AttendanceRecordsVo> list(AttendanceRecordsBo bo, PageQuery pageQuery) {
|
||||
return iAttendanceRecordsService.queryPageList(bo, pageQuery);
|
||||
}
|
||||
|
||||
@Log(title = "打卡记录", businessType = BusinessType.EXPORT)
|
||||
@PostMapping("/export")
|
||||
public void export(AttendanceRecordsBo bo, HttpServletResponse response) {
|
||||
List<AttendanceRecordsVo> list = iAttendanceRecordsService.queryList(bo);
|
||||
ExcelUtil.exportExcel(list, "打卡记录", AttendanceRecordsVo.class, response);
|
||||
}
|
||||
|
||||
@GetMapping("/{id}")
|
||||
public R<AttendanceRecordsVo> getInfo(@NotNull(message = "主键不能为空")
|
||||
@PathVariable Integer id) {
|
||||
return R.ok(iAttendanceRecordsService.queryById(id));
|
||||
}
|
||||
|
||||
@Log(title = "打卡记录", businessType = BusinessType.INSERT)
|
||||
@RepeatSubmit()
|
||||
@PostMapping()
|
||||
public R<Void> add(@Validated(AddGroup.class) @RequestBody AttendanceRecordsBo bo) {
|
||||
return toAjax(iAttendanceRecordsService.insertByBo(bo));
|
||||
}
|
||||
|
||||
@Log(title = "打卡记录", businessType = BusinessType.UPDATE)
|
||||
@RepeatSubmit()
|
||||
@PutMapping()
|
||||
public R<Void> edit(@Validated(EditGroup.class) @RequestBody AttendanceRecordsBo bo) {
|
||||
return toAjax(iAttendanceRecordsService.updateByBo(bo));
|
||||
}
|
||||
|
||||
@Log(title = "打卡记录", businessType = BusinessType.DELETE)
|
||||
@DeleteMapping("/{ids}")
|
||||
public R<Void> remove(@NotEmpty(message = "主键不能为空")
|
||||
@PathVariable Integer[] ids) {
|
||||
return toAjax(iAttendanceRecordsService.deleteWithValidByIds(Arrays.asList(ids), true));
|
||||
}
|
||||
}
|
||||
36
klp-wms/src/main/java/com/klp/domain/AttendanceRecords.java
Normal file
36
klp-wms/src/main/java/com/klp/domain/AttendanceRecords.java
Normal file
@@ -0,0 +1,36 @@
|
||||
package com.klp.domain;
|
||||
|
||||
import com.baomidou.mybatisplus.annotation.TableId;
|
||||
import com.baomidou.mybatisplus.annotation.TableName;
|
||||
import lombok.Data;
|
||||
|
||||
import java.io.Serializable;
|
||||
import java.util.Date;
|
||||
|
||||
@Data
|
||||
@TableName("attendance_records")
|
||||
public class AttendanceRecords implements Serializable {
|
||||
|
||||
private static final long serialVersionUID = 1L;
|
||||
|
||||
@TableId(value = "id")
|
||||
private Integer id;
|
||||
|
||||
private String pin;
|
||||
|
||||
private String ename;
|
||||
|
||||
private String deptname;
|
||||
|
||||
private String sn;
|
||||
|
||||
private Date checktime;
|
||||
|
||||
private Integer verify;
|
||||
|
||||
private Integer stateno;
|
||||
|
||||
private String state;
|
||||
|
||||
private Date createdAt;
|
||||
}
|
||||
@@ -0,0 +1,37 @@
|
||||
package com.klp.domain.bo;
|
||||
|
||||
import lombok.Data;
|
||||
import lombok.EqualsAndHashCode;
|
||||
import org.springframework.format.annotation.DateTimeFormat;
|
||||
|
||||
import java.util.Date;
|
||||
import com.fasterxml.jackson.annotation.JsonFormat;
|
||||
|
||||
@Data
|
||||
@EqualsAndHashCode(callSuper = false)
|
||||
public class AttendanceRecordsBo {
|
||||
|
||||
private Integer id;
|
||||
|
||||
private String pin;
|
||||
|
||||
private String ename;
|
||||
|
||||
private String deptname;
|
||||
|
||||
private String sn;
|
||||
|
||||
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
|
||||
@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
|
||||
private Date checktimeStart;
|
||||
|
||||
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
|
||||
@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
|
||||
private Date checktimeEnd;
|
||||
|
||||
private Integer verify;
|
||||
|
||||
private Integer stateno;
|
||||
|
||||
private String state;
|
||||
}
|
||||
@@ -0,0 +1,47 @@
|
||||
package com.klp.domain.vo;
|
||||
|
||||
import lombok.Data;
|
||||
|
||||
import java.util.Date;
|
||||
import com.fasterxml.jackson.annotation.JsonFormat;
|
||||
import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
|
||||
import com.alibaba.excel.annotation.ExcelProperty;
|
||||
|
||||
@Data
|
||||
@ExcelIgnoreUnannotated
|
||||
public class AttendanceRecordsVo {
|
||||
|
||||
private static final long serialVersionUID = 1L;
|
||||
|
||||
@ExcelProperty(value = "主键ID")
|
||||
private Integer id;
|
||||
|
||||
@ExcelProperty(value = "人员编号")
|
||||
private String pin;
|
||||
|
||||
@ExcelProperty(value = "姓名")
|
||||
private String ename;
|
||||
|
||||
@ExcelProperty(value = "部门名称")
|
||||
private String deptname;
|
||||
|
||||
@ExcelProperty(value = "设备编号")
|
||||
private String sn;
|
||||
|
||||
@ExcelProperty(value = "打卡时间")
|
||||
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
|
||||
private Date checktime;
|
||||
|
||||
@ExcelProperty(value = "验证方式")
|
||||
private Integer verify;
|
||||
|
||||
@ExcelProperty(value = "状态编号")
|
||||
private Integer stateno;
|
||||
|
||||
@ExcelProperty(value = "状态")
|
||||
private String state;
|
||||
|
||||
@ExcelProperty(value = "创建时间")
|
||||
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
|
||||
private Date createdAt;
|
||||
}
|
||||
@@ -0,0 +1,10 @@
|
||||
package com.klp.mapper;
|
||||
|
||||
import com.klp.domain.AttendanceRecords;
|
||||
import com.klp.domain.vo.AttendanceRecordsVo;
|
||||
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
|
||||
import org.apache.ibatis.annotations.Mapper;
|
||||
|
||||
@Mapper
|
||||
public interface AttendanceRecordsMapper extends BaseMapper<AttendanceRecords> {
|
||||
}
|
||||
@@ -0,0 +1,25 @@
|
||||
package com.klp.service;
|
||||
|
||||
import com.klp.domain.AttendanceRecords;
|
||||
import com.klp.domain.vo.AttendanceRecordsVo;
|
||||
import com.klp.domain.bo.AttendanceRecordsBo;
|
||||
import com.klp.common.core.page.TableDataInfo;
|
||||
import com.klp.common.core.domain.PageQuery;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
|
||||
public interface IAttendanceRecordsService {
|
||||
|
||||
AttendanceRecordsVo queryById(Integer id);
|
||||
|
||||
TableDataInfo<AttendanceRecordsVo> queryPageList(AttendanceRecordsBo bo, PageQuery pageQuery);
|
||||
|
||||
List<AttendanceRecordsVo> queryList(AttendanceRecordsBo bo);
|
||||
|
||||
Boolean insertByBo(AttendanceRecordsBo bo);
|
||||
|
||||
Boolean updateByBo(AttendanceRecordsBo bo);
|
||||
|
||||
Boolean deleteWithValidByIds(Collection<Integer> ids, Boolean isValid);
|
||||
}
|
||||
@@ -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