pangu-user-platform/frontend/ruoyi-ui/src/views/business/student/components/MemberSelectDialog.vue

157 lines
3.9 KiB
Vue

<template>
<el-dialog
v-model="visible"
title="选择归属用户"
width="700px"
:close-on-click-modal="false"
append-to-body
>
<!-- 搜索区域 -->
<el-form :inline="true" style="margin-bottom: 16px">
<el-form-item label="手机号">
<el-input v-model="queryParams.phone" placeholder="请输入手机号" clearable style="width: 150px" @keyup.enter="handleQuery" />
</el-form-item>
<el-form-item label="昵称">
<el-input v-model="queryParams.nickname" placeholder="请输入昵称" clearable style="width: 150px" @keyup.enter="handleQuery" />
</el-form-item>
<el-form-item>
<el-button type="primary" @click="handleQuery">搜索</el-button>
<el-button @click="resetQuery">重置</el-button>
</el-form-item>
</el-form>
<!-- 列表 -->
<el-table
v-loading="loading"
:data="tableData"
border
stripe
highlight-current-row
@current-change="handleCurrentChange"
style="width: 100%"
max-height="400"
>
<el-table-column prop="phone" label="手机号" width="130" />
<el-table-column prop="nickname" label="昵称" width="120" />
<el-table-column prop="identityType" label="身份" width="80" align="center">
<template #default="{ row }">
<el-tag :type="row.identityType === '1' ? 'success' : 'primary'" size="small">
{{ row.identityType === '1' ? '家长' : '教师' }}
</el-tag>
</template>
</el-table-column>
<el-table-column prop="gender" label="性别" width="60" align="center">
<template #default="{ row }">
{{ row.gender === '1' ? '男' : row.gender === '2' ? '女' : '未知' }}
</template>
</el-table-column>
<el-table-column prop="createTime" label="注册时间" width="160" />
</el-table>
<!-- 分页 -->
<el-pagination
v-model:current-page="queryParams.pageNum"
v-model:page-size="queryParams.pageSize"
:page-sizes="[10, 20, 50]"
:total="total"
layout="total, sizes, prev, pager, next"
style="margin-top: 16px; justify-content: flex-end"
@size-change="getList"
@current-change="getList"
/>
<template #footer>
<el-button @click="visible = false">取消</el-button>
<el-button type="primary" @click="handleConfirm" :disabled="!selectedRow">确定</el-button>
</template>
</el-dialog>
</template>
<script setup>
/**
* 会员选择弹窗
* @author pangu
*/
import { ElMessage } from 'element-plus'
import { ref } from 'vue'
import request from '@/utils/request'
const emit = defineEmits(['select'])
const visible = ref(false)
const loading = ref(false)
const tableData = ref([])
const total = ref(0)
const selectedRow = ref(null)
const queryParams = ref({
pageNum: 1,
pageSize: 10,
phone: '',
nickname: ''
})
// 获取会员列表
const getList = async () => {
loading.value = true
try {
const res = await request.get('/business/member/list', { params: queryParams.value })
if (res.code === 200) {
tableData.value = res.rows || []
total.value = res.total || 0
}
} catch (e) {
console.error('获取会员列表失败:', e)
} finally {
loading.value = false
}
}
// 搜索
const handleQuery = () => {
queryParams.value.pageNum = 1
getList()
}
// 重置
const resetQuery = () => {
queryParams.value = {
pageNum: 1,
pageSize: 10,
phone: '',
nickname: ''
}
getList()
}
// 选中行变化
const handleCurrentChange = (row) => {
selectedRow.value = row
}
// 确认选择
const handleConfirm = () => {
if (!selectedRow.value) {
ElMessage.warning('请选择一个会员')
return
}
emit('select', selectedRow.value)
visible.value = false
}
// 打开弹窗
const open = () => {
visible.value = true
selectedRow.value = null
queryParams.value = {
pageNum: 1,
pageSize: 10,
phone: '',
nickname: ''
}
getList()
}
defineExpose({ open })
</script>