parent
45cc7e947c
commit
38edbe8a6d
@ -0,0 +1,95 @@
|
||||
package com.chanko.yunxi.mes.module.heli.controller.admin.workshop;
|
||||
|
||||
import com.chanko.yunxi.mes.framework.common.pojo.CommonResult;
|
||||
import com.chanko.yunxi.mes.framework.common.pojo.PageParam;
|
||||
import com.chanko.yunxi.mes.framework.common.pojo.PageResult;
|
||||
import com.chanko.yunxi.mes.framework.common.util.object.BeanUtils;
|
||||
import com.chanko.yunxi.mes.framework.excel.core.util.ExcelUtils;
|
||||
import com.chanko.yunxi.mes.framework.operatelog.core.annotations.OperateLog;
|
||||
import com.chanko.yunxi.mes.module.heli.controller.admin.workshop.vo.WorkshopPageReqVO;
|
||||
import com.chanko.yunxi.mes.module.heli.controller.admin.workshop.vo.WorkshopRespVO;
|
||||
import com.chanko.yunxi.mes.module.heli.controller.admin.workshop.vo.WorkshopSaveReqVO;
|
||||
import com.chanko.yunxi.mes.module.heli.dal.dataobject.workshop.WorkshopDO;
|
||||
import com.chanko.yunxi.mes.module.heli.service.workshop.WorkshopService;
|
||||
import io.swagger.v3.oas.annotations.Operation;
|
||||
import io.swagger.v3.oas.annotations.Parameter;
|
||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
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 com.chanko.yunxi.mes.framework.common.pojo.CommonResult.success;
|
||||
import static com.chanko.yunxi.mes.framework.operatelog.core.enums.OperateTypeEnum.EXPORT;
|
||||
|
||||
@Slf4j
|
||||
@Tag(name = "管理后台 - 车间")
|
||||
@RestController
|
||||
@RequestMapping("/heli/workshop")
|
||||
@Validated
|
||||
public class WorkshopController {
|
||||
|
||||
@Resource
|
||||
private WorkshopService workshopService;
|
||||
|
||||
@PostMapping("/create")
|
||||
@Operation(summary = "创建车间")
|
||||
@PreAuthorize("@ss.hasPermission('heli:workshop:create')")
|
||||
public CommonResult<Long> createWorkshop(@Valid @RequestBody WorkshopSaveReqVO createReqVO) {
|
||||
return success(workshopService.createWorkshop(createReqVO));
|
||||
}
|
||||
|
||||
@PutMapping("/update")
|
||||
@Operation(summary = "更新车间")
|
||||
@PreAuthorize("@ss.hasPermission('heli:workshop:update')")
|
||||
public CommonResult<Boolean> updateWorkshop(@Valid @RequestBody WorkshopSaveReqVO updateReqVO) {
|
||||
workshopService.updateWorkshop(updateReqVO);
|
||||
return success(true);
|
||||
}
|
||||
|
||||
@DeleteMapping("/delete")
|
||||
@Operation(summary = "删除车间")
|
||||
@Parameter(name = "id", description = "编号", required = true)
|
||||
@PreAuthorize("@ss.hasPermission('heli:workshop:delete')")
|
||||
public CommonResult<Boolean> deleteWorkshop(@RequestParam("id") Long id) {
|
||||
workshopService.deleteWorkshop(id);
|
||||
return success(true);
|
||||
}
|
||||
|
||||
@GetMapping("/get")
|
||||
@Operation(summary = "获得车间")
|
||||
@Parameter(name = "id", description = "编号", required = true, example = "1024")
|
||||
@PreAuthorize("@ss.hasPermission('heli:workshop:query')")
|
||||
public CommonResult<WorkshopRespVO> getWorkshop(@RequestParam("id") Long id) {
|
||||
WorkshopDO workshop = workshopService.getWorkshop(id);
|
||||
return success(BeanUtils.toBean(workshop, WorkshopRespVO.class));
|
||||
}
|
||||
|
||||
@GetMapping("/page")
|
||||
@Operation(summary = "获得车间分页")
|
||||
@PreAuthorize("@ss.hasPermission('heli:workshop:query')")
|
||||
public CommonResult<PageResult<WorkshopRespVO>> getWorkshopPage(@Valid WorkshopPageReqVO pageReqVO) {
|
||||
PageResult<WorkshopDO> pageResult = workshopService.getWorkshopPage(pageReqVO);
|
||||
return success(BeanUtils.toBean(pageResult, WorkshopRespVO.class));
|
||||
}
|
||||
|
||||
@GetMapping("/export-excel")
|
||||
@Operation(summary = "导出车间 Excel")
|
||||
@PreAuthorize("@ss.hasPermission('heli:workshop:export')")
|
||||
@OperateLog(type = EXPORT)
|
||||
public void exportWorkshopExcel(@Valid WorkshopPageReqVO pageReqVO,
|
||||
HttpServletResponse response) throws IOException {
|
||||
pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE);
|
||||
List<WorkshopDO> list = workshopService.getWorkshopPage(pageReqVO).getList();
|
||||
// 导出 Excel
|
||||
ExcelUtils.write(response, "车间.xls", "数据", WorkshopRespVO.class,
|
||||
BeanUtils.toBean(list, WorkshopRespVO.class));
|
||||
}
|
||||
|
||||
}
|
@ -0,0 +1,34 @@
|
||||
package com.chanko.yunxi.mes.module.heli.dal.mysql.workshop;
|
||||
|
||||
import com.chanko.yunxi.mes.framework.common.pojo.PageResult;
|
||||
import com.chanko.yunxi.mes.framework.mybatis.core.mapper.BaseMapperX;
|
||||
import com.chanko.yunxi.mes.module.heli.controller.admin.workshop.vo.WorkshopPageReqVO;
|
||||
import com.chanko.yunxi.mes.module.heli.dal.dataobject.workshop.WorkshopDO;
|
||||
import com.chanko.yunxi.mes.module.system.dal.dataobject.dept.DeptDO;
|
||||
import com.chanko.yunxi.mes.module.system.dal.dataobject.user.AdminUserDO;
|
||||
import com.github.yulichang.wrapper.MPJLambdaWrapper;
|
||||
import org.apache.commons.lang.StringUtils;
|
||||
import org.apache.ibatis.annotations.Mapper;
|
||||
|
||||
/**
|
||||
* 车间 Mapper
|
||||
*
|
||||
* @author 管理员
|
||||
*/
|
||||
@Mapper
|
||||
public interface WorkshopMapper extends BaseMapperX<WorkshopDO> {
|
||||
|
||||
default PageResult<WorkshopDO> selectPage(WorkshopPageReqVO reqVO) {
|
||||
MPJLambdaWrapper<WorkshopDO> query = new MPJLambdaWrapper<>();
|
||||
query.selectAll(WorkshopDO.class)
|
||||
.select("u.nickname as leaderUserName", "d.name as deptName")
|
||||
.leftJoin(AdminUserDO.class, "u", AdminUserDO::getId, WorkshopDO::getLeaderUserId)
|
||||
.leftJoin(DeptDO.class, "d", DeptDO::getId, WorkshopDO::getDeptId);
|
||||
|
||||
query.like(!StringUtils.isEmpty(reqVO.getCode()), WorkshopDO::getCode, reqVO.getCode())
|
||||
.like(!StringUtils.isEmpty(reqVO.getName()), WorkshopDO::getName, reqVO.getName())
|
||||
.eq(reqVO.getStatus() != null, WorkshopDO::getStatus, reqVO.getStatus());
|
||||
return selectPage(reqVO, query);
|
||||
}
|
||||
|
||||
}
|
@ -0,0 +1,55 @@
|
||||
package com.chanko.yunxi.mes.module.heli.service.workshop;
|
||||
|
||||
import java.util.*;
|
||||
import javax.validation.*;
|
||||
import com.chanko.yunxi.mes.module.heli.controller.admin.workshop.vo.*;
|
||||
import com.chanko.yunxi.mes.module.heli.dal.dataobject.workshop.WorkshopDO;
|
||||
import com.chanko.yunxi.mes.framework.common.pojo.PageResult;
|
||||
import com.chanko.yunxi.mes.framework.common.pojo.PageParam;
|
||||
|
||||
/**
|
||||
* 车间 Service 接口
|
||||
*
|
||||
* @author 管理员
|
||||
*/
|
||||
public interface WorkshopService {
|
||||
|
||||
/**
|
||||
* 创建车间
|
||||
*
|
||||
* @param createReqVO 创建信息
|
||||
* @return 编号
|
||||
*/
|
||||
Long createWorkshop(@Valid WorkshopSaveReqVO createReqVO);
|
||||
|
||||
/**
|
||||
* 更新车间
|
||||
*
|
||||
* @param updateReqVO 更新信息
|
||||
*/
|
||||
void updateWorkshop(@Valid WorkshopSaveReqVO updateReqVO);
|
||||
|
||||
/**
|
||||
* 删除车间
|
||||
*
|
||||
* @param id 编号
|
||||
*/
|
||||
void deleteWorkshop(Long id);
|
||||
|
||||
/**
|
||||
* 获得车间
|
||||
*
|
||||
* @param id 编号
|
||||
* @return 车间
|
||||
*/
|
||||
WorkshopDO getWorkshop(Long id);
|
||||
|
||||
/**
|
||||
* 获得车间分页
|
||||
*
|
||||
* @param pageReqVO 分页查询
|
||||
* @return 车间分页
|
||||
*/
|
||||
PageResult<WorkshopDO> getWorkshopPage(WorkshopPageReqVO pageReqVO);
|
||||
|
||||
}
|
@ -0,0 +1,77 @@
|
||||
package com.chanko.yunxi.mes.module.heli.service.workshop;
|
||||
|
||||
import cn.hutool.core.lang.UUID;
|
||||
import com.chanko.yunxi.mes.framework.common.pojo.PageResult;
|
||||
import com.chanko.yunxi.mes.framework.common.util.object.BeanUtils;
|
||||
import com.chanko.yunxi.mes.module.heli.controller.admin.workshop.vo.WorkshopPageReqVO;
|
||||
import com.chanko.yunxi.mes.module.heli.controller.admin.workshop.vo.WorkshopSaveReqVO;
|
||||
import com.chanko.yunxi.mes.module.heli.dal.dataobject.workshop.WorkshopDO;
|
||||
import com.chanko.yunxi.mes.module.heli.dal.mysql.workshop.WorkshopMapper;
|
||||
import org.springframework.stereotype.Service;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
|
||||
import javax.annotation.Resource;
|
||||
|
||||
import static com.chanko.yunxi.mes.framework.common.exception.util.ServiceExceptionUtil.exception;
|
||||
import static com.chanko.yunxi.mes.module.heli.enums.CodeEnum.WORKSHOP;
|
||||
import static com.chanko.yunxi.mes.module.heli.enums.ErrorCodeConstants.WORKSHOP_NOT_EXISTS;
|
||||
|
||||
/**
|
||||
* 车间 Service 实现类
|
||||
*
|
||||
* @author 管理员
|
||||
*/
|
||||
@Service
|
||||
@Validated
|
||||
public class WorkshopServiceImpl implements WorkshopService {
|
||||
|
||||
@Resource
|
||||
private WorkshopMapper workshopMapper;
|
||||
|
||||
@Override
|
||||
public Long createWorkshop(WorkshopSaveReqVO createReqVO) {
|
||||
// 插入
|
||||
// 自动生成
|
||||
WorkshopDO workshop = BeanUtils.toBean(createReqVO, WorkshopDO.class);
|
||||
workshop.setCode(UUID.fastUUID().toString(true));
|
||||
workshopMapper.insert(workshop);
|
||||
workshop.setCode(WORKSHOP.getCode(workshop.getId().toString()));
|
||||
workshopMapper.updateById(workshop);
|
||||
// 返回
|
||||
return workshop.getId();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void updateWorkshop(WorkshopSaveReqVO updateReqVO) {
|
||||
// 校验存在
|
||||
validateWorkshopExists(updateReqVO.getId());
|
||||
// 更新
|
||||
WorkshopDO updateObj = BeanUtils.toBean(updateReqVO, WorkshopDO.class);
|
||||
workshopMapper.updateById(updateObj);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deleteWorkshop(Long id) {
|
||||
// 校验存在
|
||||
validateWorkshopExists(id);
|
||||
// 删除
|
||||
workshopMapper.deleteById(id);
|
||||
}
|
||||
|
||||
private void validateWorkshopExists(Long id) {
|
||||
if (workshopMapper.selectById(id) == null) {
|
||||
throw exception(WORKSHOP_NOT_EXISTS);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public WorkshopDO getWorkshop(Long id) {
|
||||
return workshopMapper.selectById(id);
|
||||
}
|
||||
|
||||
@Override
|
||||
public PageResult<WorkshopDO> getWorkshopPage(WorkshopPageReqVO pageReqVO) {
|
||||
return workshopMapper.selectPage(pageReqVO);
|
||||
}
|
||||
|
||||
}
|
@ -0,0 +1,41 @@
|
||||
import request from '@/config/axios'
|
||||
|
||||
export interface WorkshopVO {
|
||||
id: number
|
||||
code: string
|
||||
name: string
|
||||
deptId: number
|
||||
leaderUserId: number
|
||||
description: string
|
||||
status: number
|
||||
}
|
||||
|
||||
// 查询车间分页
|
||||
export const getWorkshopPage = async (params) => {
|
||||
return await request.get({ url: `/heli/workshop/page`, params })
|
||||
}
|
||||
|
||||
// 查询车间详情
|
||||
export const getWorkshop = async (id: number) => {
|
||||
return await request.get({ url: `/heli/workshop/get?id=` + id })
|
||||
}
|
||||
|
||||
// 新增车间
|
||||
export const createWorkshop = async (data: WorkshopVO) => {
|
||||
return await request.post({ url: `/heli/workshop/create`, data })
|
||||
}
|
||||
|
||||
// 修改车间
|
||||
export const updateWorkshop = async (data: WorkshopVO) => {
|
||||
return await request.put({ url: `/heli/workshop/update`, data })
|
||||
}
|
||||
|
||||
// 删除车间
|
||||
export const deleteWorkshop = async (id: number) => {
|
||||
return await request.delete({ url: `/heli/workshop/delete?id=` + id })
|
||||
}
|
||||
|
||||
// 导出车间 Excel
|
||||
export const exportWorkshop = async (params) => {
|
||||
return await request.download({ url: `/heli/workshop/export-excel`, params })
|
||||
}
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in new issue