previewMassSendingStrategy.tsx 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. import { Card, Form, Input, Radio } from 'antd';
  2. import React, { useEffect } from 'react';
  3. import style from '../../index.less';
  4. import SendTimeSet from '@/pages/weComTask/components/sendTimeSet';
  5. import FilterUser from '@/pages/weComTask/components/filterUser';
  6. import dayjs from 'dayjs';
  7. import '../../global.less'
  8. /**
  9. * 群发预览
  10. * @param param0
  11. * @returns
  12. */
  13. const PreviewMassSendingStrategy: React.FC<{ massSendingStrategy: { [x: string]: any }, configType?: BUSINES_SPLAN_API.ConfigTypeProps }> = ({ massSendingStrategy, configType = 'USER_GROUP' }) => {
  14. /************************************************/
  15. const [form] = Form.useForm();
  16. const strategySettings = Form.useWatch('strategySettings', form);
  17. /************************************************/
  18. useEffect(() => {
  19. if (massSendingStrategy) {
  20. form.setFieldsValue({
  21. ...massSendingStrategy, strategySettings: massSendingStrategy?.strategySettings?.map(item => {
  22. const { sendTime, startTime, endTime, sendDay, timeRepeatType } = item
  23. if (timeRepeatType === 'TIME_TYPE_SINGLE_PLACE') {
  24. return {
  25. ...item,
  26. timeRepeatType,
  27. sendDay: sendDay ? dayjs(sendDay + ' ' + sendTime) : undefined
  28. }
  29. }
  30. return {
  31. ...item,
  32. timeRepeatType,
  33. sendTime: sendTime ? dayjs('2025-04-25 ' + sendTime) : undefined,
  34. startTime: startTime ? dayjs(startTime) : undefined,
  35. endTime: endTime ? dayjs(endTime) : undefined,
  36. sendDay: sendDay ? dayjs(sendDay) : undefined
  37. }
  38. })
  39. })
  40. }
  41. }, [massSendingStrategy])
  42. return <Form
  43. form={form}
  44. name={'newMassSendingShowzs' + configType}
  45. labelAlign='left'
  46. labelCol={{ span: 5 }}
  47. colon={false}
  48. preserve={true}
  49. >
  50. <Card
  51. title={<strong>基础信息配置</strong>}
  52. style={{ background: '#fff', marginBottom: 10 }}
  53. id='basicInfo'
  54. >
  55. <div className='block_tm'>
  56. <Form.Item label={<strong>群发标题</strong>} name="groupSendName">
  57. <Input placeholder="请输入标题" />
  58. </Form.Item>
  59. </div>
  60. </Card>
  61. <Form.List name="strategySettings">
  62. {(fields) => (
  63. <>
  64. {fields.map(({ key, name, ...restField }, index) => {
  65. const timeRepeatType = strategySettings?.[index]?.timeRepeatType
  66. const sendData = strategySettings?.[index]?.sendData
  67. return <Card
  68. key={key}
  69. title={<strong>策略{index + 1}配置</strong>}
  70. style={{ background: '#fff', marginBottom: 10 }}
  71. >
  72. <div className='block_tm'>
  73. <div className={style.strategy_item}>
  74. <Form.Item
  75. {...restField}
  76. label={<strong>策略名称</strong>}
  77. name={[name, 'strategyName']}
  78. >
  79. <Input placeholder="请输入标题" />
  80. </Form.Item>
  81. <SendTimeSet isShow active='all' form={form} restField={restField} name={name} timeRepeatType={timeRepeatType} />
  82. <Form.List name={[name, 'sendData']}>
  83. {(fields) => (
  84. <>
  85. {fields.map(({ key, name, ...restField }, i) => {
  86. return <Card
  87. key={i}
  88. title={<strong>策略{index + 1} 发送对象{i + 1}</strong>}
  89. style={{ background: '#fff', marginBottom: 10 }}
  90. >
  91. <div style={{ display: 'flex', flexDirection: 'column', alignItems: 'flex-start' }}>
  92. <Form.Item
  93. {...restField}
  94. name={[name, 'externalUserType']}
  95. rules={[{ required: true, message: '请选择转移对象!' }]}
  96. noStyle
  97. >
  98. <Radio.Group options={[{ label: '全部', value: 'all' }, { label: '指定', value: 'specify' }]} />
  99. </Form.Item>
  100. {sendData?.[i]?.externalUserType === 'specify' && <div style={{ marginTop: 8, width: '100%' }}>
  101. <Form.Item
  102. {...restField}
  103. name={[name, 'externalUserFilter']}
  104. rules={[{ required: true, message: '请选择人群包!' }]}
  105. noStyle
  106. >
  107. <FilterUser isSHow configType={configType} />
  108. </Form.Item>
  109. </div>}
  110. </div>
  111. </Card>
  112. })}
  113. </>
  114. )}
  115. </Form.List>
  116. </div>
  117. </div>
  118. </Card>
  119. })}
  120. </>
  121. )}
  122. </Form.List>
  123. </Form>
  124. };
  125. export default React.memo(PreviewMassSendingStrategy);