refactor: user manage
This commit is contained in:
parent
6d9068c378
commit
59e4710a42
@ -60,9 +60,11 @@ interface FormItemModel {
|
|||||||
path: string
|
path: string
|
||||||
label?: string
|
label?: string
|
||||||
rules?: Arrayable<FormItemRule>,
|
rules?: Arrayable<FormItemRule>,
|
||||||
selectProps: {
|
hidden?: (e: any) => boolean,
|
||||||
|
selectProps?: {
|
||||||
options?: { label: string, value: string }[]
|
options?: { label: string, value: string }[]
|
||||||
placeholder?: string
|
placeholder?: string
|
||||||
|
multiple?: boolean
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -25,7 +25,6 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { onBeforeMount, ref } from 'vue'
|
import { onBeforeMount, ref } from 'vue'
|
||||||
import type { CreateMemberParamsItem, FormItemModel } from '@/api/type/role'
|
import type { CreateMemberParamsItem, FormItemModel } from '@/api/type/role'
|
||||||
import RoleApi from '@/api/system/role'
|
|
||||||
import UserApi from '@/api/user/user'
|
import UserApi from '@/api/user/user'
|
||||||
import WorkspaceApi from '@/api/workspace/workspace'
|
import WorkspaceApi from '@/api/workspace/workspace'
|
||||||
import MemberFormContent from './MemberFormContent.vue'
|
import MemberFormContent from './MemberFormContent.vue'
|
||||||
|
|||||||
@ -4,10 +4,10 @@
|
|||||||
<div v-for="(element, index) in form" :key="index" class="flex w-full">
|
<div v-for="(element, index) in form" :key="index" class="flex w-full">
|
||||||
<el-form-item v-for="model of props.models" :key="model.path" :prop="`[${index}].${model.path}`"
|
<el-form-item v-for="model of props.models" :key="model.path" :prop="`[${index}].${model.path}`"
|
||||||
:rules="model.rules" :label="index === 0 && model.label ? model.label : ''" class="mr-8" style="flex: 1">
|
:rules="model.rules" :label="index === 0 && model.label ? model.label : ''" class="mr-8" style="flex: 1">
|
||||||
<el-select v-model="element[model.path]"
|
<el-select v-show="!model?.hidden?.(element)" v-model="element[model.path]"
|
||||||
:placeholder="model.selectProps.placeholder ?? $t('common.selectPlaceholder')" clearable filterable multiple
|
:placeholder="model.selectProps?.placeholder ?? $t('common.selectPlaceholder')" clearable filterable
|
||||||
style="width: 100%" collapse-tags collapse-tags-tooltip>
|
multiple style="width: 100%" collapse-tags collapse-tags-tooltip v-bind="model.selectProps">
|
||||||
<el-option v-for="opt in model.selectProps.options" :key="opt.value" :label="opt.label"
|
<el-option v-for="opt in model.selectProps?.options" :key="opt.value" :label="opt.label"
|
||||||
:value="opt.value" />
|
:value="opt.value" />
|
||||||
</el-select>
|
</el-select>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
|
|||||||
@ -45,16 +45,16 @@
|
|||||||
</el-input>
|
</el-input>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item :label="$t('views.userManage.userForm.phone.label')">
|
<el-form-item :label="$t('views.userManage.userForm.phone.label')">
|
||||||
<el-input
|
<el-input v-model="userForm.phone" :placeholder="$t('views.userManage.userForm.phone.placeholder')">
|
||||||
v-model="userForm.phone"
|
|
||||||
:placeholder="$t('views.userManage.userForm.phone.placeholder')"
|
|
||||||
>
|
|
||||||
</el-input>
|
</el-input>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="默认密码" v-if="!isEdit">
|
<el-form-item label="默认密码" v-if="!isEdit">
|
||||||
<span>{{userForm.password}}</span>
|
<span>{{ userForm.password }}</span>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-form>
|
</el-form>
|
||||||
|
<h4 class="title-decoration-1 mb-16 mt-8">{{ $t('views.userManage.roleSetting') }}</h4>
|
||||||
|
<MemberFormContent ref="memberFormContentRef" :models="formItemModel" v-model:form="list"
|
||||||
|
v-loading="memberFormContentLoading" />
|
||||||
<template #footer>
|
<template #footer>
|
||||||
<el-button @click.prevent="visible = false"> {{ $t('common.cancel') }}</el-button>
|
<el-button @click.prevent="visible = false"> {{ $t('common.cancel') }}</el-button>
|
||||||
<el-button type="primary" @click="submit(userFormRef)" :loading="loading">
|
<el-button type="primary" @click="submit(userFormRef)" :loading="loading">
|
||||||
@ -64,11 +64,15 @@
|
|||||||
</el-drawer>
|
</el-drawer>
|
||||||
</template>
|
</template>
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import {ref, reactive, watch} from 'vue'
|
import { ref, reactive, watch, onBeforeMount } from 'vue'
|
||||||
import type {FormInstance} from 'element-plus'
|
import type { FormInstance } from 'element-plus'
|
||||||
import userManageApi from '@/api/user/user-manage'
|
import userManageApi from '@/api/user/user-manage'
|
||||||
import {MsgSuccess} from '@/utils/message'
|
import { MsgSuccess } from '@/utils/message'
|
||||||
import {t} from '@/locales'
|
import { t } from '@/locales'
|
||||||
|
import type { FormItemModel } from '@/api/type/role'
|
||||||
|
import WorkspaceApi from '@/api/workspace/workspace'
|
||||||
|
import MemberFormContent from '@/views/role/component/MemberFormContent.vue'
|
||||||
|
import { RoleTypeEnum } from '@/enums/system'
|
||||||
|
|
||||||
const props = defineProps({
|
const props = defineProps({
|
||||||
title: String,
|
title: String,
|
||||||
@ -85,6 +89,69 @@ const userForm = ref<any>({
|
|||||||
nick_name: '',
|
nick_name: '',
|
||||||
})
|
})
|
||||||
|
|
||||||
|
const list = ref<any[]>([]);
|
||||||
|
const memberFormContentLoading = ref(false);
|
||||||
|
const formItemModel = ref<FormItemModel[]>([]);
|
||||||
|
const roleFormItem = ref<FormItemModel[]>([]);
|
||||||
|
const adminRoleList = ref<any[]>([])
|
||||||
|
const workspaceFormItem = ref<FormItemModel[]>([])
|
||||||
|
|
||||||
|
async function getRoleFormItem() {
|
||||||
|
try {
|
||||||
|
const res = await WorkspaceApi.getWorkspaceRoleList(memberFormContentLoading);
|
||||||
|
roleFormItem.value = [{
|
||||||
|
path: 'role_id',
|
||||||
|
label: t('views.role.member.role'),
|
||||||
|
rules: [
|
||||||
|
{
|
||||||
|
required: true,
|
||||||
|
message: `${t('common.selectPlaceholder')}${t('views.role.member.role')}`,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
selectProps: {
|
||||||
|
options: res.data?.map(item => ({
|
||||||
|
label: item.name,
|
||||||
|
value: item.id
|
||||||
|
})) || [],
|
||||||
|
placeholder: `${t('common.selectPlaceholder')}${t('views.role.member.role')}`,
|
||||||
|
multiple: false
|
||||||
|
}
|
||||||
|
}]
|
||||||
|
adminRoleList.value = res.data.filter(item => item.type === RoleTypeEnum.ADMIN)
|
||||||
|
} catch (e) {
|
||||||
|
console.error(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
async function getWorkspaceFormItem() {
|
||||||
|
try {
|
||||||
|
const res = await WorkspaceApi.getWorkspaceList(memberFormContentLoading)
|
||||||
|
workspaceFormItem.value = [
|
||||||
|
{
|
||||||
|
path: 'workspace_ids',
|
||||||
|
label: t('views.role.member.workspace'),
|
||||||
|
hidden: (e) => adminRoleList.value.find(item => item.id === e.role_id),
|
||||||
|
selectProps: {
|
||||||
|
options:
|
||||||
|
res.data?.map((item) => ({
|
||||||
|
label: item.name,
|
||||||
|
value: item.id,
|
||||||
|
})) || [],
|
||||||
|
placeholder: `${t('common.selectPlaceholder')}${t('views.role.member.workspace')}`,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
]
|
||||||
|
} catch (e) {
|
||||||
|
console.error(e)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
onBeforeMount(async () => {
|
||||||
|
await getRoleFormItem();
|
||||||
|
await getWorkspaceFormItem();
|
||||||
|
formItemModel.value = [...roleFormItem.value, ...workspaceFormItem.value]
|
||||||
|
list.value = [{ role_id: '', workspace_ids: [] }]
|
||||||
|
})
|
||||||
|
|
||||||
const rules = reactive({
|
const rules = reactive({
|
||||||
username: [
|
username: [
|
||||||
{
|
{
|
||||||
@ -157,18 +224,25 @@ const open = (data: any) => {
|
|||||||
visible.value = true
|
visible.value = true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const memberFormContentRef = ref<InstanceType<typeof MemberFormContent>>()
|
||||||
const submit = async (formEl: FormInstance | undefined) => {
|
const submit = async (formEl: FormInstance | undefined) => {
|
||||||
if (!formEl) return
|
if (!formEl) return
|
||||||
await formEl.validate((valid, fields) => {
|
await formEl.validate((valid, fields) => {
|
||||||
if (valid) {
|
if (valid) {
|
||||||
|
memberFormContentRef.value?.validate().then(async (valid: any) => {
|
||||||
|
if (valid) {
|
||||||
|
const params = {
|
||||||
|
...userForm.value,
|
||||||
|
role_setting: list.value
|
||||||
|
}
|
||||||
if (isEdit.value) {
|
if (isEdit.value) {
|
||||||
userManageApi.putUserManage(userForm.value.id, userForm.value, loading).then((res) => {
|
userManageApi.putUserManage(userForm.value.id, params, loading).then((res) => {
|
||||||
emit('refresh')
|
emit('refresh')
|
||||||
MsgSuccess(t('common.editSuccess'))
|
MsgSuccess(t('common.editSuccess'))
|
||||||
visible.value = false
|
visible.value = false
|
||||||
})
|
})
|
||||||
} else {
|
} else {
|
||||||
userManageApi.postUserManage(userForm.value, loading).then((res) => {
|
userManageApi.postUserManage(params, loading).then((res) => {
|
||||||
emit('refresh')
|
emit('refresh')
|
||||||
MsgSuccess(t('common.createSuccess'))
|
MsgSuccess(t('common.createSuccess'))
|
||||||
visible.value = false
|
visible.value = false
|
||||||
@ -176,8 +250,10 @@ const submit = async (formEl: FormInstance | undefined) => {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
}
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
defineExpose({open})
|
defineExpose({ open })
|
||||||
</script>
|
</script>
|
||||||
<style lang="scss" scoped></style>
|
<style lang="scss" scoped></style>
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user