fix worker org

plp
chenshuichuan 2 years ago
parent 1f91bafe6a
commit c2cc14b97c

@ -0,0 +1,27 @@
package cn.iocoder.yudao.module.mes.controller.admin.organization.vo;
import lombok.AllArgsConstructor;
import lombok.Getter;
@Getter
@AllArgsConstructor
public enum OrgStatusEnum {
("close"),
("free"),
使("inuse");
private final String value;
// 一个可选的方法,用于根据整数值获取对应的枚举实例
public static OrgStatusEnum fromValue(String value) {
for (OrgStatusEnum status : OrgStatusEnum.values()) {
if (status.getValue() .equals(value)) {
return status;
}
}
throw new IllegalArgumentException("Unknown value: " + value);
}
}

@ -5,6 +5,7 @@ import lombok.Data;
import org.springframework.format.annotation.DateTimeFormat;
import java.time.LocalDateTime;
import java.util.List;
import static cn.iocoder.yudao.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND;
@ -45,6 +46,8 @@ public class OrganizationListReqVO {
@Schema(description = "组织类型", example = "2")
private String orgType;
@Schema(description = "组织类型", example = "2")
private List<String> orgTypes;
@Schema(description = "创建时间")
@DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)

@ -1,33 +1,31 @@
package cn.iocoder.yudao.module.mes.controller.admin.orgworker;
import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource;
import org.springframework.validation.annotation.Validated;
import org.springframework.security.access.prepost.PreAuthorize;
import io.swagger.v3.oas.annotations.tags.Tag;
import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.Operation;
import javax.validation.constraints.*;
import javax.validation.*;
import javax.servlet.http.*;
import java.util.*;
import java.io.IOException;
import cn.iocoder.yudao.framework.apilog.core.annotation.ApiAccessLog;
import cn.iocoder.yudao.framework.common.pojo.CommonResult;
import cn.iocoder.yudao.framework.common.pojo.PageParam;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.common.pojo.CommonResult;
import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils;
import cn.iocoder.yudao.framework.apilog.core.annotation.ApiAccessLog;
import static cn.iocoder.yudao.framework.apilog.core.enums.OperateTypeEnum.*;
import cn.iocoder.yudao.module.mes.controller.admin.orgworker.vo.*;
import cn.iocoder.yudao.module.mes.controller.admin.orgworker.vo.OrgWorkerPageReqVO;
import cn.iocoder.yudao.module.mes.controller.admin.orgworker.vo.OrgWorkerRespVO;
import cn.iocoder.yudao.module.mes.controller.admin.orgworker.vo.OrgWorkerSaveReqVO;
import cn.iocoder.yudao.module.mes.dal.dataobject.orgworker.OrgWorkerDO;
import cn.iocoder.yudao.module.mes.service.orgworker.OrgWorkerService;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.tags.Tag;
import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource;
import javax.servlet.http.HttpServletResponse;
import javax.validation.Valid;
import java.io.IOException;
import java.util.List;
import static cn.iocoder.yudao.framework.apilog.core.enums.OperateTypeEnum.EXPORT;
import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
@Tag(name = "管理后台 - 工位安排")
@RestController
@ -73,10 +71,9 @@ public class OrgWorkerController {
@GetMapping("/page")
@Operation(summary = "获得工位安排分页")
@PreAuthorize("@ss.hasPermission('mes:org-worker:query')")
public CommonResult<PageResult<OrgWorkerRespVO>> getOrgWorkerPage(@Valid OrgWorkerPageReqVO pageReqVO) {
PageResult<OrgWorkerDO> pageResult = orgWorkerService.getOrgWorkerPage(pageReqVO);
return success(BeanUtils.toBean(pageResult, OrgWorkerRespVO.class));
PageResult<OrgWorkerRespVO> pageResult = orgWorkerService.getOrgWorkerPage(pageReqVO);
return success(pageResult);
}
@GetMapping("/export-excel")
@ -86,10 +83,10 @@ public class OrgWorkerController {
public void exportOrgWorkerExcel(@Valid OrgWorkerPageReqVO pageReqVO,
HttpServletResponse response) throws IOException {
pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE);
List<OrgWorkerDO> list = orgWorkerService.getOrgWorkerPage(pageReqVO).getList();
List<OrgWorkerRespVO> list = orgWorkerService.getOrgWorkerPage(pageReqVO).getList();
// 导出 Excel
ExcelUtils.write(response, "工位安排.xls", "数据", OrgWorkerRespVO.class,
BeanUtils.toBean(list, OrgWorkerRespVO.class));
list);
}
}

