index.tsx 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. import { useAjax } from "@/Hook/useAjax"
  2. import { MediaGameDayProps, getMediaGameDayListApi, getMediaGameDayTotalApi } from "@/services/gameData/medium"
  3. import React, { useEffect, useState } from "react"
  4. import moment from "moment"
  5. import columns12 from "./tableConfig"
  6. import { getPresets } from "@/components/QueryForm/const"
  7. import TableData from "../../components/TableData"
  8. import QueryForm from "@/components/QueryForm"
  9. /**
  10. * 游戏媒体每日数据
  11. * @returns
  12. */
  13. const GameEvery: React.FC = () => {
  14. /*****************************/
  15. const [queryForm, setQueryForm] = useState<MediaGameDayProps>({
  16. pageNum: 1, pageSize: 50,
  17. sourceSystem: 'ZX_ONE',
  18. beginDate: moment().format('YYYY-MM-DD'), //subtract(30, 'd').
  19. endDate: moment().format('YYYY-MM-DD')
  20. })
  21. const [totalData, setTotalData] = useState<any[]>([])
  22. const getMediaGameDayList = useAjax((params) => getMediaGameDayListApi(params))
  23. const getMediaGameDayTotal = useAjax((params) => getMediaGameDayTotalApi(params))
  24. /*****************************/
  25. useEffect(() => {
  26. getMediaGameDayList.run(queryForm)
  27. getMediaGameDayTotal.run(queryForm).then((res: { id: number; gameName: string, beginDay?: string }) => {
  28. res.id = 1
  29. res.gameName = '总计'
  30. res.beginDay = queryForm.beginDate
  31. setTotalData([res])
  32. })
  33. }, [queryForm])
  34. return <div>
  35. <TableData
  36. leftChild={<QueryForm
  37. initialValues={{ consumeDay: [moment(), moment()], sourceSystem: 'ZX_ONE' }}
  38. onChange={(data: any) => {
  39. console.log(data)
  40. const { costBeginDay, costEndDay, type, gameClassify, cpName, ...params } = data
  41. let newQueryForm = JSON.parse(JSON.stringify(queryForm))
  42. newQueryForm.pageNum = 1
  43. newQueryForm.accountType = type
  44. newQueryForm.gameType = gameClassify
  45. newQueryForm.gameCp = cpName
  46. if (costBeginDay && costEndDay) {
  47. newQueryForm.beginDate = costBeginDay
  48. newQueryForm.endDate = costEndDay
  49. } else {
  50. delete newQueryForm.beginDate
  51. delete newQueryForm.endDate
  52. }
  53. setQueryForm({ ...newQueryForm, ...params })
  54. }}
  55. isSource
  56. isConsumeDay={{ ranges: getPresets() }}
  57. isCpName
  58. isGameId
  59. isBGGameClassify
  60. isType
  61. />}
  62. isZj
  63. totalData={totalData}
  64. scroll={{ x: 1000, y: 600 }}
  65. ajax={getMediaGameDayList}
  66. fixed={{ left: 2, right: 1 }}
  67. dataSource={getMediaGameDayList?.data?.records?.map((item: any, index: number) => ({ ...item, id: Number(queryForm.pageNum.toString() + index.toString()) }))}
  68. total={getMediaGameDayList?.data?.total}
  69. page={queryForm.pageNum}
  70. pageSize={queryForm.pageSize}
  71. sortData={{
  72. field: queryForm?.sortFiled,
  73. order: queryForm?.sortType === 'asc' ? 'ascend' : 'descend'
  74. }}
  75. title={`游戏媒体每日数据`}
  76. onChange={(props: any) => {
  77. let { pagination, sortData } = props
  78. let { current, pageSize } = pagination
  79. let newQueryForm = JSON.parse(JSON.stringify(queryForm))
  80. if (sortData && sortData?.order) {
  81. newQueryForm['sortType'] = sortData?.order === 'ascend' ? 'asc' : 'desc'
  82. newQueryForm['sortFiled'] = sortData?.field
  83. } else {
  84. delete newQueryForm['sortType']
  85. delete newQueryForm['sortFiled']
  86. }
  87. newQueryForm.pageNum = current
  88. newQueryForm.pageSize = pageSize
  89. setQueryForm({ ...newQueryForm })
  90. }}
  91. config={columns12()}
  92. configName={'游戏媒体每日数据'}
  93. />
  94. </div>
  95. }
  96. export default GameEvery