index.tsx 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. import React, { useEffect, useState } from "react"
  2. import TableData from "../../components/TableData"
  3. import QueryForm from "@/components/QueryForm"
  4. import { useAjax } from "@/Hook/useAjax"
  5. import { ActiveDataProps, getActiveDataListApi, getActiveDataTotalApi } from "@/services/gameData/game"
  6. import columns12 from "./tableConfig"
  7. import moment from "moment"
  8. import { ActiveEnum, TableEnum, getPresets } from "@/components/QueryForm/const"
  9. /**
  10. * 游戏留存数据
  11. * @returns
  12. */
  13. const Active: React.FC = () => {
  14. /************************************/
  15. const [queryForm, setQueryForm] = useState<ActiveDataProps>({
  16. activeTypes: 'reg' as ActiveEnum,
  17. tableTypes: 'buy' as TableEnum,
  18. pageNum: 1, pageSize: 40,
  19. registeredBeginDate: moment().format('YYYY-MM-DD'),
  20. registeredEndDate: moment().format('YYYY-MM-DD'),
  21. sourceSystem: 'ZX_ONE'
  22. })
  23. const [totalData, setTotalData] = useState<any[]>([])
  24. const getActiveDataList = useAjax((params) => getActiveDataListApi(params))
  25. const getActiveDataTotal = useAjax((params) => getActiveDataTotalApi(params))
  26. /************************************/
  27. useEffect(() => {
  28. getActiveDataList.run(queryForm)
  29. getActiveDataTotal.run(queryForm).then((res: { id: number; costDate: string; beginDay: string | undefined, activeTypes: any }) => {
  30. res.id = 1
  31. res.costDate = '总计'
  32. res.beginDay = queryForm.registeredBeginDate || moment().subtract(366, 'days').format('YYYY-MM-DD')
  33. res.activeTypes = queryForm.activeTypes
  34. setTotalData([res])
  35. })
  36. }, [queryForm])
  37. return <div>
  38. <TableData
  39. leftChild={<QueryForm
  40. initialValues={{ regDay: [moment(), moment()], sourceSystem: 'ZX_ONE', tableTypes: 'buy', activeTypes: 'reg' }}
  41. onChange={(data: any) => {
  42. console.log(data)
  43. const { regStartDay, gameClassify, regEndDay, rechargeDay, ...params } = data
  44. let newQueryForm = JSON.parse(JSON.stringify(queryForm))
  45. newQueryForm.pageNum = 1
  46. if (regStartDay && regEndDay) {
  47. newQueryForm.registeredBeginDate = regStartDay
  48. newQueryForm.registeredEndDate = regEndDay
  49. } else {
  50. delete newQueryForm.registeredBeginDate
  51. delete newQueryForm.registeredEndDate
  52. }
  53. newQueryForm.classify = gameClassify
  54. setQueryForm({ ...newQueryForm, ...params })
  55. }}
  56. isSource
  57. isRegDay={{ ranges: getPresets() }}
  58. isGameIds
  59. isBGGameClassify
  60. isUserEnterType
  61. isActiveTypes
  62. isGameDimension
  63. />}
  64. isZj
  65. totalData={totalData}
  66. scroll={{ x: 1000, y: 600 }}
  67. ajax={getActiveDataList}
  68. fixed={{ left: 2, right: 0 }}
  69. dataSource={getActiveDataList?.data?.records?.map((item: any, index: number) => ({ ...item, activeTypes: queryForm?.activeTypes, id: Number(queryForm.pageNum.toString() + index.toString()) }))}
  70. total={getActiveDataList?.data?.total}
  71. page={queryForm.pageNum}
  72. pageSize={queryForm.pageSize}
  73. sortData={{
  74. field: queryForm?.sortFiled,
  75. order: queryForm?.sortType === 'asc' ? 'ascend' : 'descend'
  76. }}
  77. estimatedRowHeight={() => 41}
  78. title={`游戏留存数据(用户活跃数据2023-08-20开始统计)`}
  79. onChange={(props: any) => {
  80. let { pagination, sortData } = props
  81. let { current, pageSize } = pagination
  82. let newQueryForm = JSON.parse(JSON.stringify(queryForm))
  83. if (sortData && sortData?.order) {
  84. newQueryForm['sortType'] = sortData?.order === 'ascend' ? 'asc' : 'desc'
  85. newQueryForm['sortFiled'] = sortData?.field
  86. } else {
  87. delete newQueryForm['sortType']
  88. delete newQueryForm['sortFiled']
  89. }
  90. newQueryForm.pageNum = current
  91. newQueryForm.pageSize = pageSize
  92. setQueryForm({ ...newQueryForm })
  93. }}
  94. config={columns12()}
  95. configName={'游戏留存数据'}
  96. />
  97. </div>
  98. }
  99. export default Active