index.tsx 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. import {exportTraceBackSN, getTraceBackSNList} from '@apis';
  2. import {Table, TableTools} from '@components';
  3. import {
  4. useContextSection,
  5. useQueryTableList,
  6. useTableExportEvent,
  7. } from '@hooks';
  8. import {Card} from 'antd';
  9. import {FC} from 'react';
  10. import {PRELOAD_KEY, context, pageContext, searchContext} from '../context';
  11. import {ColumnsType} from 'antd/es/table';
  12. import {CODE_COL_WIDTH, NORMAL_TABLE_WIDTH} from '@utils';
  13. import {GetTraceBackSNListData} from '@models';
  14. const columns: ColumnsType<GetTraceBackSNListData> = [
  15. {title: 'SN编号', dataIndex: 'snCode', width: CODE_COL_WIDTH},
  16. {title: '交货单号', dataIndex: 'deliveryOrder', width: CODE_COL_WIDTH},
  17. {title: '销售订单编号', dataIndex: 'deliveryCode', width: CODE_COL_WIDTH},
  18. {
  19. title: '销售公司编号',
  20. dataIndex: 'deliveryCompany',
  21. width: NORMAL_TABLE_WIDTH,
  22. },
  23. ];
  24. const TableList: FC = function () {
  25. const params = useContextSection(context, state => state[0]);
  26. const [{data, count}] = useQueryTableList({
  27. queryFn: getTraceBackSNList,
  28. params,
  29. pageContext,
  30. searchContext,
  31. });
  32. const [isExporting, onExport] = useTableExportEvent({
  33. pageContext,
  34. context,
  35. fn: exportTraceBackSN,
  36. });
  37. return (
  38. <Card className='table-wrapper'>
  39. <TableTools
  40. title='发货详情'
  41. pageContext={pageContext}
  42. searchContext={searchContext}
  43. isExporting={isExporting}
  44. onExport={onExport}
  45. preloadKey={PRELOAD_KEY}
  46. />
  47. <Table
  48. columns={columns}
  49. data={data}
  50. count={count}
  51. pageContext={pageContext}
  52. searchContext={searchContext}
  53. data-testid='deliver_trace_sn_table'
  54. preloadKey={PRELOAD_KEY}
  55. />
  56. </Card>
  57. );
  58. };
  59. export default TableList;