import { PlusOutlined } from '@ant-design/icons'; import type { ActionType, ProColumns } from '@ant-design/pro-components'; import { useParams } from '@umijs/max'; import { Popconfirm } from 'antd'; import React, { useCallback, useRef, useState } from 'react'; import ConfigurableDrawerForm, { type ConfigurableDrawerFormRef, } from '@/components/DrawerForm'; import EnhancedProTable from '@/components/EnhancedProTable'; import type { ToolbarAction } from '@/components/EnhancedProTable/types'; import { formStatusType } from '@/constants'; import { createDictData, type DictDataVO, deleteDictData, getDictDataPage, updateDictData, } from '@/services/system/dict/dict.data'; import { baseDictDataColumns, formColumns } from './config'; const SyStemDictData = () => { const configurableDrawerRef = useRef(null); const tableRef = useRef(null); const [type, setType] = useState<'create' | 'update'>('create'); const [id, setId] = useState(0); const routerParams = useParams(); console.log(routerParams); const handleEdit = (record: DictDataVO) => { setType('update'); setId(record.id); configurableDrawerRef.current?.open(record); }; const onFetch = async (params: { pageSize?: number; current?: number }) => { const data = await getDictDataPage({ ...params, dictType: routerParams.type, pageNo: params.current, pageSize: params.pageSize, }); return { data: data.list, success: true, total: data.total, }; }; const handleAdd = () => { setType('create'); configurableDrawerRef.current?.open({ dictType: routerParams.type, }); }; const handleSubmit = useCallback( async (values: DictDataVO) => { if (type === 'create') { await createDictData(values); } else { await updateDictData({ ...values, id, }); } tableRef.current?.reload(); return true; }, [type, id], ); const toolbarActions: ToolbarAction[] = [ { key: 'add', label: '新建', type: 'primary', icon: , onClick: handleAdd, }, ]; const actionColumns: ProColumns = { title: '操作', dataIndex: 'option', valueType: 'option', fixed: 'right', width: 120, render: ( _text: React.ReactNode, record: DictDataVO, _: any, action: any, ) => [ handleEdit(record)}> 编辑 , { await deleteDictData(record.id); action?.reload(); }} okText="是" cancelText="否" > 删除 , ], }; const columns = [...baseDictDataColumns, actionColumns]; return ( <> ref={tableRef} columns={columns} request={onFetch} toolbarActions={toolbarActions} headerTitle="租户列表" showIndex={false} showSelection={false} /> ); }; export default SyStemDictData;