@ -1,11 +1,14 @@
package cn.iocoder.yudao.module.mes.controller.admin.orgworker.vo;
import lombok.*;
import java.util.*;
import io.swagger.v3.oas.annotations.media.Schema;
import cn.iocoder.yudao.framework.common.pojo.PageParam;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.ToString;
import org.springframework.format.annotation.DateTimeFormat;
import java.time.LocalDateTime;
import java.util.List;
import static cn.iocoder.yudao.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND;
@ -17,11 +20,16 @@ public class OrgWorkerPageReqVO extends PageParam {
@Schema(description = "工位id", example = "4727")
private Long orgId;
@Schema(description = "工位id", example = "4727")
private List<Long> orgIds;
@Schema(description = "工作日期")
@DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
private LocalDateTime[] workDate;
@Schema(description = "工位类型", example = "2")
private String orgType;
@Schema(description = "班别", example = "2")
private Integer groupType;

@ -1,14 +1,13 @@
package cn.iocoder.yudao.module.mes.controller.admin.orgworker.vo;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.*;
import java.util.*;
import java.util.*;
import org.springframework.format.annotation.DateTimeFormat;
import java.time.LocalDateTime;
import com.alibaba.excel.annotation.*;
import cn.iocoder.yudao.framework.excel.core.annotations.DictFormat;
import cn.iocoder.yudao.framework.excel.core.convert.DictConvert;
import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
import com.alibaba.excel.annotation.ExcelProperty;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.Data;
import java.time.LocalDateTime;
@Schema(description = "管理后台 - 工位安排 Response VO")
@Data
@ -20,8 +19,10 @@ public class OrgWorkerRespVO {
private Long id;
@Schema(description = "工位id", requiredMode = Schema.RequiredMode.REQUIRED, example = "4727")
@ExcelProperty("工位id")
private Long orgId;
@Schema(description = "工位", requiredMode = Schema.RequiredMode.REQUIRED, example = "4727")
@ExcelProperty("工位")
private String orgName;
@Schema(description = "工作日期", requiredMode = Schema.RequiredMode.REQUIRED)
@ExcelProperty("工作日期")
@ -33,8 +34,10 @@ public class OrgWorkerRespVO {
private Integer groupType;
@Schema(description = "工人id", requiredMode = Schema.RequiredMode.REQUIRED, example = "2095")
@ExcelProperty("工人id")
private Long workerId;
@Schema(description = "工人", requiredMode = Schema.RequiredMode.REQUIRED, example = "2095")
@ExcelProperty("工人")
private String workerName;
@Schema(description = "报工单id", example = "5496")
@ExcelProperty("报工单id")

@ -37,7 +37,22 @@ public interface OrganizationMapper extends BaseMapperX<OrganizationDO> {
)
.orderByAsc(OrganizationDO::getSort));
}
default List<OrganizationDO> selectList2(OrganizationListReqVO reqVO) {
return selectList(new LambdaQueryWrapperX<OrganizationDO>()
.likeIfPresent(OrganizationDO::getName, reqVO.getName())
.eqIfPresent(OrganizationDO::getParentId, reqVO.getParentId())
.eqIfPresent(OrganizationDO::getSort, reqVO.getSort())
.eqIfPresent(OrganizationDO::getWorkerUserId, reqVO.getWorkerUserId())
.eqIfPresent(OrganizationDO::getMachineId, reqVO.getMachineId())
.eqIfPresent(OrganizationDO::getPhone, reqVO.getPhone())
.eqIfPresent(OrganizationDO::getEmail, reqVO.getEmail())
.eqIfPresent(OrganizationDO::getOrgType,reqVO.getOrgType())
.eqIfPresent(OrganizationDO::getIsEnable, reqVO.getIsEnable())
.eqIfPresent(OrganizationDO::getStatus, reqVO.getStatus())
.eqIfPresent(OrganizationDO::getOrgClass, reqVO.getOrgClass())
.betweenIfPresent(OrganizationDO::getCreateTime, reqVO.getCreateTime())
.orderByAsc(OrganizationDO::getSort));
}
default OrganizationDO selectByParentIdAndName(Long parentId, String name) {
return selectOne(OrganizationDO::getParentId, parentId, OrganizationDO::getName, name);
}

@ -1,13 +1,11 @@
package cn.iocoder.yudao.module.mes.dal.mysql.orgworker;
import java.util.*;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX;
import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX;
import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX;
import cn.iocoder.yudao.module.mes.controller.admin.orgworker.vo.OrgWorkerPageReqVO;
import cn.iocoder.yudao.module.mes.dal.dataobject.orgworker.OrgWorkerDO;
import org.apache.ibatis.annotations.Mapper;
import cn.iocoder.yudao.module.mes.controller.admin.orgworker.vo.*;
/**
* Mapper
@ -25,6 +23,7 @@ public interface OrgWorkerMapper extends BaseMapperX<OrgWorkerDO> {
.eqIfPresent(OrgWorkerDO::getWorkerId, reqVO.getWorkerId())
.eqIfPresent(OrgWorkerDO::getReportId, reqVO.getReportId())
.betweenIfPresent(OrgWorkerDO::getCreateTime, reqVO.getCreateTime())
.in(reqVO.getOrgIds()!=null&&reqVO.getOrgIds().size()>0,OrgWorkerDO::getOrgId, reqVO.getOrgIds())
.orderByDesc(OrgWorkerDO::getId));
}

@ -1,12 +1,17 @@
package cn.iocoder.yudao.module.mes.service.organization;
import cn.hutool.core.collection.CollUtil;
import cn.iocoder.yudao.framework.common.util.collection.CollectionUtils;
import cn.iocoder.yudao.module.mes.controller.admin.organization.vo.OrganizationListReqVO;
import cn.iocoder.yudao.module.mes.controller.admin.organization.vo.OrganizationRespVO;
import cn.iocoder.yudao.module.mes.controller.admin.organization.vo.OrganizationSaveReqVO;
import cn.iocoder.yudao.module.mes.dal.dataobject.organization.OrganizationDO;
import javax.validation.Valid;
import java.util.Collection;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
/**
* 线 Service
@ -47,10 +52,19 @@ public interface OrganizationService {
/**
* 线
*
*
* @param listReqVO
* @return 线
*/
List<OrganizationDO> getOrganizationList(OrganizationListReqVO listReqVO);
List<OrganizationDO> getOrganizationListNoParent(OrganizationListReqVO listReqVO);
List<OrganizationRespVO> buildVOList(List<OrganizationDO> list);
List<OrganizationDO> getList(Collection<Long> ids);
default Map<Long, OrganizationDO> getMap(Collection<Long> ids) {
if (CollUtil.isEmpty(ids)) {
return new HashMap<>();
}
return CollectionUtils.convertMap(getList(ids), OrganizationDO::getId);
}
}

