index.tsx 4.97 KB
import { postErpOrderListByPage } from '@/services';
import {
  ActionType,
  FooterToolbar,
  PageContainer,
  ProDescriptionsItemProps,
  ProTable,
} from '@ant-design/pro-components';
import { Button, Divider } from 'antd';
import React, { useRef, useState } from 'react';
import OrderDrawer from './components/OrderDrawer';

// 子表格
const expandedRowRender = (props = {}) => {
  const { sub_orders = [] } = props;

  return (
    <ProTable
      rowKey="sub_order_id"
      columns={[
        {
          title: 'ProductCode',
          dataIndex: 'product_code',
          key: 'product_code',
        },
        {
          title: 'ProductName',
          dataIndex: 'product_name',
          key: 'product_name',
        },
        {
          title: 'ProductName',
          dataIndex: 'product_name',
          key: 'product_name',
        },
        {
          title: 'ProductName',
          dataIndex: 'product_name',
          key: 'product_name',
        },
        // {
        //   title: 'Action',
        //   dataIndex: 'operation',
        //   key: 'operation',
        //   valueType: 'option',
        //   render: () => [<a key="Pause">Pause</a>, <a key="Stop">Stop</a>],
        // },
      ]}
      headerTitle={false}
      search={false}
      options={false}
      dataSource={sub_orders}
      pagination={false}
    />
  );
};

const TableList: React.FC<unknown> = () => {
  const actionRef = useRef<ActionType>();
  const [row, setRow] = useState<API.UserInfo>();
  const [selectedRowsState, setSelectedRows] = useState<API.UserInfo[]>([]);
  const [orderDrawerVisible, setOrderDrawerVisible] = useState<boolean>(false);

  const columns: ProDescriptionsItemProps<API.UserInfo>[] = [
    {
      title: 'SaleCode',
      dataIndex: 'sales_code',
      // tip: '名称是唯一的 key',
      formItemProps: {
        rules: [
          {
            required: true,
            message: '名称为必填项',
          },
        ],
      },
    },
    {
      title: 'CustomerName',
      dataIndex: 'customer_name',
      valueType: 'text',
    },
    {
      title: 'CustomerName',
      dataIndex: 'customer_name',
      valueType: 'text',
    },
    {
      title: 'CustomerName',
      dataIndex: 'customer_name',
      valueType: 'text',
    },
    {
      title: 'CustomerName',
      dataIndex: 'customer_name',
      valueType: 'text',
    },
    {
      title: 'CustomerName',
      dataIndex: 'customer_name',
      valueType: 'text',
    },
    {
      title: 'CustomerName',
      dataIndex: 'customer_name',
      valueType: 'text',
    },
    {
      title: 'CustomerName',
      dataIndex: 'customer_name',
      valueType: 'text',
    },
    {
      title: '操作',
      dataIndex: 'option',
      valueType: 'option',
      render: (_, record) => (
        <>
          <a
            onClick={() => {
              setOrderDrawerVisible(true);
              console.log(
                '%c [ record ]-123',
                'font-size:13px; background:pink; color:#bf2c9f;',
                record,
              );
              setRow(record);
            }}
          >
            编辑
          </a>
          <Divider type="vertical" />
          <a href="">xxxx</a>
        </>
      ),
    },
  ];

  return (
    <PageContainer
      header={{
        title: '订单管理',
      }}
    >
      <ProTable<API.UserInfo>
        headerTitle="查询表格"
        actionRef={actionRef}
        rowKey="main_order_id"
        search={{
          labelWidth: 120,
        }}
        expandable={{ expandedRowRender }}
        toolBarRender={() => [
          <Button
            key="1"
            type="primary"
            onClick={() => setOrderDrawerVisible(true)}
          >
            新建
          </Button>,
        ]}
        request={async (params, sorter, filter) => {
          const { data } = await postErpOrderListByPage({
            ...params,
            // FIXME: remove @ts-ignore
            // @ts-ignore
            sorter,
            filter,
          });

          return {
            data: data?.records || [],
          };
        }}
        columns={columns}
        rowSelection={{
          onChange: (_, selectedRows) => setSelectedRows(selectedRows),
        }}
      />
      {selectedRowsState?.length > 0 && (
        <FooterToolbar
          extra={
            <div>
              已选择{' '}
              <a style={{ fontWeight: 600 }}>{selectedRowsState.length}</a>{' '}
              项&nbsp;&nbsp;
            </div>
          }
        >
          <Button
            onClick={async () => {
              await handleRemove(selectedRowsState);
              setSelectedRows([]);
              actionRef.current?.reloadAndRest?.();
            }}
          >
            批量删除
          </Button>
          <Button type="primary">批量审批</Button>
        </FooterToolbar>
      )}
      {orderDrawerVisible && (
        <OrderDrawer data={row} onClose={() => setOrderDrawerVisible(false)} />
      )}
    </PageContainer>
  );
};

export default TableList;