feat(mes): 更新班组表单和成员列表组件逻辑

优化班组表单的弹窗标题逻辑,支持不同表单类型的动态标题显示。调整成员列表组件,确保操作按钮仅在编辑模式下可见。简化消息提示内容,提升用户体验。
pull/871/MERGE
YunaiV 2026-04-02 00:27:23 +08:00
parent e0238243aa
commit f133e4f5c5
3 changed files with 35 additions and 27 deletions

View File

@ -59,7 +59,7 @@
<el-button v-if="!isDetail" @click="submitForm" type="primary" :disabled="formLoading">
</el-button>
<el-button @click="dialogVisible = false"></el-button>
<el-button @click="dialogVisible = false"></el-button>
</template>
</Dialog>
</template>
@ -72,16 +72,23 @@ import { MesAutoCodeRuleCode } from '@/views/mes/utils/constants'
import CalTeamMemberList from './CalTeamMemberList.vue'
defineOptions({ name: 'CalTeamForm' })
const emit = defineEmits(['success'])
const { t } = useI18n() //
const message = useMessage() //
const dialogVisible = ref(false) //
const dialogTitle = ref('') //
const formLoading = ref(false) //
const formType = ref('') // create - update -
const formType = ref('') // create - update - detail -
const activeTab = ref('member') // Tab
const isDetail = computed(() => formType.value === 'detail') //
const dialogTitle = computed(() => {
const titles: Record<string, string> = {
create: '新增班组',
update: '编辑班组',
detail: '班组详情'
}
return titles[formType.value] || formType.value
})
const formData = ref({
id: undefined,
code: undefined,
@ -110,10 +117,9 @@ const generateCode = async () => {
/** 打开弹窗 */
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 {
@ -123,10 +129,8 @@ const open = async (type: string, id?: number) => {
}
}
}
defineExpose({ open })
/** 提交表单 */
const emit = defineEmits(['success'])
const submitForm = async () => {
await formRef.value.validate()
formLoading.value = true
@ -134,10 +138,10 @@ const submitForm = async () => {
const data = formData.value as unknown as CalTeamVO
if (formType.value === 'create') {
await CalTeamApi.createTeam(data)
message.success(t('common.createSuccess'))
message.success('新增成功')
} else {
await CalTeamApi.updateTeam(data)
message.success(t('common.updateSuccess'))
message.success('修改成功')
}
dialogVisible.value = false
emit('success')
@ -157,4 +161,6 @@ const resetForm = () => {
}
formRef.value?.resetFields()
}
defineExpose({ open })
</script>

View File

@ -2,7 +2,7 @@
<template>
<div>
<!-- 操作栏 -->
<el-button type="primary" plain size="small" @click="openForm()" class="mb-10px">
<el-button v-if="isEditable" type="primary" plain size="small" @click="openForm()" class="mb-10px">
<Icon icon="ep:plus" class="mr-5px" /> 添加成员
</el-button>
<!-- 列表 -->
@ -11,7 +11,7 @@
<el-table-column label="用户昵称" align="center" prop="nickname" min-width="120" />
<el-table-column label="手机号" align="center" prop="telephone" min-width="120" />
<el-table-column label="备注" align="center" prop="remark" min-width="150" />
<el-table-column label="操作" align="center" width="80">
<el-table-column v-if="isEditable" label="操作" align="center" width="80">
<template #default="scope">
<el-button link type="danger" @click="handleDelete(scope.row.id)"></el-button>
</template>
@ -58,11 +58,14 @@ defineOptions({ name: 'CalTeamMemberList' })
const props = defineProps<{
teamId: number //
formType: string // 表单类型create / update / detail
}>()
const { t } = useI18n() //
const message = useMessage() //
const isEditable = computed(() => ['create', 'update'].includes(props.formType)) //
// ==================== ====================
const loading = ref(false) //
const list = ref<CalTeamMemberVO[]>([]) //
@ -76,6 +79,16 @@ const getList = async () => {
}
}
/** 删除按钮操作 */
const handleDelete = async (id: number) => {
try {
await message.delConfirm()
await CalTeamMemberApi.deleteTeamMember(id)
message.success('删除成功')
await getList()
} catch {}
}
// ==================== / ====================
const dialogVisible = ref(false) //
const formLoading = ref(false) //
@ -106,25 +119,14 @@ const submitForm = async () => {
formLoading.value = true
try {
await CalTeamMemberApi.createTeamMember(formData.value as unknown as CalTeamMemberVO)
message.success(t('common.createSuccess'))
message.success('添加成功')
dialogVisible.value = false
//
await getList()
} finally {
formLoading.value = false
}
}
/** 删除按钮操作 */
const handleDelete = async (id: number) => {
try {
await message.delConfirm()
await CalTeamMemberApi.deleteTeamMember(id)
message.success('删除成功')
await getList()
} catch {}
}
/** 监听 teamId 变化,加载列表 */
watch(
() => props.teamId,

View File

@ -138,6 +138,7 @@ const { t } = useI18n() // 国际化
const loading = ref(true) //
const list = ref<CalTeamVO[]>([]) //
const total = ref(0) //
const exportLoading = ref(false) //
const queryParams = reactive({
pageNo: 1,
pageSize: 10,
@ -146,7 +147,7 @@ const queryParams = reactive({
calendarType: undefined
})
const queryFormRef = ref() //
const exportLoading = ref(false) //
const formRef = ref() //
/** 查询列表 */
const getList = async () => {
@ -173,7 +174,6 @@ const resetQuery = () => {
}
/** 添加/修改操作 */
const formRef = ref()
const openForm = (type: string, id?: number) => {
formRef.value.open(type, id)
}