@ -17,10 +17,7 @@ import org.springframework.stereotype.Service;
import org.springframework.validation.annotation.Validated;
import javax.annotation.Resource;
import java.util.Collections;
import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.*;
import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception;
import static cn.iocoder.yudao.framework.common.util.collection.CollectionUtils.convertSet;
@ -153,6 +150,10 @@ public class OrganizationServiceImpl implements OrganizationService {
public List<OrganizationDO> getOrganizationList(OrganizationListReqVO listReqVO) {
return organizationMapper.selectList(listReqVO);
}
@Override
public List<OrganizationDO> getOrganizationListNoParent(OrganizationListReqVO listReqVO) {
return organizationMapper.selectList2(listReqVO);
}
@Resource
public MachineComponentService machineComponentService;
@ -170,4 +171,11 @@ public class OrganizationServiceImpl implements OrganizationService {
});
}
@Override
public List<OrganizationDO> getList(Collection<Long> ids) {
if (CollUtil.isEmpty(ids)) {
return Collections.emptyList();
}
return organizationMapper.selectBatchIds(ids);
}
}

@ -1,11 +1,13 @@
package cn.iocoder.yudao.module.mes.service.orgworker;
import java.util.*;
import javax.validation.*;
import cn.iocoder.yudao.module.mes.controller.admin.orgworker.vo.*;
import cn.iocoder.yudao.module.mes.dal.dataobject.orgworker.OrgWorkerDO;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.common.pojo.PageParam;
import cn.iocoder.yudao.module.mes.controller.admin.orgworker.vo.OrgWorkerPageReqVO;
import cn.iocoder.yudao.module.mes.controller.admin.orgworker.vo.OrgWorkerRespVO;
import cn.iocoder.yudao.module.mes.controller.admin.orgworker.vo.OrgWorkerSaveReqVO;
import cn.iocoder.yudao.module.mes.dal.dataobject.orgworker.OrgWorkerDO;
import javax.validation.Valid;
import java.util.List;
/**
* Service
@ -50,6 +52,6 @@ public interface OrgWorkerService {
* @param pageReqVO
* @return
*/
PageResult<OrgWorkerDO> getOrgWorkerPage(OrgWorkerPageReqVO pageReqVO);
PageResult<OrgWorkerRespVO> getOrgWorkerPage(OrgWorkerPageReqVO pageReqVO);
List<OrgWorkerRespVO> buildVOList(List<OrgWorkerDO> list);
}

