hook.tsx 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. import dayjs from "dayjs";
  2. import { message } from "@/utils/message";
  3. import { getReferralList } from "@/api/distribution";
  4. import type { PaginationProps } from "@pureadmin/table";
  5. import { onMounted, reactive, ref } from "vue";
  6. import type { ReferralQuery } from "../../utils/types";
  7. import {
  8. initPagination,
  9. handlePageSizeChange,
  10. handleCurrentPageChange,
  11. resetPagination
  12. } from "@/utils/paginationHelper";
  13. export function useReferral() {
  14. const form = reactive<ReferralQuery>({
  15. distributorId: undefined,
  16. userId: undefined,
  17. status: undefined,
  18. startDate: "",
  19. endDate: ""
  20. });
  21. const loading = ref(true);
  22. const dataList = ref([]);
  23. const pagination = reactive<PaginationProps>(initPagination());
  24. const statusMap: Record<number, { text: string; type: "success" | "warning" | "danger" | "info" | "primary" }> = {
  25. 0: { text: "待生效", type: "warning" },
  26. 1: { text: "已生效", type: "success" },
  27. 2: { text: "已失效", type: "danger" }
  28. };
  29. const columns: TableColumnList = [
  30. {
  31. label: "分销员名称",
  32. prop: "distributorName",
  33. minWidth: 120,
  34. formatter: ({ distributorName }) => distributorName || "-"
  35. },
  36. {
  37. label: "用户名称",
  38. prop: "userName",
  39. minWidth: 120,
  40. formatter: ({ userName }) => userName || "-"
  41. },
  42. {
  43. label: "状态",
  44. prop: "status",
  45. minWidth: 90,
  46. cellRenderer: ({ row }) => {
  47. const item = statusMap[row.status] || { text: "未知", type: "info" };
  48. return <el-tag type={item.type as any} size="small">{item.text}</el-tag>;
  49. }
  50. },
  51. {
  52. label: "首单ID",
  53. prop: "firstOrderId",
  54. minWidth: 100,
  55. formatter: ({ firstOrderId }) => firstOrderId || "-"
  56. },
  57. {
  58. label: "首单金额",
  59. prop: "firstOrderAmount",
  60. minWidth: 100,
  61. cellRenderer: ({ row }) => {
  62. return row.firstOrderAmount ? (
  63. <span class="text-red-600 font-bold">¥{row.firstOrderAmount}</span>
  64. ) : (
  65. <span class="text-gray-400">-</span>
  66. );
  67. }
  68. },
  69. {
  70. label: "首单时间",
  71. prop: "firstOrderTime",
  72. minWidth: 160,
  73. formatter: ({ firstOrderTime }) =>
  74. firstOrderTime
  75. ? dayjs(firstOrderTime).format("YYYY-MM-DD HH:mm:ss")
  76. : "-"
  77. },
  78. {
  79. label: "生效时间",
  80. prop: "effectiveTime",
  81. minWidth: 160,
  82. formatter: ({ effectiveTime }) =>
  83. effectiveTime
  84. ? dayjs(effectiveTime).format("YYYY-MM-DD HH:mm:ss")
  85. : "-"
  86. },
  87. {
  88. label: "失效时间",
  89. prop: "expireTime",
  90. minWidth: 160,
  91. formatter: ({ expireTime }) =>
  92. expireTime
  93. ? dayjs(expireTime).format("YYYY-MM-DD HH:mm:ss")
  94. : "-"
  95. },
  96. {
  97. label: "创建时间",
  98. prop: "createTime",
  99. minWidth: 160,
  100. formatter: ({ createTime }) =>
  101. createTime
  102. ? dayjs(createTime).format("YYYY-MM-DD HH:mm:ss")
  103. : "-"
  104. }
  105. ];
  106. async function onSearch() {
  107. loading.value = true;
  108. try {
  109. const searchParams: any = {
  110. page: pagination.currentPage,
  111. pageSize: pagination.pageSize
  112. };
  113. if (form.distributorId) searchParams.distributorId = form.distributorId;
  114. if (form.userId) searchParams.userId = form.userId;
  115. if (form.status !== undefined && form.status !== null)
  116. searchParams.status = form.status;
  117. if (form.startDate) searchParams.startDate = form.startDate;
  118. if (form.endDate) searchParams.endDate = form.endDate;
  119. const { data } = await getReferralList(searchParams);
  120. if (data) {
  121. dataList.value = data.list || [];
  122. pagination.total = data.total || 0;
  123. }
  124. } catch (error) {
  125. console.error("获取推荐记录列表失败:", error);
  126. dataList.value = [];
  127. pagination.total = 0;
  128. } finally {
  129. setTimeout(() => {
  130. loading.value = false;
  131. }, 300);
  132. }
  133. }
  134. const resetForm = formEl => {
  135. if (!formEl) return;
  136. formEl.resetFields();
  137. resetPagination(pagination, onSearch);
  138. };
  139. function handleSizeChange(val: number) {
  140. handlePageSizeChange(val, pagination, onSearch);
  141. }
  142. function handleCurrentChange(val: number) {
  143. handleCurrentPageChange(val, pagination, onSearch);
  144. }
  145. onMounted(() => {
  146. onSearch();
  147. });
  148. return {
  149. form,
  150. loading,
  151. columns,
  152. dataList,
  153. pagination,
  154. statusMap,
  155. onSearch,
  156. resetForm,
  157. handleSizeChange,
  158. handleCurrentChange
  159. };
  160. }