fix: 修复部门多级下拉菜单回显错误问题

This commit is contained in:
郝先瑞 2022-08-26 07:33:12 +08:00
parent c3e9754547
commit 66e0a0c5a7
2 changed files with 151 additions and 56 deletions

View File

@ -1,67 +1,160 @@
import { PageQueryParam, PageResult } from '../base';
import request from '@/utils/request';
import { AxiosPromise } from 'axios';
import {
UserFormData,
UserInfo,
UserPageResult,
UserQueryParam
} from '@/types/api/system/user';
/**
*
*
*/
export interface UserInfo {
nickname: string;
avatar: string;
roles: string[];
perms: string[];
export function getUserInfo(): AxiosPromise<UserInfo> {
return request({
url: '/youlai-admin/api/v1/users/me',
method: 'get'
});
}
/**
*
*
*
* @param queryParams
*/
export interface UserQueryParam extends PageQueryParam {
keywords: string;
status: number;
deptId: number;
export function listUserPages(
queryParams: UserQueryParam
): AxiosPromise<UserPageResult> {
return request({
url: '/youlai-admin/api/v1/users/pages',
method: 'get',
params: queryParams
});
}
/**
*
*
*
* @param userId
*/
export interface UserItem {
id: string;
username: string;
nickname: string;
mobile: string;
gender: number;
avatar: string;
email: string;
status: number;
deptName: string;
roleNames: string;
createTime: string;
export function getUserFormData(userId: number): AxiosPromise<UserFormData> {
return request({
url: '/youlai-admin/api/v1/users/' + userId + '/form_data',
method: 'get'
});
}
/**
*
*
*
* @param data
*/
export type UserPageResult = PageResult<UserItem[]>;
/**
*
*/
export interface UserFormData {
id: number | undefined;
deptId: number;
username: string;
nickname: string;
password: string;
mobile: string;
email: string;
gender: number;
status: number;
remark: string;
roleIds: number[];
export function addUser(data: any) {
return request({
url: '/youlai-admin/api/v1/users',
method: 'post',
data: data
});
}
/**
*
*
*
* @param id
* @param data
*/
export interface UserImportFormData {
deptId: number;
roleIds: number[];
export function updateUser(id: number, data: UserFormData) {
return request({
url: '/youlai-admin/api/v1/users/' + id,
method: 'put',
data: data
});
}
/**
*
*
* @param id
* @param status
*/
export function updateUserStatus(id: number, status: number) {
return request({
url: '/youlai-admin/api/v1/users/' + id + '/status',
method: 'patch',
params: { status: status }
});
}
/**
*
*
* @param id
* @param password
*/
export function updateUserPassword(id: number, password: string) {
return request({
url: '/youlai-admin/api/v1/users/' + id + '/password',
method: 'patch',
params: { password: password }
});
}
/**
*
*
* @param ids
*/
export function deleteUsers(ids: string) {
return request({
url: '/youlai-admin/api/v1/users/' + ids,
method: 'delete'
});
}
/**
*
*
* @returns
*/
export function downloadTemplate() {
return request({
url: '/youlai-admin/api/v1/users/template',
method: 'get',
responseType: 'arraybuffer'
});
}
/**
*
*
* @param queryParams
* @returns
*/
export function exportUser(queryParams: UserQueryParam) {
return request({
url: '/youlai-admin/api/v1/users/_export',
method: 'get',
params: queryParams,
responseType: 'arraybuffer'
});
}
/**
*
*
* @param file
*/
export function importUser(deptId: number, roleIds: string, file: File) {
const formData = new FormData();
formData.append('file', file);
formData.append('deptId', deptId.toString());
formData.append('roleIds', roleIds);
return request({
url: '/youlai-admin/api/v1/users/_import',
method: 'post',
data: formData,
headers: {
'Content-Type': 'multipart/form-data'
}
});
}

View File

@ -18,7 +18,7 @@ import {
// API
import {
listUserPages,
getUserFormData,
getUserDetail,
deleteUsers,
addUser,
updateUser,
@ -272,27 +272,28 @@ function resetPassword(row: { [key: string]: any }) {
* 添加用户
**/
async function handleAdd() {
await loadDeptOptions();
await loadRoleOptions();
state.dialog = {
title: '添加用户',
visible: true
};
await loadDeptOptions();
await loadRoleOptions();
}
/**
* 修改用户
**/
async function handleUpdate(row: { [key: string]: any }) {
const userId = row.id || state.ids;
await loadDeptOptions();
await loadRoleOptions();
state.dialog = {
title: '修改用户',
visible: true
};
getUserFormData(userId).then(({ data }) => {
state.formData = data;
const userId = row.id || state.ids;
await loadDeptOptions();
await loadRoleOptions();
getUserDetail(userId).then(({ data }) => {
formData.value = data;
});
}
@ -398,7 +399,7 @@ function handleDownloadTemplate() {
async function showImportDialog() {
await loadDeptOptions();
await loadRoleOptions();
state.importDialog.visible = true;
importDialog.value.visible = true;
}
/**
@ -714,6 +715,7 @@ onMounted(() => {
:data="deptOptions"
filterable
check-strictly
:render-after-expand="false"
/>
</el-form-item>