index.tsx 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. import ProTable from '@jetlinks/pro-table';
  2. import type { ProTableProps } from '@jetlinks/pro-table';
  3. import type { ParamsType } from '@ant-design/pro-provider';
  4. import React, { useState } from 'react';
  5. import { isFunction } from 'lodash';
  6. import { Space, Pagination } from 'antd';
  7. import { AppstoreOutlined, BarsOutlined } from '@ant-design/icons';
  8. import classNames from 'classnames';
  9. import './index.less';
  10. enum ModelEnum {
  11. TABLE = 'TABLE',
  12. CARD = 'CARD',
  13. }
  14. type ModelType = keyof typeof ModelEnum;
  15. interface ProTableCardProps<T> {
  16. cardRender?: (data: T) => JSX.Element | React.ReactNode;
  17. }
  18. const ProTableCard = <
  19. T extends Record<string, any>,
  20. U extends ParamsType = ParamsType,
  21. ValueType = 'text',
  22. >(
  23. props: ProTableCardProps<T> & ProTableProps<T, U, ValueType>,
  24. ) => {
  25. const { cardRender, toolBarRender, request, ...extraProps } = props;
  26. const [model, setModel] = useState<ModelType>(ModelEnum.CARD);
  27. const [total, setTotal] = useState<number | undefined>(0);
  28. const [current, setCurrent] = useState(1); // 当前页
  29. const [pageIndex, setPageIndex] = useState(0);
  30. const [pageSize, setPageSize] = useState(10); // 每页条数
  31. /**
  32. * 处理 Card
  33. * @param dataSource
  34. */
  35. const handleCard = (dataSource: readonly T[] | undefined): JSX.Element => {
  36. return (
  37. <div className={'pro-table-card-items'}>
  38. {dataSource
  39. ? dataSource.map((item) =>
  40. cardRender && isFunction(cardRender) ? cardRender(item) : null,
  41. )
  42. : null}
  43. </div>
  44. );
  45. };
  46. return (
  47. <div className={'pro-table-card'}>
  48. <ProTable<T, U, ValueType>
  49. {...extraProps}
  50. params={
  51. {
  52. ...props.params,
  53. current: current,
  54. pageIndex: pageIndex,
  55. pageSize,
  56. } as any
  57. }
  58. request={async (param, sort, filter) => {
  59. if (request) {
  60. const resp = await request(param, sort, filter);
  61. setTotal(resp.result ? resp.result.total : 0);
  62. return {
  63. code: resp.message,
  64. result: {
  65. data: resp.result ? resp.result.data : [],
  66. pageIndex: resp.result ? resp.result.pageIndex : 0,
  67. pageSize: resp.result ? resp.result.pageSize : 0,
  68. total: resp.result ? resp.result.total : 0,
  69. },
  70. status: resp.status,
  71. };
  72. }
  73. return {};
  74. }}
  75. pagination={{
  76. onChange: (page, size) => {
  77. setCurrent(page);
  78. setPageIndex(page - 1);
  79. setPageSize(size);
  80. },
  81. pageSize: pageSize,
  82. current: current,
  83. }}
  84. toolBarRender={(action, row) => {
  85. const oldBar = toolBarRender ? toolBarRender(action, row) : [];
  86. return [
  87. ...oldBar,
  88. <Space
  89. align="center"
  90. key={ModelEnum.TABLE}
  91. size={12}
  92. className={classNames(`pro-table-card-setting-item`, {
  93. active: model === ModelEnum.TABLE,
  94. })}
  95. onClick={() => {
  96. setModel(ModelEnum.TABLE);
  97. }}
  98. >
  99. <BarsOutlined />
  100. </Space>,
  101. <Space
  102. align="center"
  103. size={12}
  104. key={ModelEnum.CARD}
  105. className={classNames(`pro-table-card-setting-item`, {
  106. active: model === ModelEnum.CARD,
  107. })}
  108. onClick={() => {
  109. setModel(ModelEnum.CARD);
  110. }}
  111. >
  112. <AppstoreOutlined />
  113. </Space>,
  114. ];
  115. }}
  116. tableViewRender={
  117. model === ModelEnum.CARD
  118. ? (tableProps) => {
  119. return handleCard(tableProps.dataSource);
  120. }
  121. : undefined
  122. }
  123. />
  124. {model === ModelEnum.CARD && (
  125. <Pagination
  126. showSizeChanger
  127. size="small"
  128. className={'pro-table-card-pagination'}
  129. total={total}
  130. current={current}
  131. onChange={(page, size) => {
  132. setCurrent(page);
  133. setPageIndex(page - 1);
  134. setPageSize(size);
  135. }}
  136. pageSize={pageSize}
  137. showTotal={(num) => {
  138. const minSize = pageIndex * pageSize + 1;
  139. const MaxSize = (pageIndex + 1) * pageSize;
  140. return `第 ${minSize} - ${MaxSize > num ? num : MaxSize} 条/总共 ${num} 条`;
  141. }}
  142. />
  143. )}
  144. </div>
  145. );
  146. };
  147. export default ProTableCard;