table.ts 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. import { ref, isRef } from 'vue';
  2. import { PageResult } from '@/api/types/common';
  3. export default function useTable<T extends Record<string, any>>(
  4. apiFunc: (data: any) => Promise<PageResult<T>>,
  5. searchModel: Record<string, any>,
  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. ...(isRef(searchModel || {}) ? searchModel.value : searchModel),
  15. pageNumber: pageNumber.value,
  16. pageSize: pageSize.value,
  17. };
  18. const data = await apiFunc(datas);
  19. dataList.value = data.result;
  20. total.value = data.totalCount;
  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: number) {
  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 && 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. dataList,
  53. pagination,
  54. getRowIndex,
  55. getList,
  56. toPage,
  57. deletePageLastItem,
  58. };
  59. }