refactor(mes): 重构设备保养记录模块,抽取可复用 Select 组件

1. 新增 DvMachinerySelect、DvCheckPlanSelect、UserSelect 三个通用选择器组件
2. MaintenRecordForm 和 index 页面改用 Select 组件替代内联远程搜索逻辑
3. MaintenRecordLineForm 合并到 MaintenRecordLineList(参考 pro/route 风格)
4. API 文件 maintenRecordLine.ts 迁移至 line/index.ts
5. 保养记录状态枚举从 10/20 改为 0/1,与后端对齐
pull/871/MERGE
YunaiV 2026-02-20 14:42:46 +08:00
parent 083c187f2f
commit 9392e32630
5 changed files with 276 additions and 513 deletions

View File

@ -2,94 +2,32 @@
<Dialog :title="dialogTitle" v-model="dialogVisible" width="900px">
<el-form
ref="formRef"
v-loading="formLoading"
:model="formData"
:rules="formRules"
label-width="100px"
v-loading="formLoading"
>
<el-row>
<el-col :span="8">
<!-- TODO @AI设备 select不用 设备名称品牌规格型号 -->
<!-- DONE @AI这里抽成一个独立的 components 组件一定要按照我说的 -->
<el-form-item label="设备" prop="machineryId">
<el-select
v-model="formData.machineryId"
filterable
remote
reserve-keyword
placeholder="请输入设备名称或编码搜索"
:remote-method="getMachineryOptions"
@change="handleMachineryChange"
>
<el-option
v-for="item in machineryOptions"
:key="item.id"
:label="item.name"
:value="item.id"
/>
</el-select>
<DvMachinerySelect v-model="formData.machineryId" />
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="设备名称">
<el-input v-model="machineryInfo.name" disabled />
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="品牌">
<el-input v-model="machineryInfo.brand" disabled />
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="24">
<el-form-item label="规格型号">
<el-input v-model="machineryInfo.spec" disabled type="textarea" />
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="8">
<!-- TODO @AI使用包养计划的 select 组件 -->
<!-- DONE @AI这里抽成一个独立的 components 组件一定要按照我说的 -->
<el-form-item label="保养计划" prop="planId">
<el-select
v-model="formData.planId"
filterable
remote
reserve-keyword
placeholder="请输入计划名称搜索"
:remote-method="getPlanOptions"
>
<el-option
v-for="item in planOptions"
:key="item.id"
:label="item.name"
:value="item.id"
/>
</el-select>
<DvCheckPlanSelect v-model="formData.planId" />
</el-form-item>
</el-col>
<el-col :span="8">
<!-- TODO @AI保养人的 select -->
<!-- DONE @AIuser-select 封装一个到 views/system/user/components -->
<el-form-item label="保养人" prop="userId">
<el-select
v-model="formData.userId"
filterable
remote
reserve-keyword
placeholder="请输入保养人搜索"
:remote-method="getUserOptions"
>
<el-option
v-for="item in userOptions"
:key="item.id"
:label="item.nickname"
:value="item.id"
/>
</el-select>
<UserSelect v-model="formData.userId" placeholder="请选择保养人" />
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="8">
<el-form-item label="保养时间" prop="maintenTime">
<el-date-picker
@ -101,7 +39,6 @@
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="24">
<el-form-item label="备注" prop="remark">
@ -110,69 +47,48 @@
</el-col>
</el-row>
</el-form>
<!-- DONE @AI编辑时展示保养项目明细 -->
<template v-if="formData.id">
<el-divider content-position="center">保养项目明细</el-divider>
<MaintenRecordLineList :record-id="formData.id" />
</template>
<template #footer>
<el-button :disabled="formLoading" type="primary" @click="submitForm"> </el-button>
<el-button @click="dialogVisible = false"> </el-button>
<el-button type="primary" @click="submitForm" :disabled="formLoading"> </el-button>
<!-- TODO @AI提交挪到 index.vue 外面 -->
<el-button
type="success"
@click="handleFinish"
v-if="formData.id && formData.status === 10"
:disabled="formLoading"
> </el-button
>
</template>
</Dialog>
</template>
<script setup lang="ts">
import { DvMaintenRecordApi } from '@/api/mes/dv/maintenrecord'
import { DvMachineryApi } from '@/api/mes/dv/machinery'
import * as UserApi from '@/api/system/user'
import request from '@/config/axios'
import MaintenRecordLineList from './components/MaintenRecordLineList.vue'
// TODO @AI /Users/yunai/Java/yudao-all-in-one/yudao-ui-admin-vue3/src/views/system/user/UserForm.vue
import DvMachinerySelect from '@/views/mes/dv/machinery/components/DvMachinerySelect.vue'
import DvCheckPlanSelect from '@/views/mes/dv/checkplan/components/DvCheckPlanSelect.vue'
import UserSelect from '@/views/system/user/components/UserSelect.vue'
import MaintenRecordLineList from './MaintenRecordLineList.vue'
defineOptions({ name: 'MaintenRecordForm' })
const { t } = useI18n()
const message = useMessage()
const { t } = useI18n() //
const message = useMessage() //
const dialogVisible = ref(false)
const dialogTitle = ref('')
const formLoading = ref(false)
const formType = ref('')
const dialogVisible = ref(false) //
const dialogTitle = ref('') //
const formLoading = ref(false) // 12
const formType = ref('') // create - update -
const formData = ref({
id: undefined,
planId: undefined,
machineryId: undefined,
maintenTime: undefined,
userId: undefined,
status: 10,
status: 0,
remark: ''
})
const formRules = reactive({
machineryId: [{ required: true, message: '设备不能为空', trigger: 'blur' }],
maintenTime: [{ required: true, message: '保养时间不能为空', trigger: 'blur' }]
})
const formRef = ref()
const machineryOptions = ref<any[]>([])
const planOptions = ref<any[]>([])
const userOptions = ref<any[]>([])
const machineryInfo = reactive({
name: '',
brand: '',
spec: ''
})
const formRef = ref() // Ref
/** 打开弹窗 */
const open = async (type: string, id?: number) => {
@ -185,36 +101,21 @@ const open = async (type: string, id?: number) => {
formLoading.value = true
try {
formData.value = await DvMaintenRecordApi.getMaintenRecord(id)
//
if (formData.value.machineryId) {
const machinery = await DvMachineryApi.getMachinery(formData.value.machineryId)
if (machinery) {
machineryOptions.value = [machinery]
handleMachineryChange(machinery.id)
}
}
// TODO @ DvCheckPlanApi DvCheckPlanApi.getCheckPlan()
if (formData.value.planId) {
const plan = await request.get({
url: `/mes/dv/check-plan/get?id=${formData.value.planId}`
})
if (plan) planOptions.value = [plan]
}
if (formData.value.userId) {
const user = await UserApi.getUser(formData.value.userId)
if (user) userOptions.value = [user]
}
} finally {
formLoading.value = false
}
}
}
defineExpose({ open })
defineExpose({ open }) // open
/** 提交表单 */
const emit = defineEmits(['success'])
const emit = defineEmits(['success']) // success
const submitForm = async () => {
await formRef.value.validate()
//
if (!formRef) return
const valid = await formRef.value.validate()
if (!valid) return
//
formLoading.value = true
try {
const data = formData.value as any
@ -226,30 +127,13 @@ const submitForm = async () => {
message.success(t('common.updateSuccess'))
}
dialogVisible.value = false
//
emit('success')
} finally {
formLoading.value = false
}
}
/** 提交按钮(完成保养) */
const handleFinish = async () => {
if (formData.value.id && formData.value.status === 10) {
formLoading.value = true
try {
formData.value.status = 20
await DvMaintenRecordApi.updateMaintenRecord(formData.value as any)
message.success('已提交保养完成')
dialogVisible.value = false
emit('success')
} catch {
formData.value.status = 10
} finally {
formLoading.value = false
}
}
}
/** 重置表单 */
const resetForm = () => {
formData.value = {
@ -258,48 +142,9 @@ const resetForm = () => {
machineryId: undefined,
maintenTime: undefined,
userId: undefined,
status: 10,
status: 0,
remark: ''
}
machineryInfo.name = ''
machineryInfo.brand = ''
machineryInfo.spec = ''
formRef.value?.resetFields()
}
/** 获取设备选项 */
const getMachineryOptions = async (query: string) => {
const data = await DvMachineryApi.getMachineryPage({ name: query, pageNo: 1, pageSize: 20 })
machineryOptions.value = data.list
}
/** 处理设备变化 */
const handleMachineryChange = async (val: number) => {
const selected = machineryOptions.value.find((item) => item.id === val)
if (selected) {
machineryInfo.name = selected.name
machineryInfo.brand = selected.brand
machineryInfo.spec = selected.spec
}
}
/** 获取计划选项 */
// TODO @ DvCheckPlanApi DvCheckPlanApi.getCheckPlanPage()
const getPlanOptions = async (query: string) => {
try {
const data = await request.get({
url: `/mes/dv/check-plan/page`,
params: { name: query, pageNo: 1, pageSize: 20 }
})
planOptions.value = data.list
} catch {}
}
/** 获取用户选项 */
const getUserOptions = async (query: string) => {
try {
const data = await UserApi.getUserPage({ nickname: query, pageNo: 1, pageSize: 20 })
userOptions.value = data.list
} catch {}
}
</script>

View File

@ -0,0 +1,203 @@
<!-- MES 设备保养记录明细列表 -->
<template>
<div>
<!-- 操作栏 -->
<el-row class="mb-10px" v-if="!disabled">
<el-button type="primary" plain @click="openForm('create')">
<Icon icon="ep:plus" class="mr-5px" /> 添加明细
</el-button>
</el-row>
<!-- 列表 -->
<el-table v-loading="loading" :data="list" :stripe="true" :show-overflow-tooltip="true">
<el-table-column label="项目名称" align="center" prop="subjectName" />
<el-table-column label="项目内容" align="center" prop="subjectContent" />
<el-table-column label="标准" align="center" prop="subjectStandard" />
<el-table-column label="保养结果" align="center" prop="status">
<template #default="scope">
<dict-tag :type="DICT_TYPE.MES_MAINTEN_STATUS" :value="scope.row.status" />
</template>
</el-table-column>
<el-table-column label="异常描述" align="center" prop="result" />
<el-table-column label="操作" align="center" width="130" v-if="!disabled">
<template #default="scope">
<el-button link type="primary" @click="openForm('update', scope.row)">编辑</el-button>
<el-button link type="danger" @click="handleDelete(scope.row.id)"></el-button>
</template>
</el-table-column>
</el-table>
<Pagination
:total="total"
v-model:page="queryParams.pageNo"
v-model:limit="queryParams.pageSize"
@pagination="getList"
/>
<!-- 表单弹窗添加/修改 -->
<Dialog :title="formTitle" v-model="formVisible" width="500px">
<el-form ref="formRef" :model="formData" :rules="formRules" label-width="80px">
<el-form-item label="项目" prop="subjectId">
<el-select
v-model="formData.subjectId"
filterable
remote
reserve-keyword
placeholder="请输入项目名称搜索"
:remote-method="getSubjectOptions"
>
<el-option
v-for="item in subjectOptions"
:key="item.id"
:label="item.name"
:value="item.id"
/>
</el-select>
</el-form-item>
<el-form-item label="保养结果" prop="status">
<el-radio-group v-model="formData.status">
<el-radio
v-for="dict in getIntDictOptions(DICT_TYPE.MES_MAINTEN_STATUS)"
:key="dict.value"
:value="dict.value"
>
{{ dict.label }}
</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="异常描述" prop="result">
<el-input v-model="formData.result" type="textarea" placeholder="请输入异常描述" />
</el-form-item>
<el-form-item label="备注" prop="remark">
<el-input v-model="formData.remark" type="textarea" placeholder="请输入备注" />
</el-form-item>
</el-form>
<template #footer>
<el-button @click="formVisible = false"> </el-button>
<el-button type="primary" @click="submitForm" :loading="formLoading"> </el-button>
</template>
</Dialog>
</div>
</template>
<script setup lang="ts">
import { getIntDictOptions, DICT_TYPE } from '@/utils/dict'
import { DvMaintenRecordLineApi } from '@/api/mes/dv/maintenrecord/line'
import { DvSubjectApi } from '@/api/mes/dv/subject'
defineOptions({ name: 'MaintenRecordLineList' })
const props = defineProps<{
recordId: number
disabled?: boolean
}>()
const message = useMessage() //
const { t } = useI18n() //
const loading = ref(false) //
const list = ref([]) //
const total = ref(0) //
const queryParams = reactive({
pageNo: 1,
pageSize: 10,
recordId: props.recordId
})
//
const formVisible = ref(false) //
const formTitle = ref('') //
const formLoading = ref(false) //
const formType = ref('') // create - update -
const formRef = ref() // Ref
const formData = ref<any>({}) //
const formRules = reactive({
subjectId: [{ required: true, message: '项目不能为空', trigger: 'blur' }],
status: [{ required: true, message: '保养结果不能为空', trigger: 'blur' }]
})
const subjectOptions = ref<any[]>([]) //
/** 查询列表 */
const getList = async () => {
loading.value = true
try {
const data = await DvMaintenRecordLineApi.getMaintenRecordLinePage(queryParams)
list.value = data.list
total.value = data.total
} finally {
loading.value = false
}
}
/** 添加/修改操作 */
const openForm = async (type: string, row?: any) => {
formVisible.value = true
formTitle.value = type === 'create' ? '添加明细' : '编辑明细'
formType.value = type
if (type === 'create') {
formData.value = {
recordId: props.recordId,
subjectId: undefined,
status: 1,
result: '',
remark: ''
}
} else {
formData.value = { ...row }
if (row.subjectId) {
const subject = await DvSubjectApi.getSubject(row.subjectId)
if (subject) subjectOptions.value = [subject]
}
}
formRef.value?.resetFields()
}
/** 提交表单 */
const submitForm = async () => {
const valid = await formRef.value.validate()
if (!valid) return
formLoading.value = true
try {
if (formType.value === 'create') {
await DvMaintenRecordLineApi.createMaintenRecordLine(formData.value)
message.success(t('common.createSuccess'))
} else {
await DvMaintenRecordLineApi.updateMaintenRecordLine(formData.value)
message.success(t('common.updateSuccess'))
}
formVisible.value = false
await getList()
} finally {
formLoading.value = false
}
}
/** 删除按钮操作 */
const handleDelete = async (id: number) => {
try {
await message.delConfirm()
await DvMaintenRecordLineApi.deleteMaintenRecordLine(id)
message.success(t('common.delSuccess'))
await getList()
} catch {}
}
/** 获取项目选项 */
const getSubjectOptions = async (query: string) => {
try {
const data = await DvSubjectApi.getSubjectPage({ name: query, pageNo: 1, pageSize: 20 })
subjectOptions.value = data.list
} catch {}
}
/** 监听记录编号变化 */
watch(
() => props.recordId,
(val) => {
if (val) {
queryParams.recordId = val
getList()
}
},
{ immediate: true }
)
</script>

View File

@ -1,149 +0,0 @@
<!-- TODO @AI参考别的模块合并到 List.vue -->
<!-- TODO @AI参考 /Users/yunai/Java/yudao-all-in-one/yudao-ui-admin-vue3/src/views/mes/pro/route -->
<template>
<Dialog :title="dialogTitle" v-model="dialogVisible" width="500px">
<el-form
ref="formRef"
:model="formData"
:rules="formRules"
label-width="80px"
v-loading="formLoading"
>
<el-form-item label="项目" prop="subjectId">
<el-select
v-model="formData.subjectId"
filterable
remote
reserve-keyword
placeholder="请输入项目名称搜索"
:remote-method="getSubjectOptions"
>
<el-option
v-for="item in subjectOptions"
:key="item.id"
:label="item.name"
:value="item.id"
/>
</el-select>
</el-form-item>
<el-form-item label="保养结果" prop="status">
<el-radio-group v-model="formData.status">
<el-radio
v-for="dict in getIntDictOptions(DICT_TYPE.MES_MAINTEN_STATUS)"
:key="dict.value"
:value="dict.value"
>
{{ dict.label }}
</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="异常描述" prop="result">
<el-input v-model="formData.result" type="textarea" placeholder="请输入异常描述" />
</el-form-item>
<el-form-item label="备注" prop="remark">
<el-input v-model="formData.remark" type="textarea" placeholder="请输入备注" />
</el-form-item>
</el-form>
<template #footer>
<el-button @click="dialogVisible = false"> </el-button>
<el-button type="primary" @click="submitForm" :disabled="formLoading"> </el-button>
</template>
</Dialog>
</template>
<script setup lang="ts">
import { DvMaintenRecordLineApi } from '@/api/mes/dv/maintenrecord/maintenRecordLine'
import { DvSubjectApi } from '@/api/mes/dv/subject'
import { DICT_TYPE, getIntDictOptions } from '@/utils/dict'
defineOptions({ name: 'MaintenRecordLineForm' })
const { t } = useI18n()
const message = useMessage()
const dialogVisible = ref(false)
const dialogTitle = ref('')
const formLoading = ref(false)
const formType = ref('')
const formData = ref({
id: undefined,
recordId: undefined,
subjectId: undefined,
status: 1,
result: '',
remark: ''
})
const formRules = reactive({
subjectId: [{ required: true, message: '项目不能为空', trigger: 'blur' }],
status: [{ required: true, message: '保养结果不能为空', trigger: 'blur' }]
})
const formRef = ref()
const subjectOptions = ref<any[]>([])
/** 打开弹窗 */
const open = async (type: string, id?: number, recordId?: number) => {
dialogVisible.value = true
dialogTitle.value = t('action.' + type)
formType.value = type
resetForm()
formData.value.recordId = recordId
if (id) {
formLoading.value = true
try {
formData.value = await DvMaintenRecordLineApi.getMaintenRecordLine(id)
//
if (formData.value.subjectId) {
const subject = await DvSubjectApi.getSubject(formData.value.subjectId)
if (subject) subjectOptions.value = [subject]
}
} finally {
formLoading.value = false
}
}
}
defineExpose({ open })
/** 提交表单 */
const emit = defineEmits(['success'])
const submitForm = async () => {
await formRef.value.validate()
formLoading.value = true
try {
const data = formData.value as any
if (formType.value === 'create') {
await DvMaintenRecordLineApi.createMaintenRecordLine(data)
message.success(t('common.createSuccess'))
} else {
await DvMaintenRecordLineApi.updateMaintenRecordLine(data)
message.success(t('common.updateSuccess'))
}
dialogVisible.value = false
emit('success')
} finally {
formLoading.value = false
}
}
/** 重置表单 */
const resetForm = () => {
formData.value = {
id: undefined,
recordId: undefined,
subjectId: undefined,
status: 1,
result: '',
remark: ''
}
formRef.value?.resetFields()
}
/** 获取项目选项 */
const getSubjectOptions = async (query: string) => {
try {
const data = await DvSubjectApi.getSubjectPage({ name: query, pageNo: 1, pageSize: 20 })
subjectOptions.value = data.list
} catch {}
}
</script>

View File

@ -1,129 +0,0 @@
<!-- TODO @AI参考 /Users/yunai/Java/yudao-all-in-one/yudao-ui-admin-vue3/src/views/mes/pro/route -->
<template>
<div class="app-container">
<el-row :gutter="10" class="mb8" v-if="!disabled">
<el-col :span="1.5">
<el-button
type="primary"
plain
@click="openForm('create')"
v-hasPermi="['mes:dv-mainten-record:update']"
>
<Icon icon="ep:plus" class="mr-5px" /> 新增
</el-button>
</el-col>
</el-row>
<el-table v-loading="loading" :data="list">
<el-table-column label="项目名称" align="center" prop="subjectName" />
<el-table-column label="项目内容" align="center" prop="subjectContent" />
<el-table-column label="标准" align="center" prop="subjectStandard" />
<el-table-column label="保养结果" align="center" prop="status">
<template #default="scope">
<dict-tag :type="DICT_TYPE.MES_MAINTEN_STATUS" :value="scope.row.status" />
</template>
</el-table-column>
<el-table-column label="异常描述" align="center" prop="result" />
<el-table-column
label="操作"
align="center"
class-name="small-padding fixed-width"
v-if="!disabled"
>
<template #default="scope">
<el-button
link
type="primary"
@click="openForm('update', scope.row.id)"
v-hasPermi="['mes:dv-mainten-record:update']"
>
编辑
</el-button>
<el-button
link
type="danger"
@click="handleDelete(scope.row.id)"
v-hasPermi="['mes:dv-mainten-record:update']"
>
删除
</el-button>
</template>
</el-table-column>
</el-table>
<Pagination
:total="total"
v-model:page="queryParams.pageNo"
v-model:limit="queryParams.pageSize"
@pagination="getList"
/>
<MaintenRecordLineForm ref="formRef" @success="getList" />
</div>
</template>
<script setup lang="ts">
import { DvMaintenRecordLineApi } from '@/api/mes/dv/maintenrecord/maintenRecordLine'
import MaintenRecordLineForm from './MaintenRecordLineForm.vue'
import { DICT_TYPE } from '@/utils/dict'
const props = defineProps({
recordId: {
type: Number,
required: true
},
disabled: {
type: Boolean,
default: false
}
})
const { t } = useI18n()
const message = useMessage()
const loading = ref(true)
const list = ref([])
const total = ref(0)
const queryParams = reactive({
pageNo: 1,
pageSize: 10,
recordId: props.recordId
})
/** 查询列表 */
const getList = async () => {
loading.value = true
try {
const data = await DvMaintenRecordLineApi.getMaintenRecordLinePage(queryParams)
list.value = data.list
total.value = data.total
} finally {
loading.value = false
}
}
/** 添加/修改操作 */
const formRef = ref()
const openForm = (type: string, id?: number) => {
formRef.value.open(type, id, props.recordId)
}
/** 删除按钮操作 */
const handleDelete = async (id: number) => {
try {
await message.delConfirm()
await DvMaintenRecordLineApi.deleteMaintenRecordLine(id)
message.success(t('common.delSuccess'))
await getList()
} catch {}
}
watch(
() => props.recordId,
() => {
queryParams.recordId = props.recordId
getList()
},
{ immediate: true }
)
</script>

View File

@ -8,44 +8,17 @@
:inline="true"
label-width="90px"
>
<!-- TODO @AI计划 select如果没组件就封装一个 -->
<el-form-item label="计划名称" prop="planName">
<el-input
v-model="queryParams.planName"
placeholder="请输入计划名称"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
<!-- DONE @AI计划 select如果没组件就封装一个 -->
<el-form-item label="保养计划" prop="planId">
<DvCheckPlanSelect v-model="queryParams.planId" class="!w-240px" />
</el-form-item>
<!-- TODO @AI设备 select如果没组件就封装一个 -->
<el-form-item label="设备编码" prop="machineryCode">
<el-input
v-model="queryParams.machineryCode"
placeholder="请输入设备编码"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
<!-- DONE @AI设备 select如果没组件就封装一个 -->
<el-form-item label="设备" prop="machineryId">
<DvMachinerySelect v-model="queryParams.machineryId" class="!w-240px" />
</el-form-item>
<el-form-item label="设备名称" prop="machineryName">
<el-input
v-model="queryParams.machineryName"
placeholder="请输入设备名称"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<!-- TODO @AI用户 select如果没组件就封装一个 /Users/yunai/Java/yudao-all-in-one/yudao-ui-admin-vue3/src/views/system/user/components -->
<el-form-item label="保养人" prop="nickname">
<el-input
v-model="queryParams.nickname"
placeholder="请输入保养人名称"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
<!-- DONE @AI用户 select如果没组件就封装一个 -->
<el-form-item label="保养人" prop="userId">
<UserSelect v-model="queryParams.userId" placeholder="请选择保养人" class="!w-240px" />
</el-form-item>
<el-form-item label="保养时间" prop="maintenTime">
<el-date-picker
@ -105,7 +78,6 @@
</el-table-column>
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
<template #default="scope">
<!-- TODO @AI这里加个提交操作 -->
<el-button
link
type="primary"
@ -114,6 +86,15 @@
>
编辑
</el-button>
<el-button
link
type="success"
@click="handleSubmit(scope.row)"
v-if="scope.row.status === 0"
v-hasPermi="['mes:dv-mainten-record:update']"
>
提交
</el-button>
<el-button
link
type="danger"
@ -143,27 +124,29 @@ import { dateFormatter } from '@/utils/formatTime'
import download from '@/utils/download'
import { DvMaintenRecordApi } from '@/api/mes/dv/maintenrecord'
import MaintenRecordForm from './MaintenRecordForm.vue'
import DvMachinerySelect from '@/views/mes/dv/machinery/components/DvMachinerySelect.vue'
import DvCheckPlanSelect from '@/views/mes/dv/checkplan/components/DvCheckPlanSelect.vue'
import UserSelect from '@/views/system/user/components/UserSelect.vue'
import { DICT_TYPE } from '@/utils/dict'
defineOptions({ name: 'MesDvMaintenRecord' })
const message = useMessage()
const { t } = useI18n()
const message = useMessage() //
const { t } = useI18n() //
const loading = ref(true)
const list = ref([])
const total = ref(0)
const loading = ref(true) //
const list = ref([]) //
const total = ref(0) //
const queryParams = reactive({
pageNo: 1,
pageSize: 10,
planName: undefined,
machineryCode: undefined,
machineryName: undefined,
nickname: undefined,
planId: undefined,
machineryId: undefined,
userId: undefined,
maintenTime: []
})
const queryFormRef = ref()
const exportLoading = ref(false)
const queryFormRef = ref() //
const exportLoading = ref(false) //
/** 查询列表 */
const getList = async () => {
@ -195,6 +178,16 @@ const openForm = (type: string, id?: number) => {
formRef.value.open(type, id)
}
/** 提交按钮操作 */
const handleSubmit = async (row: any) => {
try {
await message.confirm('确认提交该保养记录吗?')
await DvMaintenRecordApi.updateMaintenRecord({ ...row, status: 1 })
message.success('提交成功')
await getList()
} catch {}
}
/** 删除按钮操作 */
const handleDelete = async (id: number) => {
try {