sendEmailTable.tsx 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. import { useAjax } from "@/Hook/useAjax"
  2. import { delSendEmailLogApi, getSendEmailListApi, getSendEmailLogProps } from "@/services/gameData/roleOperate"
  3. import { Button, DatePicker, Popconfirm, Space, Table, Tag, message } from "antd"
  4. import React, { useEffect, useState } from "react"
  5. import { columnsSendEmailLog } from "./tableConfig"
  6. import './index.less'
  7. import moment from "moment"
  8. import SendMail from "./sendMail"
  9. interface Props {
  10. data: any
  11. onChange?: () => void
  12. }
  13. const SendEmailTable: React.FC<Props> = ({ data, onChange }) => {
  14. /*********************************/
  15. const [queryForm, setQueryForm] = useState<getSendEmailLogProps>({ pageNum: 1, pageSize: 20 })
  16. const [selectedRowKeys, setSelectedRowKeys] = useState<any[]>([])
  17. const [sendEmialvisible, setSendEmialVisible] = useState<boolean>(false)
  18. const [ids, setIds] = useState<string[]>([])
  19. const getSendEmailList = useAjax((params) => getSendEmailListApi(params))
  20. const delSendEmailLog = useAjax((params) => delSendEmailLogApi(params))
  21. /*********************************/
  22. useEffect(() => {
  23. getSendEmailList.run({
  24. ...queryForm,
  25. gameId: data.user_reg_game_id,
  26. roleId: data.role_id,
  27. serverId: data.server_id,
  28. userId: data.user_id
  29. })
  30. }, [queryForm, data])
  31. const del = (ids: any[]) => {
  32. delSendEmailLog.run(ids.toString()).then(res => {
  33. if (res) {
  34. onChange?.()
  35. getSendEmailList.refresh()
  36. message.success('删除成功')
  37. }
  38. })
  39. }
  40. const update = (ids: any[]) => {
  41. setIds(ids)
  42. setSendEmialVisible(true)
  43. }
  44. return <Space style={{ width: '100%' }} direction="vertical">
  45. <Space>
  46. <DatePicker.RangePicker
  47. size="small"
  48. showTime
  49. allowClear
  50. placeholder={['发送开始时间', '发送结束时间']}
  51. value={queryForm?.startDateTime && queryForm?.endDateTime ? [moment(queryForm?.startDateTime), moment(queryForm?.endDateTime)] as any : undefined}
  52. onChange={(e) => {
  53. if (e && e.length === 2) {
  54. setQueryForm({ ...queryForm, pageNum: 1, startDateTime: moment(e[0]).format('YYYY-MM-DD HH:mm:ss'), endDateTime: moment(e[1]).format('YYYY-MM-DD HH:mm:ss') })
  55. } else {
  56. setQueryForm({ ...queryForm, startDateTime: undefined, endDateTime: undefined })
  57. }
  58. }}
  59. />
  60. <Button type="primary" size="small" onClick={() => { update(selectedRowKeys) }} disabled={selectedRowKeys.length === 0}>批量更新</Button>
  61. <Popconfirm
  62. title="确定删除?"
  63. disabled={selectedRowKeys.length === 0}
  64. onConfirm={() => { del(selectedRowKeys.map(item => item.id)) }}
  65. >
  66. <Button danger size="small" disabled={selectedRowKeys.length === 0}>批量删除</Button>
  67. </Popconfirm>
  68. </Space>
  69. <Table
  70. dataSource={getSendEmailList?.data?.records}
  71. columns={columnsSendEmailLog(update, del)}
  72. loading={getSendEmailList.loading}
  73. scroll={{ x: 380, y: 300 }}
  74. className="uuTable"
  75. rowKey={'id'}
  76. pagination={
  77. {
  78. total: getSendEmailList?.data?.total || 0,//总共多少条数据,服务器给,设置后分页自动计算页数
  79. current: getSendEmailList?.data?.current || 1,//当前页数,需state控制配合翻页
  80. pageSize: getSendEmailList?.data?.size || 20,
  81. defaultCurrent: 1,//默认初始的当前页数
  82. pageSizeOptions: ['10', '20', '30', '40', '50', '60', '70', '80', '90', '100'],
  83. showTotal: (total) => <Tag color="cyan">总共{total}数据</Tag>,
  84. showSizeChanger: true, //手动开启条数筛选器,默认超过50条开启
  85. size: 'small',//设置分页尺寸
  86. onChange: (page: number, pageSize: number) => {
  87. setQueryForm({ ...queryForm, pageNum: page, pageSize })
  88. },
  89. showLessItems: true
  90. }
  91. }
  92. rowSelection={{
  93. selectedRowKeys: selectedRowKeys.map(item => item?.id),
  94. onChange: (selectedRowKeys: React.Key[], selectedRows: any[]) => {
  95. setSelectedRowKeys(selectedRows)
  96. },
  97. }}
  98. />
  99. {/* 发送礼包 */}
  100. {sendEmialvisible && <SendMail
  101. visible={sendEmialvisible}
  102. ids={ids as any}
  103. data={[data]}
  104. onClose={() => setSendEmialVisible(false)}
  105. onChange={() => {
  106. setSendEmialVisible(false);
  107. getSendEmailList?.refresh();
  108. setIds([])
  109. setSelectedRowKeys([])
  110. }}
  111. />}
  112. </Space>
  113. }
  114. export default React.memo(SendEmailTable)