index.tsx 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  1. import React, { useEffect, useState } from "react"
  2. import DayAd from "./dayAd"
  3. import columns12 from "./tableConfig"
  4. import { getPresets } from "@/components/QueryForm/const"
  5. import TableData from "../../components/TableData"
  6. import QueryForm from "@/components/QueryForm"
  7. import { PromotionDataDay, getPromotionDataTencentListApi, getPromotionDataTencentTotalApi, newEditAdqAdgroupsDataApi } from "@/services/gameData/adlist"
  8. import { useAjax } from "@/Hook/useAjax"
  9. import moment from "moment"
  10. import { Button, Space, Switch, message, notification } from "antd"
  11. import { PauseCircleOutlined, PlayCircleOutlined } from "@ant-design/icons"
  12. const TencentMonitor: React.FC = () => {
  13. /***************************************/
  14. const [queryForm, setQueryForm] = useState<PromotionDataDay>({ pageNum: 1, pageSize: 50, sourceSystem: 'ZX_ONE', costBeginDate: moment().format('YYYY-MM-DD'), costEndDate: moment().format('YYYY-MM-DD') })
  15. const [totalData, setTotalData] = useState<any[]>([])
  16. const [visible, setVisible] = useState<boolean>(false)
  17. const [promotionId, setPromotionId] = useState<number>()
  18. const [adName, setAdName] = useState<string>('')
  19. const [selectedRows, setSelectedRows] = useState<any[]>([])
  20. const [isZj, setIsZj] = useState<boolean>(true)
  21. const getPromotionDataTencentList = useAjax((params) => getPromotionDataTencentListApi(params))
  22. const getPromotionDataTencentTotal = useAjax((params) => getPromotionDataTencentTotalApi(params))
  23. const editAdqAdgroupsData = useAjax((params) => newEditAdqAdgroupsDataApi(params))
  24. /***************************************/
  25. useEffect(() => {
  26. getPromotionDataTencentList.run(queryForm)
  27. getPromotionDataTencentTotal.run(queryForm).then(res => {
  28. res.id = 1
  29. res.accountName = '总计'
  30. setTotalData([res])
  31. })
  32. }, [queryForm])
  33. const dayHandle = (data: any) => {
  34. setVisible(true)
  35. setAdName(data.promotionName)
  36. setPromotionId(data.promotionId)
  37. }
  38. // 批量启停
  39. const adStatus = (type: 'play' | 'suspend') => {
  40. let params: any = {}
  41. if (type === 'play') {
  42. params.configuredStatus = 'AD_STATUS_NORMAL'
  43. params.adgroupIds = selectedRows.filter((item: { configuredStatus: string, promotionId: number }) => item.configuredStatus === 'AD_STATUS_SUSPEND').map(item => item.promotionId)
  44. } else {
  45. params.configuredStatus = 'AD_STATUS_SUSPEND'
  46. params.adgroupIds = selectedRows.filter((item: { configuredStatus: string, promotionId: number }) => item.configuredStatus === 'AD_STATUS_NORMAL').map(item => item.promotionId)
  47. }
  48. if (params.adgroupIds.length === 0) {
  49. message.warn(`所以账号都是${type === 'play' ? '启动' : '暂停'}状态,无需${type === 'play' ? '启动' : '暂停'}操作`)
  50. return
  51. }
  52. editAdqAdgroupsData.run(params).then(res => {
  53. message.success(`${type === 'play' ? '启动' : '暂停'}成功: ${res.success},失败: ${res.fail}`)//
  54. if (res?.fail) {
  55. notification.error({
  56. message: `${type === 'play' ? '启动' : '暂停'}失败`,
  57. description: `成功: ${res.success},修改失败${res.fail}条,失败的请到任务列表查看`,
  58. duration: 0
  59. });
  60. }
  61. getPromotionDataTencentList.refresh()
  62. setSelectedRows([])
  63. })
  64. }
  65. return <div>
  66. <TableData
  67. czChild={<Space>
  68. {/* <Switch checkedChildren="开启全选" unCheckedChildren="关闭全选" checked={!isZj} onChange={(e) => { setIsZj(!e); }} /> */}
  69. <Button type='primary' size="small" style={{ background: '#67c23a', borderColor: '#67c23a' }} loading={editAdqAdgroupsData.loading} icon={<PlayCircleOutlined />} disabled={selectedRows.length === 0} onClick={() => adStatus('play')}>启动</Button>
  70. <Button type='primary' size="small" style={{ background: '#e6a23c', borderColor: '#e6a23c' }} loading={editAdqAdgroupsData.loading} icon={<PauseCircleOutlined />} disabled={selectedRows.length === 0} onClick={() => adStatus('suspend')}>暂停</Button>
  71. <span style={{ color: 'red' }}>操作完数据结果延时5分钟之内,即时结果去腾讯后台查看</span>
  72. </Space>}
  73. leftChild={<QueryForm
  74. initialValues={{ sourceSystem: 'ZX_ONE', consumeDay: [moment(), moment()] }}
  75. onChange={(data: any) => {
  76. const { type, gameClassify, costBeginDay, costEndDay, sysUserName, ...params } = data
  77. let newQueryForm = JSON.parse(JSON.stringify(queryForm))
  78. newQueryForm.pageNum = 1
  79. newQueryForm.pitcherName = sysUserName
  80. newQueryForm.accountType = type
  81. newQueryForm.classify = gameClassify
  82. if (costBeginDay && costEndDay) {
  83. newQueryForm.costBeginDate = costBeginDay
  84. newQueryForm.costEndDate = costEndDay
  85. } else {
  86. delete newQueryForm.costBeginDate
  87. delete newQueryForm.costEndDate
  88. }
  89. setQueryForm({ ...newQueryForm, ...params })
  90. }}
  91. isSource
  92. isAccountId
  93. isAccount
  94. isType
  95. isAgentId
  96. isBGGameClassify
  97. isConsumeDay={{ ranges: getPresets() }}
  98. isCpName
  99. isGameId
  100. isSysUserId
  101. isProjectId
  102. isProjectName
  103. isPromotionId
  104. isPromotionName
  105. isAdTXStatus
  106. />}
  107. isZj={isZj}
  108. totalData={totalData}
  109. scroll={{ x: 1000, y: 600 }}
  110. ajax={getPromotionDataTencentList}
  111. fixed={{ left: 3, right: 1 }}
  112. dataSource={getPromotionDataTencentList?.data?.records?.map((item: any) => ({ ...item, id: Number(item.promotionId) }))}
  113. total={getPromotionDataTencentList?.data?.total}
  114. page={queryForm.pageNum}
  115. pageSize={queryForm.pageSize}
  116. sortData={{
  117. field: queryForm?.sortFiled,
  118. order: queryForm?.sortType === 'asc' ? 'ascend' : 'descend'
  119. }}
  120. title='腾讯广告监控'
  121. onChange={(props: any) => {
  122. let { pagination, sortData } = props
  123. let { current, pageSize } = pagination
  124. let newQueryForm = JSON.parse(JSON.stringify(queryForm))
  125. if (sortData && sortData?.order) {
  126. newQueryForm['sortType'] = sortData?.order === 'ascend' ? 'asc' : 'desc'
  127. newQueryForm['sortFiled'] = sortData?.field
  128. } else {
  129. delete newQueryForm['sortType']
  130. delete newQueryForm['sortFiled']
  131. }
  132. newQueryForm.pageNum = current
  133. newQueryForm.pageSize = pageSize
  134. setQueryForm({ ...newQueryForm })
  135. }}
  136. rowSelection={{
  137. selectedRowKeys: selectedRows.map(item => item.promotionId + ''),
  138. getCheckboxProps: (record: any) => ({
  139. disabled: record.status === 'STATUS_DELETED' || record?.accountName === '总计'
  140. }),
  141. onSelect: (record: { promotionId: number }, selected: boolean) => {
  142. if (selected) {
  143. selectedRows.push({ ...record })
  144. setSelectedRows([...selectedRows])
  145. } else {
  146. let newSelectAccData = selectedRows.filter((item: { promotionId: number }) => item.promotionId !== record.promotionId)
  147. setSelectedRows([...newSelectAccData])
  148. }
  149. },
  150. onSelectAll: (selected: boolean, selectedRowss: { promotionId: number }[], changeRows: { promotionId: number }[]) => {
  151. if (selected) {
  152. let newSelectAccData = [...selectedRows]
  153. changeRows.forEach((item: { promotionId: number }) => {
  154. let index = newSelectAccData.findIndex((ite: { promotionId: number }) => ite.promotionId === item.promotionId)
  155. if (index === -1) {
  156. newSelectAccData.push({ ...item })
  157. }
  158. })
  159. setSelectedRows([...newSelectAccData])
  160. } else {
  161. let newSelectAccData = selectedRows.filter((item: { promotionId: number }) => {
  162. let index = changeRows.findIndex((ite: { promotionId: number }) => ite.promotionId === item.promotionId)
  163. if (index !== -1) {
  164. return false
  165. } else {
  166. return true
  167. }
  168. })
  169. setSelectedRows([...newSelectAccData])
  170. }
  171. }
  172. }}
  173. config={columns12(dayHandle, () => { getPromotionDataTencentList.refresh() })}
  174. configName={'腾讯广告监控'}
  175. />
  176. {visible && <DayAd adName={adName} visible={visible} onClose={() => { setVisible(false); setPromotionId(undefined) }} queryForm={queryForm} promotionId={promotionId} />}
  177. </div>
  178. }
  179. export default TencentMonitor