工序信息 ui/ux 初始化

工序信息 ui/ux 初始化
master
siontion 10 months ago
parent f0158c5ebe
commit 5cb545b7a5

@ -21,6 +21,7 @@ public interface ErrorCodeConstants {
ErrorCode CLIENT_NOT_EXISTS = new ErrorCode(1_001_003, "客户信息不存在");
ErrorCode CUSTOMER_NOT_EXISTS = new ErrorCode( 1_001_004, "客户新表信息不存在");
ErrorCode SUPPLIER_NOT_EXISTS = new ErrorCode(1_001_005, "供应商不存在");
ErrorCode PROCEDURE_NOT_EXISTS = new ErrorCode(1_001_006, "工序不存在");
/*********组织架构************/
ErrorCode WORKSHOP_NOT_EXISTS = new ErrorCode(1_002_001, "车间不存在");

@ -0,0 +1,95 @@
package com.chanko.yunxi.mes.module.heli.controller.admin.procedure;
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 com.chanko.yunxi.mes.framework.common.pojo.PageParam;
import com.chanko.yunxi.mes.framework.common.pojo.PageResult;
import com.chanko.yunxi.mes.framework.common.pojo.CommonResult;
import com.chanko.yunxi.mes.framework.common.util.object.BeanUtils;
import static com.chanko.yunxi.mes.framework.common.pojo.CommonResult.success;
import com.chanko.yunxi.mes.framework.excel.core.util.ExcelUtils;
import com.chanko.yunxi.mes.framework.operatelog.core.annotations.OperateLog;
import static com.chanko.yunxi.mes.framework.operatelog.core.enums.OperateTypeEnum.*;
import com.chanko.yunxi.mes.module.heli.controller.admin.procedure.vo.*;
import com.chanko.yunxi.mes.module.heli.dal.dataobject.procedure.ProcedureDO;
import com.chanko.yunxi.mes.module.heli.service.procedure.ProcedureService;
@Tag(name = "管理后台 - 工序")
@RestController
@RequestMapping("/heli/procedure")
@Validated
public class ProcedureController {
@Resource
private ProcedureService procedureService;
@PostMapping("/create")
@Operation(summary = "创建工序")
@PreAuthorize("@ss.hasPermission('heli:procedure:create')")
public CommonResult<Long> createProcedure(@Valid @RequestBody ProcedureSaveReqVO createReqVO) {
return success(procedureService.createProcedure(createReqVO));
}
@PutMapping("/update")
@Operation(summary = "更新工序")
@PreAuthorize("@ss.hasPermission('heli:procedure:update')")
public CommonResult<Boolean> updateProcedure(@Valid @RequestBody ProcedureSaveReqVO updateReqVO) {
procedureService.updateProcedure(updateReqVO);
return success(true);
}
@DeleteMapping("/delete")
@Operation(summary = "删除工序")
@Parameter(name = "id", description = "编号", required = true)
@PreAuthorize("@ss.hasPermission('heli:procedure:delete')")
public CommonResult<Boolean> deleteProcedure(@RequestParam("id") Long id) {
procedureService.deleteProcedure(id);
return success(true);
}
@GetMapping("/get")
@Operation(summary = "获得工序")
@Parameter(name = "id", description = "编号", required = true, example = "1024")
@PreAuthorize("@ss.hasPermission('heli:procedure:query')")
public CommonResult<ProcedureRespVO> getProcedure(@RequestParam("id") Long id) {
ProcedureDO procedure = procedureService.getProcedure(id);
return success(BeanUtils.toBean(procedure, ProcedureRespVO.class));
}
@GetMapping("/page")
@Operation(summary = "获得工序分页")
@PreAuthorize("@ss.hasPermission('heli:procedure:query')")
public CommonResult<PageResult<ProcedureRespVO>> getProcedurePage(@Valid ProcedurePageReqVO pageReqVO) {
PageResult<ProcedureDO> pageResult = procedureService.getProcedurePage(pageReqVO);
return success(BeanUtils.toBean(pageResult, ProcedureRespVO.class));
}
@GetMapping("/export-excel")
@Operation(summary = "导出工序 Excel")
@PreAuthorize("@ss.hasPermission('heli:procedure:export')")
@OperateLog(type = EXPORT)
public void exportProcedureExcel(@Valid ProcedurePageReqVO pageReqVO,
HttpServletResponse response) throws IOException {
pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE);
List<ProcedureDO> list = procedureService.getProcedurePage(pageReqVO).getList();
// 导出 Excel
ExcelUtils.write(response, "工序.xls", "数据", ProcedureRespVO.class,
BeanUtils.toBean(list, ProcedureRespVO.class));
}
}

