index.tsx 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. import QueryForm from "@/components/QueryForm"
  2. import { useAjax } from "@/Hook/useAjax"
  3. import { EverydayListType, getPromoteDayListApi, getPromoteDayTotalApi } from "@/services/gameData/extensionData"
  4. import React, { useEffect, useState } from "react"
  5. import TableData from "../../components/TableData"
  6. import columns12 from "./tableConfig"
  7. import { getGameChoiceParentListType1Api } from "@/services/gameData"
  8. import moment from "moment"
  9. import RechargeTrend from "@/components/rechargeTrend"
  10. const Everyday: React.FC = () => {
  11. /***************************/
  12. const [queryForm, setQueryForm] = useState<EverydayListType>({ pageNum: 1, pageSize: 20, beginDay: moment().format('YYYY-MM-DD'), endDay: moment().format('YYYY-MM-DD'), sourceSystem: 'ZX_ONE' })
  13. const [gameType, setGameType] = useState<any>({})
  14. const [totalData, setTotalData] = useState<any[]>([])
  15. const [rtConfig, setRtConfig] = useState<{ accountId?: number, visible: boolean, agentId?: number, beginDate?: string, sourceSystem?: string }>({ visible: false })
  16. const getPromoteDayList = useAjax((params) => getPromoteDayListApi(params))
  17. const getPromoteDayTotal = useAjax((params) => getPromoteDayTotalApi(params))
  18. const getGameChoiceParentListType1 = useAjax(() => getGameChoiceParentListType1Api())
  19. /***************************/
  20. useEffect(() => {
  21. getPromoteDayTotal.run(queryForm).then(res => {
  22. res.id = 1
  23. res.dt = '总计'
  24. setTotalData([res])
  25. })
  26. getPromoteDayList.run(queryForm)
  27. }, [queryForm])
  28. useEffect(() => {
  29. getGameChoiceParentListType1.run().then(res => {
  30. let newType: any = {}
  31. res.forEach((item: { id: number, name: string }) => {
  32. newType[item.id] = item.name
  33. })
  34. setGameType(newType)
  35. })
  36. }, [])
  37. const rechargeTrendHandle = (data: any) => {
  38. if (data?.accountId) {
  39. setRtConfig({ visible: true, accountId: data?.accountId, agentId: data.agentId, beginDate: data.dt, sourceSystem: data.sourceSystem })
  40. }
  41. }
  42. return <div>
  43. <TableData
  44. leftChild={<QueryForm
  45. initialValues={{ sourceSystem: 'ZX_ONE', consumeDay: [moment(), moment()] }}
  46. onChange={(data: any) => {
  47. const { pitcherId, costBeginDay, costEndDay, type, ...params } = data
  48. console.log(params, pitcherId)
  49. let newQueryForm = JSON.parse(JSON.stringify(queryForm))
  50. newQueryForm.pageNum = 1
  51. newQueryForm.sysUserId = pitcherId
  52. newQueryForm.beginDay = costBeginDay
  53. newQueryForm.endDay = costEndDay
  54. newQueryForm.accountType = type
  55. setQueryForm({ ...newQueryForm, ...params })
  56. }}
  57. isSource
  58. isAccountId
  59. isAgentId
  60. isType
  61. isConsumeDay={{}}
  62. isBGGameClassify
  63. // isCpName
  64. // isGameName
  65. isGameId
  66. // isGameType
  67. isSysUserId
  68. />}
  69. isZj
  70. totalData={totalData}
  71. scroll={{ x: 1000, y: 600 }}
  72. ajax={getPromoteDayList}
  73. fixed={{ left: 5, right: 1 }}
  74. dataSource={getPromoteDayList?.data?.records}
  75. total={getPromoteDayList?.data?.total}
  76. page={queryForm.pageNum}
  77. pageSize={queryForm.pageSize}
  78. title='推广每日数据'
  79. onChange={(props: any) => {
  80. console.log('props--->', props)
  81. let { pagination, sortData } = props
  82. let { current, pageSize } = pagination
  83. let newQueryForm = JSON.parse(JSON.stringify(queryForm))
  84. if (sortData && sortData?.order) {
  85. newQueryForm['sortType'] = sortData?.order === 'ascend' ? 'asc' : 'desc'
  86. newQueryForm['sortFiled'] = sortData?.field
  87. } else {
  88. delete newQueryForm['sortType']
  89. delete newQueryForm['sortFiled']
  90. }
  91. newQueryForm.pageNum = current
  92. newQueryForm.pageSize = pageSize
  93. setQueryForm({ ...newQueryForm })
  94. }}
  95. config={columns12(gameType, rechargeTrendHandle)}
  96. configName={'推广每日数据'}
  97. />
  98. {rtConfig.visible && <RechargeTrend {...rtConfig} onClose={() => setRtConfig({ visible: false })} />}
  99. </div>
  100. }
  101. export default Everyday