You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

0 lines
22 KiB

1 month ago
  1. {"ast":null,"code":"import { ref, onMounted, reactive } from 'vue';\nimport { useRouter } from 'vue-router';\nimport { ElMessage, ElMessageBox } from 'element-plus';\nimport { Search } from '@element-plus/icons-vue';\nimport { getAllUsers, updateUserRole } from '@/api/auth';\nexport default {\n __name: 'UserManagement',\n setup(__props, {\n expose: __expose\n }) {\n __expose();\n const router = useRouter();\n const loading = ref(false);\n const userList = ref([]);\n const currentPage = ref(1);\n const pageSize = ref(10);\n const total = ref(0);\n\n // \n const searchForm = reactive({\n username: '',\n sortBy: 'id',\n order: 'desc'\n });\n const loadUsers = async () => {\n loading.value = true;\n try {\n const res = await getAllUsers({\n username: searchForm.username,\n pageNum: currentPage.value,\n pageSize: pageSize.value,\n sortBy: searchForm.sortBy,\n order: searchForm.order\n });\n if (res.code === 200 && res.data) {\n userList.value = res.data.records.map(user => ({\n ...user,\n realName: user.realName || ''\n }));\n total.value = res.data.total;\n pageSize.value = res.data.size;\n currentPage.value = res.data.current;\n }\n } catch (error) {\n console.error(':', error);\n if (error.response?.status === 401) {\n ElMessage.error('');\n router.push('/login');\n } else if (error.response?.status === 403) {\n ElMessage.error('访');\n } else {\n ElMessage.error(error.message || '');\n }\n } finally {\n loading.value = false;\n }\n };\n const handleSizeChange = val => {\n pageSize.value = val;\n currentPage.value = 1; // \n loadUsers();\n };\n const handleCurrentChange = val => {\n currentPage.value = val;\n loadUsers();\n };\n\n // \n const handleSearch = () => {\n currentPage.value = 1; // \n loadUsers();\n };\n\n // \n const getRoleTypeByName = roleName => {\n switch (roleName) {\n case '':\n return 'danger';\n // \n case '':\n return 'warning';\n // \n case '':\n return 'success';\n // 绿\n case '':\n return 'info';\n // \n default:\n return '';\n }\n };\n\n // \n const getRoleCodeByName = roleName => {\n switch (roleName) {\n case '':\n return 'ROLE_ADMIN';\n case '':\n return 'ROLE_WAREHOUSE_ADMIN';\n case '':\n return 'ROLE_LOGISTICS_ADMIN';\n case '':\n return 'ROLE_USER';\n default:\n return 'ROLE_USER';\n // \n }\n };\n\n // \n const getRoleNameByCode = roleCode => {\n switch (roleCode) {\n case 'ROLE_ADMIN':\n return '';\n case 'ROLE_WAREHOUSE_ADMIN':\n return '';\n case 'ROLE_LOGISTICS_ADMIN':\n return '';\n case 'ROLE_USER':\n return '';\n default:\n return '';\n }\n };\n\n // \n const dialogVisible = ref(false);\n const currentUser = ref(null);\n const roleForm = reactive({\n roleCode: '' // 使 roleCode\n });\n const handleUpdateRole = user => {\n currentUser.value = user;\n roleForm.roleCode = getRoleCodeByName(user.realName);\n dialogVisible.value =