@ -0,0 +1,56 @@
package com.chanko.yunxi.mes.module.heli.controller.admin.procedure.vo;
import lombok.*;
import java.util.*;
import io.swagger.v3.oas.annotations.media.Schema;
import com.chanko.yunxi.mes.framework.common.pojo.PageParam;
import org.springframework.format.annotation.DateTimeFormat;
import java.time.LocalDateTime;
import static com.chanko.yunxi.mes.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND;
@Schema(description = "管理后台 - 工序分页 Request VO")
@Data
@EqualsAndHashCode(callSuper = true)
@ToString(callSuper = true)
public class ProcedurePageReqVO extends PageParam {
@Schema(description = "工序编号")
private String code;
@Schema(description = "工序名称,唯一", example = "李四")
private String name;
@Schema(description = "工序描述", example = "你猜")
private String description;
@Schema(description = "状态,1表示正常2表示禁用", example = "2")
private Integer status;
@Schema(description = "创建者")
private String creator;
@Schema(description = "创建时间")
@DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
private LocalDateTime[] createTime;
@Schema(description = "更新者")
private String updater;
@Schema(description = "更新时间")
@DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
private LocalDateTime[] updateTime;
@Schema(description = "是否删除")
private Boolean deleted;
@Schema(description = "租户编号", example = "31584")
private Long tenantId;
@Schema(description = "是否需要报工")
private Integer isReport;
@Schema(description = "车间ID", example = "13738")
private Long wid;
}

@ -0,0 +1,52 @@
package com.chanko.yunxi.mes.module.heli.controller.admin.procedure.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 com.chanko.yunxi.mes.framework.excel.core.annotations.DictFormat;
import com.chanko.yunxi.mes.framework.excel.core.convert.DictConvert;
@Schema(description = "管理后台 - 工序 Response VO")
@Data
@ExcelIgnoreUnannotated
public class ProcedureRespVO {
@Schema(description = "自增字段,唯一", requiredMode = Schema.RequiredMode.REQUIRED, example = "11605")
@ExcelProperty("自增字段,唯一")
private Long id;
@Schema(description = "工序编号")
@ExcelProperty("工序编号")
private String code;
@Schema(description = "工序名称,唯一", requiredMode = Schema.RequiredMode.REQUIRED, example = "李四")
@ExcelProperty("工序名称,唯一")
private String name;
@Schema(description = "工序描述", example = "你猜")
@ExcelProperty("工序描述")
private String description;
@Schema(description = "状态,1表示正常2表示禁用", requiredMode = Schema.RequiredMode.REQUIRED, example = "2")
@ExcelProperty(value = "状态,1表示正常2表示禁用", converter = DictConvert.class)
@DictFormat("heli_system_common_status") // TODO 代码优化:建议设置到对应的 DictTypeConstants 枚举类中
private Integer status;
@Schema(description = "创建时间", requiredMode = Schema.RequiredMode.REQUIRED)
@ExcelProperty("创建时间")
private LocalDateTime createTime;
@Schema(description = "是否需要报工")
@ExcelProperty(value = "是否需要报工", converter = DictConvert.class)
@DictFormat("infra_boolean_string") // TODO 代码优化:建议设置到对应的 DictTypeConstants 枚举类中
private Integer isReport;
@Schema(description = "车间ID", example = "13738")
@ExcelProperty("车间ID")
private Long wid;
}

@ -0,0 +1,36 @@
package com.chanko.yunxi.mes.module.heli.controller.admin.procedure.vo;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.*;
import java.util.*;
import javax.validation.constraints.*;
import java.util.*;
@Schema(description = "管理后台 - 工序新增/修改 Request VO")
@Data
public class ProcedureSaveReqVO {
@Schema(description = "自增字段,唯一", requiredMode = Schema.RequiredMode.REQUIRED, example = "11605")
private Long id;
@Schema(description = "工序编号")
private String code;
@Schema(description = "工序名称,唯一", requiredMode = Schema.RequiredMode.REQUIRED, example = "李四")
@NotEmpty(message = "工序名称,唯一不能为空")
private String name;
@Schema(description = "工序描述", example = "你猜")
private String description;
@Schema(description = "状态,1表示正常2表示禁用", requiredMode = Schema.RequiredMode.REQUIRED, example = "2")
@NotNull(message = "状态,1表示正常2表示禁用不能为空")
private Integer status;
@Schema(description = "是否需要报工")
private Integer isReport;
@Schema(description = "车间ID", example = "13738")
private Long wid;
}

