Files
iot-device-management-frontend/apps/web-antd/src/views/erp/finance/payment/modules/purchase-in-select.vue
2025-10-22 15:32:50 +08:00

109 lines
2.6 KiB
Vue

<script lang="ts" setup>
import type { VxeTableGridOptions } from '#/adapter/vxe-table';
import type { ErpPurchaseInApi } from '#/api/erp/purchase/in';
import { ref } from 'vue';
import { message, Modal } from 'ant-design-vue';
import { useVbenVxeGrid } from '#/adapter/vxe-table';
import { getPurchaseInPage } from '#/api/erp/purchase/in';
import { usePurchaseInGridColumns, usePurchaseInGridFormSchema } from '../data';
const emit = defineEmits<{
success: [rows: ErpPurchaseInApi.PurchaseIn[]];
}>();
const supplierId = ref<number>(); // 供应商ID
const open = ref<boolean>(false); // 弹窗是否打开
const selectedRows = ref<ErpPurchaseInApi.PurchaseIn[]>([]); // 选中的行
/** 表格配置 */
const [Grid, gridApi] = useVbenVxeGrid({
formOptions: {
schema: usePurchaseInGridFormSchema(),
},
gridOptions: {
columns: usePurchaseInGridColumns(),
height: 'auto',
keepSource: true,
proxyConfig: {
ajax: {
query: async ({ page }, formValues) => {
return await getPurchaseInPage({
pageNo: page.currentPage,
pageSize: page.pageSize,
supplierId: supplierId.value,
paymentEnable: true, // 只查询可付款的
...formValues,
});
},
},
},
rowConfig: {
keyField: 'id',
isHover: true,
},
checkboxConfig: {
highlight: true,
range: true,
},
toolbarConfig: {
refresh: true,
search: true,
},
} as VxeTableGridOptions<ErpPurchaseInApi.PurchaseIn>,
gridEvents: {
checkboxChange: ({
records,
}: {
records: ErpPurchaseInApi.PurchaseIn[];
}) => {
selectedRows.value = records;
},
checkboxAll: ({ records }: { records: ErpPurchaseInApi.PurchaseIn[] }) => {
selectedRows.value = records;
},
},
});
/** 打开弹窗 */
function openModal(id: number) {
// 重置数据
supplierId.value = id;
open.value = true;
selectedRows.value = [];
// 查询列表
gridApi.formApi?.resetForm();
gridApi.formApi?.setValues({ supplierId: id });
gridApi.query();
}
/** 确认选择采购入库单 */
function handleOk() {
if (selectedRows.value.length === 0) {
message.warning('请选择要添加的采购入库单');
return;
}
emit('success', selectedRows.value);
open.value = false;
}
defineExpose({ open: openModal });
</script>
<template>
<Modal
class="!w-[50vw]"
v-model:open="open"
title="选择采购入库单"
@ok="handleOk"
>
<Grid
class="max-h-[600px]"
table-title="采购入库单列表(仅展示可付款的单据)"
/>
</Modal>
</template>