box.tsx 5.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. import { Popover, Space, Image } from 'antd'
  2. import React, { useMemo } from 'react'
  3. function Box(props: { b: any }) {
  4. const { b } = props
  5. const creativePreview = b?.creativePreview || {}
  6. let el = useMemo(() => {
  7. let image_list = creativePreview?.image_list || []
  8. let image = creativePreview?.image
  9. let video = creativePreview?.video
  10. let videoImg = creativePreview?.keyFrameImageUrl
  11. if (image_list[0] || image || video) {
  12. return <div className='imagesConfig'>
  13. <Popover
  14. placement='right'
  15. content={<div>
  16. {creativePreview?.title && <div style={{ maxWidth: 300 }}><strong style={{ fontSize: 15 }}>标题:</strong>{creativePreview?.title}</div>}
  17. {creativePreview?.description && <small style={{ fontSize: 10, maxWidth: 300, display: 'inline-block' }}><strong style={{ fontSize: 13 }}>描述:</strong>{creativePreview?.description}</small>}
  18. <Space style={{ maxWidth: 300, display: 'flex', flexFlow: 'row wrap', margin: '10px 0' }}>
  19. {
  20. image_list?.length > 0 ?
  21. image_list?.map((img: string | undefined) => {
  22. return <img src={img} key={img} width={image_list?.length === 1 ? 200 : image_list?.length === 3 ? 70 : image_list?.length === 4 ? 100 : 70} />
  23. }) :
  24. image ?
  25. <img src={image} key={image} width={200} />
  26. : video ? <video src={video} style={{ width: 250 }} controls />
  27. : '--'}
  28. </Space>
  29. </div>}
  30. >
  31. {(image_list?.length > 0 || image || videoImg) && <Image
  32. preview={false}
  33. height={20}
  34. src={image_list[0] || image || videoImg}
  35. fallback=""
  36. />}
  37. </Popover>
  38. </div>
  39. } else {
  40. return <span>--</span>
  41. }
  42. }, [b])
  43. return el
  44. }
  45. export default React.memo(Box)