@ -0,0 +1,59 @@
package com.chanko.yunxi.mes.module.heli.dal.dataobject.procedure;
import lombok.*;
import java.util.*;
import java.time.LocalDateTime;
import java.time.LocalDateTime;
import com.baomidou.mybatisplus.annotation.*;
import com.chanko.yunxi.mes.framework.mybatis.core.dataobject.BaseDO;
/**
* DO
*
* @author
*/
@TableName("base_procedure")
@KeySequence("base_procedure_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库,可不写。
@Data
@EqualsAndHashCode(callSuper = true)
@ToString(callSuper = true)
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class ProcedureDO extends BaseDO {
/**
*
*/
@TableId
private Long id;
/**
*
*/
private String code;
/**
* ,
*/
private String name;
/**
*
*/
private String description;
/**
* ,12
*
* {@link TODO heli_system_common_status }
*/
private Integer status;
/**
*
*
* {@link TODO infra_boolean_string }
*/
private Integer isReport;
/**
* ID
*/
private Long wid;
}

@ -0,0 +1,37 @@
package com.chanko.yunxi.mes.module.heli.dal.mysql.procedure;
import java.util.*;
import com.chanko.yunxi.mes.framework.common.pojo.PageResult;
import com.chanko.yunxi.mes.framework.mybatis.core.query.LambdaQueryWrapperX;
import com.chanko.yunxi.mes.framework.mybatis.core.mapper.BaseMapperX;
import com.chanko.yunxi.mes.module.heli.dal.dataobject.procedure.ProcedureDO;
import org.apache.ibatis.annotations.Mapper;
import com.chanko.yunxi.mes.module.heli.controller.admin.procedure.vo.*;
/**
* Mapper
*
* @author
*/
@Mapper
public interface ProcedureMapper extends BaseMapperX<ProcedureDO> {
default PageResult<ProcedureDO> selectPage(ProcedurePageReqVO reqVO) {
return selectPage(reqVO, new LambdaQueryWrapperX<ProcedureDO>()
.likeIfPresent(ProcedureDO::getCode, reqVO.getCode())
.likeIfPresent(ProcedureDO::getName, reqVO.getName())
.eqIfPresent(ProcedureDO::getDescription, reqVO.getDescription())
.eqIfPresent(ProcedureDO::getStatus, reqVO.getStatus())
.eqIfPresent(ProcedureDO::getCreator, reqVO.getCreator())
.betweenIfPresent(ProcedureDO::getCreateTime, reqVO.getCreateTime())
.eqIfPresent(ProcedureDO::getUpdater, reqVO.getUpdater())
.betweenIfPresent(ProcedureDO::getUpdateTime, reqVO.getUpdateTime())
.eqIfPresent(ProcedureDO::getDeleted, reqVO.getDeleted())
.eqIfPresent(ProcedureDO::getTenantId, reqVO.getTenantId())
.eqIfPresent(ProcedureDO::getIsReport, reqVO.getIsReport())
.eqIfPresent(ProcedureDO::getWid, reqVO.getWid())
.orderByDesc(ProcedureDO::getId));
}
}

@ -0,0 +1,55 @@
package com.chanko.yunxi.mes.module.heli.service.procedure;
import java.util.*;
import javax.validation.*;
import com.chanko.yunxi.mes.module.heli.controller.admin.procedure.vo.*;
import com.chanko.yunxi.mes.module.heli.dal.dataobject.procedure.ProcedureDO;
import com.chanko.yunxi.mes.framework.common.pojo.PageResult;
import com.chanko.yunxi.mes.framework.common.pojo.PageParam;
/**
* Service
*
* @author
*/
public interface ProcedureService {
/**
*
*
* @param createReqVO
* @return
*/
Long createProcedure(@Valid ProcedureSaveReqVO createReqVO);
/**
*
*
* @param updateReqVO
*/
void updateProcedure(@Valid ProcedureSaveReqVO updateReqVO);
/**
*
*
* @param id
*/
void deleteProcedure(Long id);
/**
*
*
* @param id
* @return
*/
ProcedureDO getProcedure(Long id);
/**
*
*
* @param pageReqVO
* @return
*/
PageResult<ProcedureDO> getProcedurePage(ProcedurePageReqVO pageReqVO);
}

@ -0,0 +1,74 @@
package com.chanko.yunxi.mes.module.heli.service.procedure;
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 com.chanko.yunxi.mes.module.heli.controller.admin.procedure.vo.*;
import com.chanko.yunxi.mes.module.heli.dal.dataobject.procedure.ProcedureDO;
import com.chanko.yunxi.mes.framework.common.pojo.PageResult;
import com.chanko.yunxi.mes.framework.common.pojo.PageParam;
import com.chanko.yunxi.mes.framework.common.util.object.BeanUtils;
import com.chanko.yunxi.mes.module.heli.dal.mysql.procedure.ProcedureMapper;
import static com.chanko.yunxi.mes.framework.common.exception.util.ServiceExceptionUtil.exception;
import static com.chanko.yunxi.mes.module.heli.enums.ErrorCodeConstants.*;
/**
* Service
*
* @author
*/
@Service
@Validated
public class ProcedureServiceImpl implements ProcedureService {
@Resource
private ProcedureMapper procedureMapper;
@Override
public Long createProcedure(ProcedureSaveReqVO createReqVO) {
// 插入
ProcedureDO procedure = BeanUtils.toBean(createReqVO, ProcedureDO.class);
procedureMapper.insert(procedure);
// 返回
return procedure.getId();
}
@Override
public void updateProcedure(ProcedureSaveReqVO updateReqVO) {
// 校验存在
validateProcedureExists(updateReqVO.getId());
// 更新
ProcedureDO updateObj = BeanUtils.toBean(updateReqVO, ProcedureDO.class);
procedureMapper.updateById(updateObj);
}
@Override
public void deleteProcedure(Long id) {
// 校验存在
validateProcedureExists(id);
// 删除
procedureMapper.deleteById(id);
}
private void validateProcedureExists(Long id) {
if (procedureMapper.selectById(id) == null) {
throw exception(PROCEDURE_NOT_EXISTS);
}
}
@Override
public ProcedureDO getProcedure(Long id) {
return procedureMapper.selectById(id);
}
@Override
public PageResult<ProcedureDO> getProcedurePage(ProcedurePageReqVO pageReqVO) {
return procedureMapper.selectPage(pageReqVO);
}
}

@ -0,0 +1,12 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.chanko.yunxi.mes.module.heli.dal.mysql.procedure.ProcedureMapper">
<!--
一般情况下,尽可能使用 Mapper 进行 CRUD 增删改查即可。
无法满足的场景,例如说多表关联查询,才使用 XML 编写 SQL。
代码生成器暂时只生成 Mapper XML 文件本身,更多推荐 MybatisX 快速开发插件来生成查询。
文档可见https://www.iocoder.cn/MyBatis/x-plugins/
-->
</mapper>

@ -0,0 +1,174 @@
package com.chanko.yunxi.mes.module.heli.service.procedure;
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 com.chanko.yunxi.mes.framework.test.core.ut.BaseDbUnitTest;
import com.chanko.yunxi.mes.module.heli.controller.admin.procedure.vo.*;
import com.chanko.yunxi.mes.module.heli.dal.dataobject.procedure.ProcedureDO;
import com.chanko.yunxi.mes.module.heli.dal.mysql.procedure.ProcedureMapper;
import com.chanko.yunxi.mes.framework.common.pojo.PageResult;
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 com.chanko.yunxi.mes.module.heli.enums.ErrorCodeConstants.*;
import static com.chanko.yunxi.mes.framework.test.core.util.AssertUtils.*;
import static com.chanko.yunxi.mes.framework.test.core.util.RandomUtils.*;
import static com.chanko.yunxi.mes.framework.common.util.date.LocalDateTimeUtils.*;
import static com.chanko.yunxi.mes.framework.common.util.object.ObjectUtils.*;
import static com.chanko.yunxi.mes.framework.common.util.date.DateUtils.*;
import static org.junit.jupiter.api.Assertions.*;
import static org.mockito.Mockito.*;
/**
* {@link ProcedureServiceImpl}
*
* @author
*/
@Import(ProcedureServiceImpl.class)
public class ProcedureServiceImplTest extends BaseDbUnitTest {
@Resource
private ProcedureServiceImpl procedureService;
@Resource
private ProcedureMapper procedureMapper;
@Test
public void testCreateProcedure_success() {
// 准备参数
ProcedureSaveReqVO createReqVO = randomPojo(ProcedureSaveReqVO.class).setId(null);
// 调用
Long procedureId = procedureService.createProcedure(createReqVO);
// 断言
assertNotNull(procedureId);
// 校验记录的属性是否正确
ProcedureDO procedure = procedureMapper.selectById(procedureId);
assertPojoEquals(createReqVO, procedure, "id");
}
@Test
public void testUpdateProcedure_success() {
// mock 数据
ProcedureDO dbProcedure = randomPojo(ProcedureDO.class);
procedureMapper.insert(dbProcedure);// @Sql: 先插入出一条存在的数据
// 准备参数
ProcedureSaveReqVO updateReqVO = randomPojo(ProcedureSaveReqVO.class, o -> {
o.setId(dbProcedure.getId()); // 设置更新的 ID
});
// 调用
procedureService.updateProcedure(updateReqVO);
// 校验是否更新正确
ProcedureDO procedure = procedureMapper.selectById(updateReqVO.getId()); // 获取最新的
assertPojoEquals(updateReqVO, procedure);
}
@Test
public void testUpdateProcedure_notExists() {
// 准备参数
ProcedureSaveReqVO updateReqVO = randomPojo(ProcedureSaveReqVO.class);
// 调用, 并断言异常
assertServiceException(() -> procedureService.updateProcedure(updateReqVO), PROCEDURE_NOT_EXISTS);
}
@Test
public void testDeleteProcedure_success() {
// mock 数据
ProcedureDO dbProcedure = randomPojo(ProcedureDO.class);
procedureMapper.insert(dbProcedure);// @Sql: 先插入出一条存在的数据
// 准备参数
Long id = dbProcedure.getId();
// 调用
procedureService.deleteProcedure(id);
// 校验数据不存在了
assertNull(procedureMapper.selectById(id));
}
@Test
public void testDeleteProcedure_notExists() {
// 准备参数
Long id = randomLongId();
// 调用, 并断言异常
assertServiceException(() -> procedureService.deleteProcedure(id), PROCEDURE_NOT_EXISTS);
}
@Test
@Disabled // TODO 请修改 null 为需要的值,然后删除 @Disabled 注解
public void testGetProcedurePage() {
// mock 数据
ProcedureDO dbProcedure = randomPojo(ProcedureDO.class, o -> { // 等会查询到
o.setCode(null);
o.setName(null);
o.setDescription(null);
o.setStatus(null);
o.setCreator(null);
o.setCreateTime(null);
o.setUpdater(null);
o.setUpdateTime(null);
o.setDeleted(null);
o.setTenantId(null);
o.setIsReport(null);
o.setWid(null);
});
procedureMapper.insert(dbProcedure);
// 测试 code 不匹配
procedureMapper.insert(cloneIgnoreId(dbProcedure, o -> o.setCode(null)));
// 测试 name 不匹配
procedureMapper.insert(cloneIgnoreId(dbProcedure, o -> o.setName(null)));
// 测试 description 不匹配
procedureMapper.insert(cloneIgnoreId(dbProcedure, o -> o.setDescription(null)));
// 测试 status 不匹配
procedureMapper.insert(cloneIgnoreId(dbProcedure, o -> o.setStatus(null)));
// 测试 creator 不匹配
procedureMapper.insert(cloneIgnoreId(dbProcedure, o -> o.setCreator(null)));
// 测试 createTime 不匹配
procedureMapper.insert(cloneIgnoreId(dbProcedure, o -> o.setCreateTime(null)));
// 测试 updater 不匹配
procedureMapper.insert(cloneIgnoreId(dbProcedure, o -> o.setUpdater(null)));
// 测试 updateTime 不匹配
procedureMapper.insert(cloneIgnoreId(dbProcedure, o -> o.setUpdateTime(null)));
// 测试 deleted 不匹配
procedureMapper.insert(cloneIgnoreId(dbProcedure, o -> o.setDeleted(null)));
// 测试 tenantId 不匹配
procedureMapper.insert(cloneIgnoreId(dbProcedure, o -> o.setTenantId(null)));
// 测试 isReport 不匹配
procedureMapper.insert(cloneIgnoreId(dbProcedure, o -> o.setIsReport(null)));
// 测试 wid 不匹配
procedureMapper.insert(cloneIgnoreId(dbProcedure, o -> o.setWid(null)));
// 准备参数
ProcedurePageReqVO reqVO = new ProcedurePageReqVO();
reqVO.setCode(null);
reqVO.setName(null);
reqVO.setDescription(null);
reqVO.setStatus(null);
reqVO.setCreator(null);
reqVO.setCreateTime(buildBetweenTime(2023, 2, 1, 2023, 2, 28));
reqVO.setUpdater(null);
reqVO.setUpdateTime(buildBetweenTime(2023, 2, 1, 2023, 2, 28));
reqVO.setDeleted(null);
reqVO.setTenantId(null);
reqVO.setIsReport(null);
reqVO.setWid(null);
// 调用
PageResult<ProcedureDO> pageResult = procedureService.getProcedurePage(reqVO);
// 断言
assertEquals(1, pageResult.getTotal());
assertEquals(1, pageResult.getList().size());
assertPojoEquals(dbProcedure, pageResult.getList().get(0));
}
}

@ -0,0 +1,41 @@
import request from '@/config/axios'
export interface ProcedureVO {
id: number
code: string
name: string
description: string
status: number
isReport: number
wid: number
}
// 查询工序分页
export const getProcedurePage = async (params) => {
return await request.get({ url: `/heli/procedure/page`, params })
}
// 查询工序详情
export const getProcedure = async (id: number) => {
return await request.get({ url: `/heli/procedure/get?id=` + id })
}
// 新增工序
export const createProcedure = async (data: ProcedureVO) => {
return await request.post({ url: `/heli/procedure/create`, data })
}
// 修改工序
export const updateProcedure = async (data: ProcedureVO) => {
return await request.put({ url: `/heli/procedure/update`, data })
}
// 删除工序
export const deleteProcedure = async (id: number) => {
return await request.delete({ url: `/heli/procedure/delete?id=` + id })
}
// 导出工序 Excel
export const exportProcedure = async (params) => {
return await request.download({ url: `/heli/procedure/export-excel`, params })
}

@ -0,0 +1,132 @@
<template>
<Dialog :title="dialogTitle" v-model="dialogVisible">
<el-form
ref="formRef"
:model="formData"
:rules="formRules"
label-width="100px"
v-loading="formLoading"
>
<el-form-item label="工序编号" prop="code">
<el-input v-model="formData.code" placeholder="请输入工序编号" />
</el-form-item>
<el-form-item label="工序名称,唯一" prop="name">
<el-input v-model="formData.name" placeholder="请输入工序名称,唯一" />
</el-form-item>
<el-form-item label="工序描述" prop="description">
<Editor v-model="formData.description" height="150px" />
</el-form-item>
<el-form-item label="状态,1表示正常2表示禁用" prop="status">
<el-radio-group v-model="formData.status">
<el-radio
v-for="dict in getIntDictOptions(DICT_TYPE.HELI_SYSTEM_COMMON_STATUS)"
:key="dict.value"
:label="dict.value"
>
{{ dict.label }}
</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="是否需要报工" prop="isReport">
<el-radio-group v-model="formData.isReport">
<el-radio
v-for="dict in getIntDictOptions(DICT_TYPE.INFRA_BOOLEAN_STRING)"
:key="dict.value"
:label="dict.value"
>
{{ dict.label }}
</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="车间ID" prop="wid">
<el-input v-model="formData.wid" placeholder="请输入车间ID" />
</el-form-item>
</el-form>
<template #footer>
<el-button @click="submitForm" type="primary" :disabled="formLoading"> </el-button>
<el-button @click="dialogVisible = false"> </el-button>
</template>
</Dialog>
</template>
<script setup lang="ts">
import { getIntDictOptions, DICT_TYPE } from '@/utils/dict'
import * as ProcedureApi from '@/api/heli/procedure'
const { t } = useI18n() //
const message = useMessage() //
const dialogVisible = ref(false) //
const dialogTitle = ref('') //
const formLoading = ref(false) // 12
const formType = ref('') // create - update -
const formData = ref({
id: undefined,
code: undefined,
name: undefined,
description: undefined,
status: undefined,
isReport: undefined,
wid: undefined,
})
const formRules = reactive({
name: [{ required: true, message: '工序名称,唯一不能为空', trigger: 'blur' }],
status: [{ required: true, message: '状态,1表示正常2表示禁用不能为空', trigger: 'blur' }],
})
const formRef = ref() // Ref
/** 打开弹窗 */
const open = async (type: string, id?: number) => {
dialogVisible.value = true
dialogTitle.value = t('action.' + type)
formType.value = type
resetForm()
//
if (id) {
formLoading.value = true
try {
formData.value = await ProcedureApi.getProcedure(id)
} finally {
formLoading.value = false
}
}
}
defineExpose({ open }) // open
/** 提交表单 */
const emit = defineEmits(['success']) // success
const submitForm = async () => {
//
await formRef.value.validate()
//
formLoading.value = true
try {
const data = formData.value as unknown as ProcedureApi.ProcedureVO
if (formType.value === 'create') {
await ProcedureApi.createProcedure(data)
message.success(t('common.createSuccess'))
} else {
await ProcedureApi.updateProcedure(data)
message.success(t('common.updateSuccess'))
}
dialogVisible.value = false
//
emit('success')
} finally {
formLoading.value = false
}
}
/** 重置表单 */
const resetForm = () => {
formData.value = {
id: undefined,
code: undefined,
name: undefined,
description: undefined,
status: undefined,
isReport: undefined,
wid: undefined,
}
formRef.value?.resetFields()
}
</script>

@ -0,0 +1,306 @@
<template>
<ContentWrap>
<!-- 搜索工作栏 -->
<el-form
class="-mb-15px"
:model="queryParams"
ref="queryFormRef"
:inline="true"
label-width="68px"
>
<el-form-item label="工序编号" prop="code">
<el-input
v-model="queryParams.code"
placeholder="请输入工序编号"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="工序名称,唯一" prop="name">
<el-input
v-model="queryParams.name"
placeholder="请输入工序名称,唯一"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="状态,1表示正常2表示禁用" prop="status">
<el-select
v-model="queryParams.status"
placeholder="请选择状态,1表示正常2表示禁用"
clearable
class="!w-240px"
>
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HELI_SYSTEM_COMMON_STATUS)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="创建者" prop="creator">
<el-input
v-model="queryParams.creator"
placeholder="请输入创建者"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="创建时间" prop="createTime">
<el-date-picker
v-model="queryParams.createTime"
value-format="YYYY-MM-DD HH:mm:ss"
type="daterange"
start-placeholder="开始日期"
end-placeholder="结束日期"
:default-time="[new Date('1 00:00:00'), new Date('1 23:59:59')]"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="更新者" prop="updater">
<el-input
v-model="queryParams.updater"
placeholder="请输入更新者"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="更新时间" prop="updateTime">
<el-date-picker
v-model="queryParams.updateTime"
value-format="YYYY-MM-DD HH:mm:ss"
type="daterange"
start-placeholder="开始日期"
end-placeholder="结束日期"
:default-time="[new Date('1 00:00:00'), new Date('1 23:59:59')]"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="是否删除" prop="deleted">
<el-select
v-model="queryParams.deleted"
placeholder="请选择是否删除"
clearable
class="!w-240px"
>
<el-option label="请选择字典生成" value="" />
</el-select>
</el-form-item>
<el-form-item label="租户编号" prop="tenantId">
<el-input
v-model="queryParams.tenantId"
placeholder="请输入租户编号"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="是否需要报工" prop="isReport">
<el-select
v-model="queryParams.isReport"
placeholder="请选择是否需要报工"
clearable
class="!w-240px"
>
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.INFRA_BOOLEAN_STRING)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="车间ID" prop="wid">
<el-input
v-model="queryParams.wid"
placeholder="请输入车间ID"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item>
<el-button @click="handleQuery"><Icon icon="ep:search" class="mr-5px" /> 搜索</el-button>
<el-button @click="resetQuery"><Icon icon="ep:refresh" class="mr-5px" /> 重置</el-button>
<el-button
type="primary"
plain
@click="openForm('create')"
v-hasPermi="['heli:procedure:create']"
>
<Icon icon="ep:plus" class="mr-5px" /> 新增
</el-button>
<el-button
type="success"
plain
@click="handleExport"
:loading="exportLoading"
v-hasPermi="['heli:procedure:export']"
>
<Icon icon="ep:download" class="mr-5px" /> 导出
</el-button>
</el-form-item>
</el-form>
</ContentWrap>
<!-- 列表 -->
<ContentWrap>
<el-table v-loading="loading" :data="list" :stripe="true" :show-overflow-tooltip="true">
<el-table-column label="自增字段,唯一" align="center" prop="id" />
<el-table-column label="工序编号" align="center" prop="code" />
<el-table-column label="工序名称,唯一" align="center" prop="name" />
<el-table-column label="工序描述" align="center" prop="description" />
<el-table-column label="状态,1表示正常2表示禁用" align="center" prop="status">
<template #default="scope">
<dict-tag :type="DICT_TYPE.HELI_SYSTEM_COMMON_STATUS" :value="scope.row.status" />
</template>
</el-table-column>
<el-table-column
label="创建时间"
align="center"
prop="createTime"
:formatter="dateFormatter"
width="180px"
/>
<el-table-column label="是否需要报工" align="center" prop="isReport">
<template #default="scope">
<dict-tag :type="DICT_TYPE.INFRA_BOOLEAN_STRING" :value="scope.row.isReport" />
</template>
</el-table-column>
<el-table-column label="车间ID" align="center" prop="wid" />
<el-table-column label="操作" align="center">
<template #default="scope">
<el-button
link
type="primary"
@click="openForm('update', scope.row.id)"
v-hasPermi="['heli:procedure:update']"
>
编辑
</el-button>
<el-button
link
type="danger"
@click="handleDelete(scope.row.id)"
v-hasPermi="['heli:procedure:delete']"
>
删除
</el-button>
</template>
</el-table-column>
</el-table>
<!-- 分页 -->
<Pagination
:total="total"
v-model:page="queryParams.pageNo"
v-model:limit="queryParams.pageSize"
@pagination="getList"
/>
</ContentWrap>
<!-- 表单弹窗添加/修改 -->
<ProcedureForm ref="formRef" @success="getList" />
</template>
<script setup lang="ts">
import { getIntDictOptions, DICT_TYPE } from '@/utils/dict'
import { dateFormatter } from '@/utils/formatTime'
import download from '@/utils/download'
import * as ProcedureApi from '@/api/heli/procedure'
import ProcedureForm from './ProcedureForm.vue'
defineOptions({ name: 'Procedure' })
const message = useMessage() //
const { t } = useI18n() //
const loading = ref(true) //
const list = ref([]) //
const total = ref(0) //
const queryParams = reactive({
pageNo: 1,
pageSize: 10,
code: undefined,
name: undefined,
description: undefined,
status: undefined,
creator: undefined,
createTime: [],
updater: undefined,
updateTime: [],
deleted: undefined,
tenantId: undefined,
isReport: undefined,
wid: undefined,
})
const queryFormRef = ref() //
const exportLoading = ref(false) //
/** 查询列表 */
const getList = async () => {
loading.value = true
try {
const data = await ProcedureApi.getProcedurePage(queryParams)
list.value = data.list
total.value = data.total
} finally {
loading.value = false
}
}
/** 搜索按钮操作 */
const handleQuery = () => {
queryParams.pageNo = 1
getList()
}
/** 重置按钮操作 */
const resetQuery = () => {
queryFormRef.value.resetFields()
handleQuery()
}
/** 添加/修改操作 */
const formRef = ref()
const openForm = (type: string, id?: number) => {
formRef.value.open(type, id)
}
/** 删除按钮操作 */
const handleDelete = async (id: number) => {
try {
//
await message.delConfirm()
//
await ProcedureApi.deleteProcedure(id)
message.success(t('common.delSuccess'))
//
await getList()
} catch {}
}
/** 导出按钮操作 */
const handleExport = async () => {
try {
//
await message.exportConfirm()
//
exportLoading.value = true
const data = await ProcedureApi.exportProcedure(queryParams)
download.excel(data, '工序.xls')
} catch {
} finally {
exportLoading.value = false
}
}
/** 初始化 **/
onMounted(() => {
getList()
})
</script>
Loading…
Cancel
Save