@ -1,21 +1,32 @@
package cn.iocoder.yudao.module.mes.service.orgworker;
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
import org.springframework.validation.annotation.Validated;
import org.springframework.transaction.annotation.Transactional;
import java.util.*;
import cn.iocoder.yudao.module.mes.controller.admin.orgworker.vo.*;
import cn.iocoder.yudao.module.mes.dal.dataobject.orgworker.OrgWorkerDO;
import cn.hutool.core.collection.CollUtil;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.common.pojo.PageParam;
import cn.iocoder.yudao.framework.common.util.collection.MapUtils;
import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
import cn.iocoder.yudao.module.mes.controller.admin.organization.vo.OrganizationListReqVO;
import cn.iocoder.yudao.module.mes.controller.admin.orgworker.vo.OrgWorkerPageReqVO;
import cn.iocoder.yudao.module.mes.controller.admin.orgworker.vo.OrgWorkerRespVO;
import cn.iocoder.yudao.module.mes.controller.admin.orgworker.vo.OrgWorkerSaveReqVO;
import cn.iocoder.yudao.module.mes.dal.dataobject.organization.OrganizationDO;
import cn.iocoder.yudao.module.mes.dal.dataobject.orgworker.OrgWorkerDO;
import cn.iocoder.yudao.module.mes.dal.mysql.orgworker.OrgWorkerMapper;
import cn.iocoder.yudao.module.mes.service.organization.OrganizationService;
import cn.iocoder.yudao.module.system.api.user.AdminUserApi;
import cn.iocoder.yudao.module.system.api.user.dto.AdminUserRespDTO;
import org.apache.commons.lang3.StringUtils;
import org.springframework.stereotype.Service;
import org.springframework.validation.annotation.Validated;
import javax.annotation.Resource;
import java.util.Collections;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception;
import static cn.iocoder.yudao.module.mes.enums.ErrorCodeConstants.*;
import static cn.iocoder.yudao.framework.common.util.collection.CollectionUtils.convertSet;
import static cn.iocoder.yudao.module.mes.enums.ErrorCodeConstants.ORG_WORKER_NOT_EXISTS;
/**
* Service
@ -67,8 +78,39 @@ public class OrgWorkerServiceImpl implements OrgWorkerService {
}
@Override
public PageResult<OrgWorkerDO> getOrgWorkerPage(OrgWorkerPageReqVO pageReqVO) {
return orgWorkerMapper.selectPage(pageReqVO);
public PageResult<OrgWorkerRespVO> getOrgWorkerPage(OrgWorkerPageReqVO pageReqVO) {
//查询工位类型时
if(pageReqVO.getOrgId()==null && StringUtils.isNotEmpty(pageReqVO.getOrgType())){
OrganizationListReqVO reqVO = new OrganizationListReqVO();
reqVO.setOrgType(pageReqVO.getOrgType());
List<OrganizationDO> list = organizationService.getOrganizationListNoParent(reqVO);
List<Long> ids = list.stream()
.map(OrganizationDO::getId)
.collect(Collectors.toList());
pageReqVO.setOrgIds(ids);
}
PageResult<OrgWorkerDO> pageResult = orgWorkerMapper.selectPage(pageReqVO);
return new PageResult<>(buildVOList(pageResult.getList()),pageResult.getTotal());
}
@Resource
private OrganizationService organizationService;
@Resource
private AdminUserApi adminUserApi;
@Override
public List<OrgWorkerRespVO> buildVOList(List<OrgWorkerDO> list) {
if (CollUtil.isEmpty(list)) {
return Collections.emptyList();
}
Map<Long, OrganizationDO> map = organizationService.getMap(
convertSet(list, OrgWorkerDO::getOrgId));
// 1.4 管理员信息
Map<Long, AdminUserRespDTO> userMap = adminUserApi.getUserMap(
convertSet(list, OrgWorkerDO::getWorkerId));
return BeanUtils.toBean(list, OrgWorkerRespVO.class, item -> {
MapUtils.findAndThen(map, item.getOrgId(),
org -> item.setOrgName(org.getName()));
MapUtils.findAndThen(userMap, item.getWorkerId(),
user -> item.setWorkerName(user.getNickname()));
});
}
}

@ -1,32 +1,26 @@
package cn.iocoder.yudao.module.mes.service.orgworker;
import org.junit.jupiter.api.Disabled;
import org.junit.jupiter.api.Test;
import org.springframework.boot.test.mock.mockito.MockBean;
import javax.annotation.Resource;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.test.core.ut.BaseDbUnitTest;
import cn.iocoder.yudao.module.mes.controller.admin.orgworker.vo.*;
import cn.iocoder.yudao.module.mes.controller.admin.orgworker.vo.OrgWorkerPageReqVO;
import cn.iocoder.yudao.module.mes.controller.admin.orgworker.vo.OrgWorkerRespVO;
import cn.iocoder.yudao.module.mes.controller.admin.orgworker.vo.OrgWorkerSaveReqVO;
import cn.iocoder.yudao.module.mes.dal.dataobject.orgworker.OrgWorkerDO;
import cn.iocoder.yudao.module.mes.dal.mysql.orgworker.OrgWorkerMapper;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import org.junit.jupiter.api.Disabled;
import org.junit.jupiter.api.Test;
import org.springframework.context.annotation.Import;
import javax.annotation.Resource;
import org.springframework.context.annotation.Import;
import java.util.*;
import java.time.LocalDateTime;
import static cn.hutool.core.util.RandomUtil.*;
import static cn.iocoder.yudao.module.mes.enums.ErrorCodeConstants.*;
import static cn.iocoder.yudao.framework.test.core.util.AssertUtils.*;
import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.*;
import static cn.iocoder.yudao.framework.common.util.date.LocalDateTimeUtils.*;
import static cn.iocoder.yudao.framework.common.util.object.ObjectUtils.*;
import static cn.iocoder.yudao.framework.common.util.date.DateUtils.*;
import static cn.iocoder.yudao.framework.common.util.date.LocalDateTimeUtils.buildBetweenTime;
import static cn.iocoder.yudao.framework.common.util.object.ObjectUtils.cloneIgnoreId;
import static cn.iocoder.yudao.framework.test.core.util.AssertUtils.assertPojoEquals;
import static cn.iocoder.yudao.framework.test.core.util.AssertUtils.assertServiceException;
import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.randomLongId;
import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.randomPojo;
import static cn.iocoder.yudao.module.mes.enums.ErrorCodeConstants.ORG_WORKER_NOT_EXISTS;
import static org.junit.jupiter.api.Assertions.*;
import static org.mockito.Mockito.*;
/**
* {@link OrgWorkerServiceImpl}
@ -140,7 +134,7 @@ public class OrgWorkerServiceImplTest extends BaseDbUnitTest {
reqVO.setCreateTime(buildBetweenTime(2023, 2, 1, 2023, 2, 28));
// 调用
PageResult<OrgWorkerDO> pageResult = orgWorkerService.getOrgWorkerPage(reqVO);
PageResult<OrgWorkerRespVO> pageResult = orgWorkerService.getOrgWorkerPage(reqVO);
// 断言
assertEquals(1, pageResult.getTotal());
assertEquals(1, pageResult.getList().size());

Loading…
Cancel
Save