table.ts 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. import { ref } from 'vue';
  2. import { PageResult } from '@/api/types/common';
  3. export default function useTable<T>(
  4. apiFunc: Promise<PageResult<T>>,
  5. searchModel: object,
  6. initAutoFetch = false
  7. ) {
  8. const pageNumber = ref(1);
  9. const pageSize = ref(10);
  10. const total = ref(0);
  11. const dataList = ref<T>([]);
  12. async function getList() {
  13. const datas = {
  14. ...searchModel,
  15. pageNumber: pageNumber.value,
  16. pageSize: pageSize.value,
  17. };
  18. const data = await apiFunc(datas);
  19. dataList.value = data.records;
  20. total.value = data.total;
  21. }
  22. if (initAutoFetch) getList();
  23. async function toPage(page: number) {
  24. pageNumber.value = page;
  25. await getList();
  26. }
  27. async function pageSizeChange(size: number) {
  28. pageSize.value = size;
  29. await toPage(1);
  30. }
  31. function getRowIndex(index) {
  32. return pageSize.value * (pageNumber.value - 1) + index + 1;
  33. }
  34. function deletePageLastItem(len = 1) {
  35. let page = pageNumber.value || 1;
  36. if (dataList.value.length === len) {
  37. page = page > 1 ? page - 1 : 1;
  38. }
  39. toPage(page);
  40. }
  41. const pagination = ref({
  42. total,
  43. current: pageNumber,
  44. pageSize,
  45. showTotal: true,
  46. showJumper: true,
  47. showPageSize: true,
  48. onChange: toPage,
  49. onPageSizeChange: pageSizeChange,
  50. });
  51. return {
  52. total,
  53. dataList,
  54. pagination,
  55. getRowIndex,
  56. getList,
  57. toPage,
  58. deletePageLastItem,
  59. };
  60. }