oa初步完成
This commit is contained in:
@@ -1,5 +1,6 @@
|
||||
package com.ruoyi.oa.service;
|
||||
|
||||
import com.ruoyi.oa.domain.LaborCostData;
|
||||
import com.ruoyi.oa.domain.vo.SysOaAttendanceVo;
|
||||
import com.ruoyi.oa.domain.bo.SysOaAttendanceBo;
|
||||
import com.ruoyi.common.core.page.TableDataInfo;
|
||||
@@ -7,6 +8,7 @@ import com.ruoyi.common.core.domain.PageQuery;
|
||||
import com.ruoyi.oa.domain.vo.SysUserVo;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.Date;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
@@ -47,7 +49,25 @@ public interface ISysOaAttendanceService {
|
||||
*/
|
||||
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
|
||||
|
||||
/**
|
||||
* 工人列表
|
||||
* @param bo
|
||||
* @return
|
||||
*/
|
||||
List<SysUserVo> workerList(SysOaAttendanceBo bo);
|
||||
|
||||
/**
|
||||
* 批量插入
|
||||
* @param bo
|
||||
* @return
|
||||
*/
|
||||
int insertBatch(SysOaAttendanceBo bo);
|
||||
|
||||
/**
|
||||
* 人力成本计算接口
|
||||
*
|
||||
* @param time 时间
|
||||
*/
|
||||
List<LaborCostData> workerCalc(Date time);
|
||||
|
||||
}
|
||||
|
||||
@@ -49,4 +49,6 @@ public interface ISysOaProjectService {
|
||||
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
|
||||
|
||||
TableDataInfo<SysOaOutWarehouseListVo> queryOutWarePageList(SysOaOutWarehouseBo bo, PageQuery pageQuery);
|
||||
|
||||
|
||||
}
|
||||
|
||||
@@ -6,12 +6,15 @@ import com.ruoyi.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.ruoyi.common.utils.DateUtils;
|
||||
import com.ruoyi.oa.domain.LaborCostData;
|
||||
import com.ruoyi.oa.domain.vo.SysOaProjectVo;
|
||||
import com.ruoyi.oa.domain.vo.SysUserVo;
|
||||
import com.ruoyi.oa.service.ISysOaProjectService;
|
||||
import com.ruoyi.system.mapper.SysUserRoleMapper;
|
||||
import com.ruoyi.system.service.ISysUserService;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.stereotype.Service;
|
||||
import com.ruoyi.oa.domain.bo.SysOaAttendanceBo;
|
||||
@@ -22,6 +25,7 @@ import com.ruoyi.oa.service.ISysOaAttendanceService;
|
||||
|
||||
import java.time.LocalDate;
|
||||
import java.util.*;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
/**
|
||||
* 人员考勤Service业务层处理
|
||||
@@ -29,6 +33,7 @@ import java.util.*;
|
||||
* @author hdka
|
||||
* @date 2024-11-05
|
||||
*/
|
||||
@Slf4j
|
||||
@RequiredArgsConstructor
|
||||
@Service
|
||||
public class SysOaAttendanceServiceImpl implements ISysOaAttendanceService {
|
||||
@@ -182,4 +187,64 @@ public class SysOaAttendanceServiceImpl implements ISysOaAttendanceService {
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* 计算人力成本
|
||||
*
|
||||
* @param time 月份
|
||||
* @return
|
||||
*/
|
||||
@Override
|
||||
public List<LaborCostData> workerCalc(Date time) {
|
||||
|
||||
String firstDay = DateUtils.parseDateToStr("yyyy-MM-01", time);
|
||||
|
||||
String format = "yyyy-MM-";
|
||||
// 计算某月的天数
|
||||
Calendar calendar = Calendar.getInstance();
|
||||
calendar.setTime(time);
|
||||
String dateLength = String.valueOf(calendar.getActualMaximum(Calendar.DAY_OF_MONTH));
|
||||
// 将字符串拼接
|
||||
format +=dateLength;
|
||||
String lastDay = DateUtils.parseDateToStr(format, time);
|
||||
// 查询所有的工人
|
||||
List<Long> userIds = sysUserRoleMapper.selectUserIdsByRoleId(1852970465740505090L);
|
||||
|
||||
|
||||
List<LaborCostData> costDataList = new ArrayList<>();
|
||||
for (Long userId : userIds) {
|
||||
SysUserVo sysUser = BeanUtil.toBean(sysUserService.selectUserById(userId), SysUserVo.class);
|
||||
SysOaAttendanceVo sysOaAttendanceVo = new SysOaAttendanceVo();
|
||||
sysOaAttendanceVo.setUserId(sysUser.getUserId());
|
||||
|
||||
// 查询某月记录
|
||||
List<SysOaAttendanceVo> sysOaAttendanceVos = baseMapper.selectVoListAndTime(userId, DateUtils.parseDate(firstDay),DateUtils.parseDate(lastDay));
|
||||
|
||||
List<SysOaProjectVo> projectVos = new ArrayList<>();
|
||||
|
||||
Double workTimes = 0.0;
|
||||
System.out.println(sysOaAttendanceVos);
|
||||
for (SysOaAttendanceVo oaAttendanceVo : sysOaAttendanceVos) {
|
||||
SysOaProjectVo sysOaProjectVo = projectService.queryById(oaAttendanceVo.getProjectId());
|
||||
oaAttendanceVo.setColor(sysOaProjectVo.getColor());
|
||||
oaAttendanceVo.setSysOaProjectVo(sysOaProjectVo);
|
||||
oaAttendanceVo.setProjectName(sysOaProjectVo.getProjectName());
|
||||
projectVos.add(sysOaProjectVo);
|
||||
workTimes+=oaAttendanceVo.getWorkTimes();
|
||||
|
||||
}
|
||||
projectVos.stream().distinct().collect(Collectors.toList());
|
||||
LaborCostData laborCostData = new LaborCostData();
|
||||
laborCostData.setProjects(projectVos);
|
||||
laborCostData.setAttendances(sysOaAttendanceVos);
|
||||
laborCostData.setSysUser(sysUser);
|
||||
laborCostData.setWorkTimes(workTimes);
|
||||
costDataList.add(laborCostData);
|
||||
}
|
||||
|
||||
|
||||
|
||||
return costDataList;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -15,11 +15,14 @@ import com.ruoyi.oa.domain.SysOaWarehouse;
|
||||
import com.ruoyi.oa.domain.bo.SysOaOutWarehouseBo2;
|
||||
import com.ruoyi.oa.domain.bo.SysOaOutWarehouseBoList;
|
||||
import com.ruoyi.oa.domain.vo.SysOaOutWarehouseListVo;
|
||||
import com.ruoyi.oa.domain.vo.SysOaProjectVo;
|
||||
import com.ruoyi.oa.domain.vo.SysOaWarehouseVo;
|
||||
import com.ruoyi.oa.mapper.SysOaProjectMapper;
|
||||
import com.ruoyi.oa.mapper.SysOaWarehouseMapper;
|
||||
import com.ruoyi.oa.service.ISysOaWarehouseService;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
import org.apache.catalina.security.SecurityUtil;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.stereotype.Service;
|
||||
import com.ruoyi.oa.domain.bo.SysOaOutWarehouseBo;
|
||||
@@ -28,10 +31,7 @@ import com.ruoyi.oa.domain.SysOaOutWarehouse;
|
||||
import com.ruoyi.oa.mapper.SysOaOutWarehouseMapper;
|
||||
import com.ruoyi.oa.service.ISysOaOutWarehouseService;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Collection;
|
||||
import java.util.*;
|
||||
|
||||
import static cn.hutool.core.bean.BeanUtil.*;
|
||||
|
||||
@@ -61,7 +61,16 @@ public class SysOaOutWarehouseServiceImpl implements ISysOaOutWarehouseService {
|
||||
*/
|
||||
@Override
|
||||
public SysOaOutWarehouseVo queryById(Long id){
|
||||
return baseMapper.selectVoById(id);
|
||||
SysOaOutWarehouseVo sysOaOutWarehouseVo = baseMapper.selectVoById(id);
|
||||
SysOaWarehouseVo sysOaWarehouse = warehouseMapper.selectVoByIdAndXml(sysOaOutWarehouseVo.getWarehouseId());
|
||||
SysOaProjectVo sysOaProject = projectMapper.selectVoById(sysOaOutWarehouseVo.getProjectId());
|
||||
sysOaOutWarehouseVo.setWarehouse(sysOaWarehouse);
|
||||
|
||||
// 出库可能不关联项目
|
||||
if (Objects.nonNull(sysOaProject)){
|
||||
sysOaOutWarehouseVo.setProject(sysOaProject);
|
||||
}
|
||||
return sysOaOutWarehouseVo;
|
||||
}
|
||||
|
||||
|
||||
@@ -104,13 +113,11 @@ public class SysOaOutWarehouseServiceImpl implements ISysOaOutWarehouseService {
|
||||
pageQuery.setPageSize(Integer.MAX_VALUE);
|
||||
}
|
||||
pageQuery.setPageNum((pageQuery.getPageNum() - 1)*pageQuery.getPageSize());
|
||||
|
||||
List<SysOaOutWarehouseListVo> selectList = baseMapper.defineSelectList(bo, pageQuery);
|
||||
|
||||
IPage<SysOaOutWarehouseListVo> page = new Page<>(pageQuery.getPageNum(), pageQuery.getPageSize());
|
||||
page.setRecords(selectList);
|
||||
page.setTotal(total);
|
||||
log.info(String.valueOf(total));
|
||||
|
||||
return TableDataInfo.build(page);
|
||||
}
|
||||
@@ -140,7 +147,10 @@ public class SysOaOutWarehouseServiceImpl implements ISysOaOutWarehouseService {
|
||||
*/
|
||||
@Override
|
||||
public Boolean insertByBo(SysOaOutWarehouseBo bo) {
|
||||
bo.setCreateTime(new Date());
|
||||
bo.setUpdateTime(new Date());
|
||||
SysOaOutWarehouse decrease = toBean(bo, SysOaOutWarehouse.class);
|
||||
|
||||
validEntityBeforeSave(decrease);
|
||||
SysOaWarehouse warehouse = warehouseMapper.selectById(decrease.getWarehouseId());
|
||||
// 1 如果对应仓库表项目数量-将要出库数量<0,出库失败, 繁殖 , 增加该条
|
||||
@@ -152,6 +162,7 @@ public class SysOaOutWarehouseServiceImpl implements ISysOaOutWarehouseService {
|
||||
}
|
||||
else {
|
||||
warehouse.setInventory(warehouse.getInventory() - decrease.getAmount());
|
||||
warehouse.setUpdateTime(new Date());
|
||||
warehouseMapper.updateById(warehouse);
|
||||
}
|
||||
|
||||
@@ -167,17 +178,21 @@ public class SysOaOutWarehouseServiceImpl implements ISysOaOutWarehouseService {
|
||||
|
||||
|
||||
Long projectId = boList.getProjectId();
|
||||
if (projectId == null) {
|
||||
throw new Error("项目ID不能为空,新增出库失败");
|
||||
}
|
||||
List<SysOaOutWarehouseBo2> list = boList.getOutWareHouseList();
|
||||
if (projectId != null) {
|
||||
list.forEach((sysOaOutWarehouseBo2 -> {
|
||||
sysOaOutWarehouseBo2.setProjectId(projectId);
|
||||
SysOaOutWarehouseBo sysOaOutWarehouse = toBean(sysOaOutWarehouseBo2, SysOaOutWarehouseBo.class);
|
||||
insertByBo(sysOaOutWarehouse);
|
||||
}));
|
||||
|
||||
list.forEach((sysOaOutWarehouseBo2 -> {
|
||||
}else{
|
||||
list.forEach((sysOaOutWarehouseBo2 -> {
|
||||
SysOaOutWarehouseBo sysOaOutWarehouse = toBean(sysOaOutWarehouseBo2, SysOaOutWarehouseBo.class);
|
||||
insertByBo(sysOaOutWarehouse);
|
||||
}));
|
||||
}
|
||||
|
||||
sysOaOutWarehouseBo2.setProjectId(projectId);
|
||||
SysOaOutWarehouseBo sysOaOutWarehouse = toBean(sysOaOutWarehouseBo2, SysOaOutWarehouseBo.class);
|
||||
insertByBo(sysOaOutWarehouse);
|
||||
}));
|
||||
|
||||
return true;
|
||||
}
|
||||
@@ -251,12 +266,10 @@ public class SysOaOutWarehouseServiceImpl implements ISysOaOutWarehouseService {
|
||||
//需要增加的对应物料数量
|
||||
LambdaQueryWrapper<SysOaOutWarehouse> lqw = Wrappers.lambdaQuery();
|
||||
lqw.in(SysOaOutWarehouse::getId, ids.toArray());
|
||||
|
||||
List<SysOaOutWarehouse> sysOaOutWarehouses = baseMapper.selectList(lqw); //出库表中的所有删除的数据
|
||||
|
||||
sysOaOutWarehouses.forEach(sysOaOutWarehouse -> { //其中一条
|
||||
|
||||
|
||||
//出库表中的所有删除的数据
|
||||
List<SysOaOutWarehouse> sysOaOutWarehouses = baseMapper.selectList(lqw);
|
||||
//其中一条
|
||||
sysOaOutWarehouses.forEach(sysOaOutWarehouse -> {
|
||||
//选出相对应的 库存表中那一条的数据
|
||||
LambdaQueryWrapper<SysOaWarehouse> lqw2 = Wrappers.lambdaQuery();
|
||||
lqw2.eq(SysOaWarehouse::getId, sysOaOutWarehouse.getWarehouseId());
|
||||
@@ -266,8 +279,7 @@ public class SysOaOutWarehouseServiceImpl implements ISysOaOutWarehouseService {
|
||||
warehouse.setInventory(warehouse.getInventory() + sysOaOutWarehouse.getAmount());
|
||||
warehouseMapper.updateById(warehouse);
|
||||
});
|
||||
boolean flag = baseMapper.deleteBatchIds(ids) > 0;
|
||||
return flag;
|
||||
return baseMapper.deleteBatchIds(ids) > 0;
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -281,7 +293,7 @@ public class SysOaOutWarehouseServiceImpl implements ISysOaOutWarehouseService {
|
||||
lqw.eq(SysOaOutWarehouse::getProjectId, projectId);
|
||||
List<SysOaOutWarehouseVo> sysOaOutWarehouseVos = baseMapper.selectVoList(lqw);
|
||||
for (SysOaOutWarehouseVo sysOaOutWarehouseVo :sysOaOutWarehouseVos) {
|
||||
sysOaOutWarehouseVo.setWarehouseName(warehouseMapper.selectById(sysOaOutWarehouseVo.getWarehouseId()).getName());
|
||||
sysOaOutWarehouseVo.setWarehouseName(warehouseMapper.selectVoByIdAndXml((sysOaOutWarehouseVo.getWarehouseId())).getName());
|
||||
}
|
||||
return TableDataInfo.build(sysOaOutWarehouseVos);
|
||||
}
|
||||
|
||||
@@ -14,11 +14,15 @@ import com.ruoyi.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.ruoyi.oa.domain.SysOaAttendance;
|
||||
import com.ruoyi.oa.domain.SysOaTaskUser;
|
||||
import com.ruoyi.oa.domain.bo.SysOaAttendanceBo;
|
||||
import com.ruoyi.oa.domain.bo.SysOaTaskUserBo;
|
||||
import com.ruoyi.oa.domain.vo.SysOaAttendanceVo;
|
||||
import com.ruoyi.oa.domain.vo.SysOaTaskUserVo;
|
||||
import com.ruoyi.oa.domain.vo.SysUserVo;
|
||||
import com.ruoyi.oa.mapper.SysOaTaskUserMapper;
|
||||
import com.ruoyi.oa.service.ISysOaAttendanceService;
|
||||
import com.ruoyi.oa.service.ISysOaTaskUserService;
|
||||
import com.ruoyi.system.service.ISysDictTypeService;
|
||||
import com.ruoyi.system.service.ISysUserService;
|
||||
@@ -58,6 +62,9 @@ public class SysOaTaskServiceImpl implements ISysOaTaskService {
|
||||
@Autowired
|
||||
private ISysUserService userService;
|
||||
|
||||
@Autowired
|
||||
private ISysOaAttendanceService attendanceService;
|
||||
|
||||
/**
|
||||
* 查询任务管理
|
||||
*/
|
||||
@@ -129,6 +136,7 @@ public class SysOaTaskServiceImpl implements ISysOaTaskService {
|
||||
lqw.eq(StringUtils.isNotEmpty(bo.getProjectId().toString()), SysOaTask::getProjectId, bo.getProjectId());
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getTaskType()),SysOaTask::getTaskType, bo.getTaskType());
|
||||
List<SysOaTaskVo> sysOaTaskVos = baseMapper.selectVoList(lqw);
|
||||
Long projectId = bo.getProjectId();
|
||||
|
||||
// 添加负责人列表
|
||||
for (SysOaTaskVo sysOaTaskVo : sysOaTaskVos) {
|
||||
@@ -136,11 +144,33 @@ public class SysOaTaskServiceImpl implements ISysOaTaskService {
|
||||
lambdaQueryWrapper.eq(SysOaTaskUser::getTaskId, sysOaTaskVo.getTaskId());
|
||||
List<SysOaTaskUserVo> sysOaTaskUserVos = taskUserMapper.selectVoList(lambdaQueryWrapper);
|
||||
List<SysUser> sysUserList = new ArrayList<>();
|
||||
|
||||
// 计算总成本
|
||||
Double projectCostTotal = 0.0;
|
||||
|
||||
for (SysOaTaskUserVo sysOaTaskUserVo : sysOaTaskUserVos) {
|
||||
SysUser sysUser = userService.selectUserById(sysOaTaskUserVo.getUserId());
|
||||
|
||||
// 查询当前用户对于此项目的工作时长
|
||||
SysOaAttendanceBo attendance = new SysOaAttendanceBo();
|
||||
attendance.setUserId(sysOaTaskUserVo.getUserId());
|
||||
attendance.setProjectId(projectId);
|
||||
|
||||
List<SysOaAttendanceVo> sysOaAttendanceVos = attendanceService.queryList(attendance);
|
||||
|
||||
// 写入时间
|
||||
Double workTime = 0.0;
|
||||
for (SysOaAttendanceVo sysOaAttendanceVo : sysOaAttendanceVos) {
|
||||
workTime+=sysOaAttendanceVo.getDayLength();
|
||||
}
|
||||
|
||||
projectCostTotal+=workTime*sysUser.getLaborCost();
|
||||
sysUser.setWorkTime(workTime);
|
||||
|
||||
sysUserList.add(sysUser);
|
||||
}
|
||||
sysOaTaskVo.setWorkerList(sysUserList);
|
||||
sysOaTaskVo.setProjectCostTotal(projectCostTotal);
|
||||
}
|
||||
return sysOaTaskVos;
|
||||
}
|
||||
|
||||
@@ -127,13 +127,7 @@ public class SysOaWarehouseServiceImpl implements ISysOaWarehouseService {
|
||||
if(isValid){
|
||||
//TODO 做一些业务上的校验,判断是否需要校验
|
||||
}
|
||||
LambdaQueryWrapper<SysOaWarehouse> lqw = Wrappers.lambdaQuery();
|
||||
lqw.in(SysOaWarehouse::getId, ids);
|
||||
List<SysOaWarehouse> sysOaWarehouses = baseMapper.selectList(lqw);
|
||||
sysOaWarehouses.forEach(sysOaWarehouse -> {
|
||||
sysOaWarehouse.setDelFlag(1L);
|
||||
});
|
||||
|
||||
return baseMapper.updateBatchById(sysOaWarehouses);
|
||||
return baseMapper.deleteBatchIds(ids)>0;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user