feat(oa): 考勤记录查询支持导出功能并优化相关接口
- 移除了考勤记录相关接口的权限注解 - 新增了考勤记录的自定义查询方法 - 添加了昵称字段到考勤记录的 VO 类 - 更新了 mapper 和 XML 文件以支持新的查询功能
This commit is contained in:
@@ -42,7 +42,6 @@ public class GearAttendanceRecordController extends BaseController {
|
|||||||
/**
|
/**
|
||||||
* 查询考勤(含考勤/加班/出差)列表
|
* 查询考勤(含考勤/加班/出差)列表
|
||||||
*/
|
*/
|
||||||
@SaCheckPermission("oa:attendanceRecord:list")
|
|
||||||
@GetMapping("/list")
|
@GetMapping("/list")
|
||||||
public TableDataInfo<GearAttendanceRecordVo> list(GearAttendanceRecordBo bo, PageQuery pageQuery) {
|
public TableDataInfo<GearAttendanceRecordVo> list(GearAttendanceRecordBo bo, PageQuery pageQuery) {
|
||||||
return iGearAttendanceRecordService.queryPageList(bo, pageQuery);
|
return iGearAttendanceRecordService.queryPageList(bo, pageQuery);
|
||||||
@@ -51,7 +50,6 @@ public class GearAttendanceRecordController extends BaseController {
|
|||||||
/**
|
/**
|
||||||
* 导出考勤(含考勤/加班/出差)列表
|
* 导出考勤(含考勤/加班/出差)列表
|
||||||
*/
|
*/
|
||||||
@SaCheckPermission("oa:attendanceRecord:export")
|
|
||||||
@Log(title = "考勤(含考勤/加班/出差)", businessType = BusinessType.EXPORT)
|
@Log(title = "考勤(含考勤/加班/出差)", businessType = BusinessType.EXPORT)
|
||||||
@PostMapping("/export")
|
@PostMapping("/export")
|
||||||
public void export(GearAttendanceRecordBo bo, HttpServletResponse response) {
|
public void export(GearAttendanceRecordBo bo, HttpServletResponse response) {
|
||||||
@@ -64,7 +62,6 @@ public class GearAttendanceRecordController extends BaseController {
|
|||||||
*
|
*
|
||||||
* @param recordId 主键
|
* @param recordId 主键
|
||||||
*/
|
*/
|
||||||
@SaCheckPermission("oa:attendanceRecord:query")
|
|
||||||
@GetMapping("/{recordId}")
|
@GetMapping("/{recordId}")
|
||||||
public R<GearAttendanceRecordVo> getInfo(@NotNull(message = "主键不能为空")
|
public R<GearAttendanceRecordVo> getInfo(@NotNull(message = "主键不能为空")
|
||||||
@PathVariable Long recordId) {
|
@PathVariable Long recordId) {
|
||||||
@@ -74,7 +71,6 @@ public class GearAttendanceRecordController extends BaseController {
|
|||||||
/**
|
/**
|
||||||
* 新增考勤(含考勤/加班/出差)
|
* 新增考勤(含考勤/加班/出差)
|
||||||
*/
|
*/
|
||||||
@SaCheckPermission("oa:attendanceRecord:add")
|
|
||||||
@Log(title = "考勤(含考勤/加班/出差)", businessType = BusinessType.INSERT)
|
@Log(title = "考勤(含考勤/加班/出差)", businessType = BusinessType.INSERT)
|
||||||
@RepeatSubmit()
|
@RepeatSubmit()
|
||||||
@PostMapping()
|
@PostMapping()
|
||||||
@@ -85,7 +81,6 @@ public class GearAttendanceRecordController extends BaseController {
|
|||||||
/**
|
/**
|
||||||
* 修改考勤(含考勤/加班/出差)
|
* 修改考勤(含考勤/加班/出差)
|
||||||
*/
|
*/
|
||||||
@SaCheckPermission("oa:attendanceRecord:edit")
|
|
||||||
@Log(title = "考勤(含考勤/加班/出差)", businessType = BusinessType.UPDATE)
|
@Log(title = "考勤(含考勤/加班/出差)", businessType = BusinessType.UPDATE)
|
||||||
@RepeatSubmit()
|
@RepeatSubmit()
|
||||||
@PutMapping()
|
@PutMapping()
|
||||||
@@ -98,7 +93,6 @@ public class GearAttendanceRecordController extends BaseController {
|
|||||||
*
|
*
|
||||||
* @param recordIds 主键串
|
* @param recordIds 主键串
|
||||||
*/
|
*/
|
||||||
@SaCheckPermission("oa:attendanceRecord:remove")
|
|
||||||
@Log(title = "考勤(含考勤/加班/出差)", businessType = BusinessType.DELETE)
|
@Log(title = "考勤(含考勤/加班/出差)", businessType = BusinessType.DELETE)
|
||||||
@DeleteMapping("/{recordIds}")
|
@DeleteMapping("/{recordIds}")
|
||||||
public R<Void> remove(@NotEmpty(message = "主键不能为空")
|
public R<Void> remove(@NotEmpty(message = "主键不能为空")
|
||||||
|
|||||||
@@ -71,5 +71,9 @@ public class GearAttendanceRecordVo {
|
|||||||
@ExcelProperty(value = "备注")
|
@ExcelProperty(value = "备注")
|
||||||
private String remark;
|
private String remark;
|
||||||
|
|
||||||
|
//昵称
|
||||||
|
@ExcelProperty(value = "姓名")
|
||||||
|
private String nickName;
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,8 +1,12 @@
|
|||||||
package com.gear.oa.mapper;
|
package com.gear.oa.mapper;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||||
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
||||||
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||||
import com.gear.oa.domain.GearAttendanceRecord;
|
import com.gear.oa.domain.GearAttendanceRecord;
|
||||||
import com.gear.oa.domain.vo.GearAttendanceRecordVo;
|
import com.gear.oa.domain.vo.GearAttendanceRecordVo;
|
||||||
import com.gear.common.core.mapper.BaseMapperPlus;
|
import com.gear.common.core.mapper.BaseMapperPlus;
|
||||||
|
import org.apache.ibatis.annotations.Param;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 考勤(含考勤/加班/出差)Mapper接口
|
* 考勤(含考勤/加班/出差)Mapper接口
|
||||||
@@ -12,4 +16,5 @@ import com.gear.common.core.mapper.BaseMapperPlus;
|
|||||||
*/
|
*/
|
||||||
public interface GearAttendanceRecordMapper extends BaseMapperPlus<GearAttendanceRecordMapper, GearAttendanceRecord, GearAttendanceRecordVo> {
|
public interface GearAttendanceRecordMapper extends BaseMapperPlus<GearAttendanceRecordMapper, GearAttendanceRecord, GearAttendanceRecordVo> {
|
||||||
|
|
||||||
|
Page<GearAttendanceRecordVo> selectVoPagePlus(Page<Object> build, @Param("ew") QueryWrapper<GearAttendanceRecord> lqw);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
package com.gear.oa.service.impl;
|
package com.gear.oa.service.impl;
|
||||||
|
|
||||||
import cn.hutool.core.bean.BeanUtil;
|
import cn.hutool.core.bean.BeanUtil;
|
||||||
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
||||||
import com.gear.common.utils.StringUtils;
|
import com.gear.common.utils.StringUtils;
|
||||||
import com.gear.common.core.page.TableDataInfo;
|
import com.gear.common.core.page.TableDataInfo;
|
||||||
import com.gear.common.core.domain.PageQuery;
|
import com.gear.common.core.domain.PageQuery;
|
||||||
@@ -44,11 +45,26 @@ public class GearAttendanceRecordServiceImpl implements IGearAttendanceRecordSer
|
|||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public TableDataInfo<GearAttendanceRecordVo> queryPageList(GearAttendanceRecordBo bo, PageQuery pageQuery) {
|
public TableDataInfo<GearAttendanceRecordVo> queryPageList(GearAttendanceRecordBo bo, PageQuery pageQuery) {
|
||||||
LambdaQueryWrapper<GearAttendanceRecord> lqw = buildQueryWrapper(bo);
|
QueryWrapper<GearAttendanceRecord> lqw = buildQueryWrapperPlus(bo);
|
||||||
Page<GearAttendanceRecordVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
|
Page<GearAttendanceRecordVo> result = baseMapper.selectVoPagePlus(pageQuery.build(), lqw);
|
||||||
return TableDataInfo.build(result);
|
return TableDataInfo.build(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private QueryWrapper<GearAttendanceRecord> buildQueryWrapperPlus(GearAttendanceRecordBo bo) {
|
||||||
|
Map<String, Object> params = bo.getParams();
|
||||||
|
QueryWrapper<GearAttendanceRecord> lqw = Wrappers.query();
|
||||||
|
// 使用表别名 ar 来构建查询条件
|
||||||
|
lqw.eq(StringUtils.isNotBlank(bo.getUserId()), "ar.user_id", bo.getUserId());
|
||||||
|
lqw.eq(bo.getRecordDate() != null, "ar.record_date", bo.getRecordDate());
|
||||||
|
lqw.eq(StringUtils.isNotBlank(bo.getRecordType()), "ar.record_type", bo.getRecordType());
|
||||||
|
lqw.eq(bo.getStartTime() != null, "ar.start_time", bo.getStartTime());
|
||||||
|
lqw.eq(bo.getEndTime() != null, "ar.end_time", bo.getEndTime());
|
||||||
|
lqw.eq(bo.getDurationHour() != null, "ar.duration_hour", bo.getDurationHour());
|
||||||
|
//逻辑删除
|
||||||
|
lqw.eq("ar.del_flag", "0");
|
||||||
|
return lqw;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 查询考勤(含考勤/加班/出差)列表
|
* 查询考勤(含考勤/加班/出差)列表
|
||||||
*/
|
*/
|
||||||
|
|||||||
@@ -20,6 +20,15 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
|||||||
<result property="delFlag" column="del_flag"/>
|
<result property="delFlag" column="del_flag"/>
|
||||||
<result property="remark" column="remark"/>
|
<result property="remark" column="remark"/>
|
||||||
</resultMap>
|
</resultMap>
|
||||||
|
<select id="selectVoPagePlus" resultType="com.gear.oa.domain.vo.GearAttendanceRecordVo">
|
||||||
|
select ar.record_id, ar.user_id, ar.record_date, ar.record_type, ar.start_time,
|
||||||
|
ar.end_time, ar.duration_hour, ar.status, ar.create_time, ar.create_by,
|
||||||
|
ar.update_time, ar.update_by, ar.del_flag, ar.remark,
|
||||||
|
u.nick_name AS nickName
|
||||||
|
from gear_attendance_record ar
|
||||||
|
left join gear_user u on ar.user_id = u.user_id
|
||||||
|
${ew.customSqlSegment}
|
||||||
|
</select>
|
||||||
|
|
||||||
|
|
||||||
</mapper>
|
</mapper>
|
||||||
|
|||||||
Reference in New Issue
Block a user