223 lines
6.5 KiB
Vue
Raw Normal View History

2022-07-28 12:18:38 +08:00
<script setup lang="ts">
import { ref, unref, onMounted } from 'vue'
import dayjs from 'dayjs'
2022-11-17 15:03:13 +08:00
import { ElMessage } from 'element-plus'
2022-07-28 12:18:38 +08:00
import { DICT_TYPE } from '@/utils/dict'
import { useTable } from '@/hooks/web/useTable'
import { useI18n } from '@/hooks/web/useI18n'
import { FormExpose } from '@/components/Form'
import type { UserGroupVO } from '@/api/bpm/userGroup/types'
import { rules, allSchemas } from './group.data'
import * as UserGroupApi from '@/api/bpm/userGroup'
import { getListSimpleUsersApi } from '@/api/system/user'
2022-11-16 10:28:28 +08:00
import { UserVO } from '@/api/system/user'
2022-07-28 12:18:38 +08:00
const { t } = useI18n() // 国际化
// ========== 列表相关 ==========
const { register, tableObject, methods } = useTable<UserGroupVO>({
getListApi: UserGroupApi.getUserGroupPageApi,
delListApi: UserGroupApi.deleteUserGroupApi
})
const { getList, setSearchParams, delList } = methods
// ========== CRUD 相关 ==========
const actionLoading = ref(false) // 遮罩层
const actionType = ref('') // 操作按钮的类型
const dialogVisible = ref(false) // 是否显示弹出层
const dialogTitle = ref('edit') // 弹出层标题
const formRef = ref<FormExpose>() // 表单 Ref
// ========== 用户选择 ==========
const userIds = ref<number[]>([])
const userOptions = ref<UserVO[]>([])
const getUserOptions = async () => {
const res = await getListSimpleUsersApi()
userOptions.value.push(...res)
}
// 设置标题
const setDialogTile = (type: string) => {
dialogTitle.value = t('action.' + type)
actionType.value = type
dialogVisible.value = true
}
// 新增操作
const handleCreate = () => {
setDialogTile('create')
userIds.value = []
}
// 修改操作
const handleUpdate = async (row: UserGroupVO) => {
setDialogTile('update')
// 设置数据
const res = await UserGroupApi.getUserGroupApi(row.id)
userIds.value = res.memberUserIds
unref(formRef)?.setValues(res)
}
// 提交按钮
const submitForm = async () => {
2022-10-17 11:24:22 +08:00
const elForm = unref(formRef)?.getElFormRef()
if (!elForm) return
elForm.validate(async (valid) => {
if (valid) {
actionLoading.value = true
// 提交请求
try {
const data = unref(formRef)?.formModel as UserGroupVO
data.memberUserIds = userIds.value
if (actionType.value === 'create') {
await UserGroupApi.createUserGroupApi(data)
ElMessage.success(t('common.createSuccess'))
} else {
await UserGroupApi.updateUserGroupApi(data)
ElMessage.success(t('common.updateSuccess'))
}
// 操作成功,重新加载列表
dialogVisible.value = false
await getList()
} finally {
actionLoading.value = false
}
2022-07-28 12:18:38 +08:00
}
2022-10-17 11:24:22 +08:00
})
2022-07-28 12:18:38 +08:00
}
// 根据用户名获取用户真实名
const getUserNickName = (userId: number) => {
for (const user of userOptions.value) {
if (user.id === userId) return user.nickname
}
return '未知(' + userId + ')'
}
// ========== 详情相关 ==========
const detailRef = ref() // 详情 Ref
// 详情操作
const handleDetail = async (row: UserGroupVO) => {
// 设置数据
detailRef.value = row
setDialogTile('detail')
}
// ========== 初始化 ==========
onMounted(async () => {
await getList()
await getUserOptions()
})
</script>
2022-07-18 19:06:37 +08:00
<template>
2022-07-28 12:18:38 +08:00
<!-- 搜索工作区 -->
<ContentWrap>
<Search :schema="allSchemas.searchSchema" @search="setSearchParams" @reset="setSearchParams" />
</ContentWrap>
<ContentWrap>
<!-- 操作工具栏 -->
<div class="mb-10px">
2022-11-15 17:42:04 +08:00
<el-button type="primary" v-hasPermi="['bpm:user-group:create']" @click="handleCreate()">
2022-07-28 12:18:38 +08:00
<Icon icon="ep:zoom-in" class="mr-5px" /> {{ t('action.add') }}
</el-button>
</div>
<!-- 列表 -->
<Table
:columns="allSchemas.tableColumns"
:selection="false"
:data="tableObject.tableList"
:loading="tableObject.loading"
:pagination="{
total: tableObject.total
}"
v-model:pageSize="tableObject.pageSize"
v-model:currentPage="tableObject.currentPage"
@register="register"
>
<template #status="{ row }">
<DictTag :type="DICT_TYPE.COMMON_STATUS" :value="row.status" />
</template>
<template #memberUserIds="{ row }">
<span v-for="userId in row.memberUserIds" :key="userId">
{{ getUserNickName(userId) + ' ' }}
</span>
</template>
<template #createTime="{ row }">
<span>{{ dayjs(row.createTime).format('YYYY-MM-DD HH:mm:ss') }}</span>
</template>
<template #action="{ row }">
<el-button
link
type="primary"
v-hasPermi="['bpm:user-group:update']"
@click="handleUpdate(row)"
>
<Icon icon="ep:edit" class="mr-1px" /> {{ t('action.edit') }}
</el-button>
<el-button
link
type="primary"
v-hasPermi="['bpm:user-group:update']"
@click="handleDetail(row)"
>
<Icon icon="ep:view" class="mr-1px" /> {{ t('action.detail') }}
</el-button>
<el-button
link
type="primary"
v-hasPermi="['bpm:user-group:delete']"
2022-07-28 15:56:38 +08:00
@click="delList(row.id, false)"
2022-07-28 12:18:38 +08:00
>
<Icon icon="ep:delete" class="mr-1px" /> {{ t('action.del') }}
</el-button>
</template>
</Table>
</ContentWrap>
2022-07-18 19:06:37 +08:00
2022-11-15 12:25:19 +08:00
<XModal v-model="dialogVisible" :title="dialogTitle">
2022-07-28 12:18:38 +08:00
<!-- 对话框(添加 / 修改) -->
<Form
v-if="['create', 'update'].includes(actionType)"
:schema="allSchemas.formSchema"
:rules="rules"
ref="formRef"
>
<template #memberUserIds>
<el-select v-model="userIds" multiple>
<el-option
v-for="item in userOptions"
:key="item.id"
:label="item.nickname"
:value="item.id"
/>
</el-select>
</template>
</Form>
<!-- 对话框(详情) -->
<Descriptions
v-if="actionType === 'detail'"
:schema="allSchemas.detailSchema"
:data="detailRef"
>
<template #memberUserIds="{ row }">
<span v-for="userId in row.memberUserIds" :key="userId">
{{ getUserNickName(userId) + ' ' }}
</span>
</template>
</Descriptions>
<template #footer>
2022-11-15 17:42:04 +08:00
<!-- 按钮保存 -->
<XButton
2022-07-28 12:18:38 +08:00
v-if="['create', 'update'].includes(actionType)"
type="primary"
2022-11-15 17:42:04 +08:00
:title="t('action.save')"
2022-07-28 12:18:38 +08:00
:loading="actionLoading"
2022-11-15 17:42:04 +08:00
@click="submitForm()"
/>
<!-- 按钮关闭 -->
<XButton :loading="actionLoading" :title="t('dialog.close')" @click="dialogVisible = false" />
2022-07-28 12:18:38 +08:00
</template>
2022-11-15 12:25:19 +08:00
</XModal>
2022-07-28 12:18:38 +08:00
</template>