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
32 KiB

3 months ago
  1. {"ast":null,"code":"import { ref, computed, onMounted, reactive } from 'vue';\nimport { useRouter } from 'vue-router';\nimport { useStore } from 'vuex';\nimport { ElMessage, ElMessageBox } from 'element-plus';\nimport { Search } from '@element-plus/icons-vue';\nimport { getAllUsers, updateUserRole, deleteUser, getUserList } from '@/api/auth';\nexport default {\n __name: 'UserManagement',\n setup(__props, {\n expose: __expose\n }) {\n __expose();\n const router = useRouter();\n const store = useStore();\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 realName: '',\n roleCode: ''\n });\n\n // \n const roleOptions = [{\n label: '',\n value: 'ROLE_ADMIN'\n }, {\n label: '',\n value: 'ROLE_LOGISTICS_ADMIN'\n }, {\n label: '',\n value: 'ROLE_WAREHOUSE_ADMIN'\n }, {\n label: '',\n value: 'ROLE_USER'\n }];\n\n // \n const getRoleTagType = roleCode => {\n const typeMap = {\n 'ROLE_ADMIN': 'danger',\n 'ROLE_LOGISTICS_ADMIN': 'warning',\n 'ROLE_WAREHOUSE_ADMIN': 'success',\n 'ROLE_USER': 'info'\n };\n return typeMap[roleCode] || 'info';\n };\n\n // \n const getRoleLabel = roleCode => {\n const labelMap = {\n 'ROLE_ADMIN': '',\n 'ROLE_LOGISTICS_ADMIN': '',\n 'ROLE_WAREHOUSE_ADMIN': '',\n 'ROLE_USER': ''\n };\n return labelMap[roleCode] || roleCode;\n };\n const loadUsers = async () => {\n loading.value = true;\n try {\n const params = {\n pageNum: currentPage.value,\n pageSize: pageSize.value,\n username: searchForm.username || undefined,\n realName: searchForm.realName || undefined,\n roleCode: searchForm.roleCode || undefined\n };\n\n // 1. \n console.log(':', {\n currentPage: currentPage.value,\n pageSize: pageSize.value,\n total: total.value\n });\n\n // 2. \n console.log(':', params);\n const res = await getUserList(params);\n\n // 3. \n console.log(':', res);\n if (res.code === 200 && res.data) {\n // 4. \n console.log(':', {\n records: res.data.records,\n recordsLength: res.data.records.length,\n total: res.data.total,\n current: res.data.current,\n size: res.data.size,\n pages: res.data.pages\n });\n userList.value = res.data.records;\n total.value = res.data.total;\n currentPage.value = res.data.current;\n pageSize.value = res.data.size;\n\n // 5. \n console.log(':', {\n listLength: userList.value.length,\n total: total.value,\n currentPage: currentPage.value,\n pageSize: pageSize.value\n });\n }\n } catch (error) {\n console.error(':', error);\n ElMessage.error(error.message || '');\n } finally {\n loading.value = false;\n }\n };\n\n // \n const handleSizeChange = val => {\n pageSize.value = val;\n currentPage.value = 1; // \n loadUsers();\n };\n\n // \n const handleCurrentChange = val => {\n currentPage.value = val;\n loadUsers();\n };\n\n // \n const handleSearch = () => {\n