fix: 选人的一些问题

This commit is contained in:
dap 2024-12-19 14:31:46 +08:00
parent 5577f8d339
commit e7eb0577ec

View File

@ -25,7 +25,7 @@ const emit = defineEmits<{
const [BasicModal, modalApi] = useVbenModal({
title: '选择人员',
class: 'w-[1000px]',
class: 'w-[1050px]',
fullscreenButton: false,
onConfirm: handleSubmit,
async onOpened() {
@ -67,7 +67,6 @@ const formOptions: VbenFormProps = {
await formApi.resetForm();
const formValues = formApi.form.values;
formApi.setLatestSubmissionValues(formValues);
await rightTableApi.grid.loadData([]);
await reload(formValues);
},
};
@ -103,7 +102,9 @@ const gridOptions: VxeGridProps = {
],
height: 'auto',
keepSource: true,
pagerConfig: {},
pagerConfig: {
layouts: ['PrevPage', 'Number', 'NextPage', 'Sizes', 'Total'],
},
proxyConfig: {
ajax: {
query: async ({ page }, formValues = {}) => {
@ -114,6 +115,18 @@ const gridOptions: VxeGridProps = {
Reflect.deleteProperty(formValues, 'deptId');
}
//
if (props.mode === 'multiple') {
const records = rightTableApi.grid.getData();
await tableApi.grid.setCheckboxRow(records, true);
}
if (props.mode === 'single') {
const records = rightTableApi.grid.getData();
if (records.length === 1) {
await tableApi.grid.setRadioRow(records[0]);
}
}
return await userList({
pageNum: page.currentPage,
pageSize: page.pageSize,
@ -151,9 +164,15 @@ function checkBoxEvent() {
if (props.mode !== 'multiple') {
return;
}
//
/**
* 给右边表格赋值
* records拿到的是当前页的选中数据
* reserveRecords拿到的是其他页选中的数据
*/
const records = tableApi.grid.getCheckboxRecords();
rightTableApi.grid.loadData(records);
const reserveRecords = tableApi.grid.getCheckboxReserveRecords();
const realRecords = [...records, ...reserveRecords];
rightTableApi.grid.loadData(realRecords);
}
function radioEvent() {
@ -222,6 +241,7 @@ async function handleRemoveItem(row: any) {
function handleRemoveAll() {
if (props.mode === 'multiple') {
tableApi.grid.clearCheckboxRow();
tableApi.grid.clearCheckboxReserve();
}
if (props.mode === 'single') {
tableApi.grid.clearRadioRow();
@ -259,10 +279,10 @@ function handleSubmit() {
@reload="() => tableApi.reload()"
@select="handleDeptQuery"
/>
<div class="h-[600px] w-[420px]">
<div class="h-[600px] w-[450px]">
<BasicTable />
</div>
<div class="flex h-[600px] w-[360px] flex-col">
<div class="flex h-[600px] flex-col">
<div class="flex w-full px-4">
<div class="flex w-full items-center justify-between">
<div>已选中人员</div>