index.tsx 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. import React, { useContext, useEffect, useState } from "react"
  2. import style from '../index.less'
  3. import { Button, Space, Tag } from "antd"
  4. import { EditOutlined } from "@ant-design/icons"
  5. import { DispatchAddelivery } from ".."
  6. import NewDynamic from "./newDynamic"
  7. import { AD_STATUS_ENUM, CONVERSION_DATA_ENUM, CONVERSION_TARGET_ENUM, DELIVERY_MODE_ENUM, FLOATING_ZONE_TYPE_ENUM, PAGE_TYPE_ENUM, TEXT_LINK_TYPE_ENUM } from "../../const"
  8. import { getProfilesApi } from "@/services/adqV3/global"
  9. import { useAjax } from "@/Hook/useAjax"
  10. /**
  11. * 创意
  12. * @returns
  13. */
  14. const Dynamic: React.FC<{ creativeTemplateAppellation?: string, creativeTemplateStyle?: string }> = ({ creativeTemplateAppellation, creativeTemplateStyle }) => {
  15. /***************************************/
  16. const { addelivery, setAddelivery, clearData, setAccountCreateLogs, accountCreateLogs, putInType, setIsDqSubmit } = useContext(DispatchAddelivery)!;
  17. const { adgroups, dynamic: dynamicData } = addelivery;
  18. const { deliveryMode, creativeTemplateId, dynamicCreativeName, creativeComponents, configuredStatus } = dynamicData
  19. const { textLink, actionButton, showData, brand, mainJumpInfo, floatingZoneComponent, creativeLabelDTOS, creativeBarrageDTOS, creativeFirstReplyDTO } = creativeComponents || {}
  20. const [newVisible, setNewVisible] = useState<boolean>(false);
  21. const [profileData, setprofileData] = useState<any>()
  22. const getProfiles = useAjax((params) => getProfilesApi(params))
  23. /***************************************/
  24. useEffect(() => {
  25. if (['PAGE_TYPE_H5_PROFILE'].includes(brand?.[0]?.value?.jumpInfo?.pageType)) {
  26. getProfiles.run({}).then(res => {
  27. if (res) {
  28. setprofileData(res?.find((item: { id: any }) => item.id === brand?.[0]?.value?.profileId))
  29. }
  30. })
  31. }
  32. }, [brand])
  33. return <div className={`${style.settingsBody_content_row} ${style.row3}`}>
  34. <div className={style.title}>
  35. <span>创意信息</span>
  36. </div>
  37. <div className={style.detail}>
  38. <div className={style.detail_body}>
  39. {dynamicData && Object.keys(dynamicData).length > 0 && <>
  40. <p style={{ fontWeight: 'bold', color: configuredStatus === 'AD_STATUS_NORMAL' ? '#52c41a' : '#FF4D4F' }}>创意状态:{AD_STATUS_ENUM[configuredStatus as keyof typeof AD_STATUS_ENUM]}</p>
  41. <p>创意名称:{dynamicCreativeName}</p>
  42. <p style={{ fontWeight: 'bold', color: '#000' }}>投放模式:{DELIVERY_MODE_ENUM[deliveryMode as keyof typeof DELIVERY_MODE_ENUM]}</p>
  43. <p>{((creativeTemplateId && creativeTemplateAppellation) || creativeTemplateId) && `创意形式:${creativeTemplateAppellation || creativeTemplateId}`}</p>
  44. {brand?.length > 0 && <>
  45. <p style={{ fontWeight: 'bold', color: '#000' }}>品牌形象跳转:{PAGE_TYPE_ENUM[brand?.[0]?.value?.jumpInfo?.pageType as keyof typeof PAGE_TYPE_ENUM]}</p>
  46. {['PAGE_TYPE_H5_PROFILE'].includes(brand?.[0]?.value?.jumpInfo?.pageType) ? <>
  47. {profileData ? <>
  48. <Space>
  49. <img src={profileData?.headImageUrl} alt="" width={20} style={{ display: 'block' }} />
  50. <span style={{ fontWeight: 'bold', color: '#000', fontSize: 12 }}>{profileData?.profileName}</span>
  51. </Space>
  52. <p>详细描述:{profileData?.description}</p>
  53. </> : <span style={{ color: 'red', fontWeight: 'bold', fontSize: 12 }}>{getProfiles.loading ? '' : '当前头像昵称跳转页被删除'} </span>}
  54. </> : ['PAGE_TYPE_NOT_USED'].includes(brand?.[0]?.value?.jumpInfo?.pageType) && <Space align="center">
  55. <img src={brand?.[0]?.value?.brandImageId} alt="" width={20} style={{ display: 'block' }} />
  56. <span style={{ fontWeight: 'bold', color: '#000', fontSize: 12 }}>{brand?.[0]?.value?.brandName}</span>
  57. </Space>}
  58. </>}
  59. <p style={{ fontWeight: 'bold', color: '#000' }}>跳转类型:{mainJumpInfo?.map((item: any) => {
  60. let pageType = item.value.pageType
  61. return PAGE_TYPE_ENUM[pageType as keyof typeof PAGE_TYPE_ENUM]
  62. }).toString()}</p>
  63. {textLink?.length > 0 && <>
  64. <p style={{ fontWeight: 'bold', color: '#000' }}>朋友圈文字链:开启</p>
  65. <p>文字链文案:{TEXT_LINK_TYPE_ENUM[textLink?.[0]?.value?.linkNameType as keyof typeof TEXT_LINK_TYPE_ENUM]}</p>
  66. {textLink?.[0]?.value?.jumpInfo?.pageType && <p>跳转落地页:{PAGE_TYPE_ENUM[textLink?.[0]?.value?.jumpInfo?.pageType as keyof typeof PAGE_TYPE_ENUM]}</p>}
  67. </>}
  68. {actionButton?.length > 0 && <>
  69. <p style={{ fontWeight: 'bold', color: '#000' }}>行动按钮:开启</p>
  70. <p>按钮文案:{actionButton?.[0]?.value?.buttonText}</p>
  71. {actionButton?.[0]?.value?.jumpInfo?.pageType && <p>跳转落地页:{PAGE_TYPE_ENUM[actionButton?.[0]?.value?.jumpInfo?.pageType as keyof typeof PAGE_TYPE_ENUM]}</p>}
  72. </>}
  73. {creativeLabelDTOS?.length > 0 && <>
  74. <p style={{ fontWeight: 'bold', color: '#000' }}>标签:</p>
  75. {creativeLabelDTOS.map((item: { content: string }, index: number) => <Tag key={index}>{item.content}</Tag>)}
  76. </>}
  77. {creativeBarrageDTOS?.length > 0 && <>
  78. <p style={{ fontWeight: 'bold', color: '#000' }}>弹幕:</p>
  79. {creativeBarrageDTOS.map((item: { text: string }, index: number) => <Tag key={index}>{item.text}</Tag>)}
  80. </>}
  81. {showData?.length > 0 && <>
  82. <p style={{ fontWeight: 'bold', color: '#000' }}>数据外显:开启</p>
  83. <p>数据类型:{CONVERSION_DATA_ENUM[showData?.[0]?.value?.conversionDataType as keyof typeof CONVERSION_DATA_ENUM]}</p>
  84. <p>转化行为:{CONVERSION_TARGET_ENUM[showData?.[0]?.value?.conversionTargetType as keyof typeof CONVERSION_TARGET_ENUM]}</p>
  85. </>}
  86. {floatingZoneComponent && Object.keys(floatingZoneComponent).length > 0 && <>
  87. <p style={{ fontWeight: 'bold', color: '#000' }}>浮层卡片:{floatingZoneComponent?.floatingZoneSwitch ? '开启' : '关闭'}</p>
  88. {floatingZoneComponent?.floatingZoneType && <p>复层卡片类型:{FLOATING_ZONE_TYPE_ENUM[floatingZoneComponent.floatingZoneType as keyof typeof FLOATING_ZONE_TYPE_ENUM]}</p>}
  89. {floatingZoneComponent?.floatingZoneImageUrl && <p style={{ display: 'flex', alignItems: 'flex-start' }}>创意图片:<img src={floatingZoneComponent?.floatingZoneImageUrl} width={40} /></p>}
  90. {floatingZoneComponent?.floatingZoneSingleImageUrl && <p style={{ display: 'flex', alignItems: 'flex-start' }}>创意图片:<img src={floatingZoneComponent?.floatingZoneSingleImageUrl} width={40} /></p>}
  91. {floatingZoneComponent?.floatingZoneName && <p>文案:{floatingZoneComponent.floatingZoneName}</p>}
  92. {floatingZoneComponent?.floatingZoneDesc && <p>文案:{floatingZoneComponent.floatingZoneDesc}</p>}
  93. {floatingZoneComponent?.floatingZoneButtonText && <p>按钮文案:{floatingZoneComponent.floatingZoneButtonText}</p>}
  94. </>}
  95. {creativeFirstReplyDTO?.text && <p>首评:{creativeFirstReplyDTO?.text}</p>}
  96. </>}
  97. </div>
  98. <div className={style.detail_footer}>
  99. <Button disabled={!(adgroups && Object.keys(adgroups)?.length > 0)} type="link" icon={<EditOutlined />} style={{ padding: 0, fontSize: 12 }} onClick={() => setNewVisible(true)}>编辑</Button>
  100. </div>
  101. </div>
  102. {/* 添加创意 */}
  103. {newVisible && <NewDynamic
  104. visible={newVisible}
  105. putInType={putInType}
  106. creativeTemplateStyle={creativeTemplateStyle}
  107. value={dynamicData}
  108. onClose={() => {
  109. setNewVisible(false)
  110. }}
  111. onChange={(dynamic) => {
  112. let oldPageTypeList = mainJumpInfo?.map((item: { value: { pageType: any } }) => item.value) || []
  113. let newPageTypeList = dynamic?.creativeComponents?.mainJumpInfo.map((item: { value: { pageType: any } }) => item.value)
  114. if (
  115. oldPageTypeList?.[0]?.pageType !== newPageTypeList?.[0]?.pageType ||
  116. oldPageTypeList?.length !== newPageTypeList?.length ||
  117. (oldPageTypeList?.[0]?.pageType === "PAGE_TYPE_WECHAT_CANVAS" && newPageTypeList?.[0]?.pageType === "PAGE_TYPE_WECHAT_CANVAS" && oldPageTypeList?.[0]?.pageSpec?.wechatCanvasSpec?.overrideCanvasHeadOption !== newPageTypeList?.[0]?.pageSpec?.wechatCanvasSpec?.overrideCanvasHeadOption) ||
  118. dynamic.deliveryMode !== deliveryMode || // 投放模式
  119. dynamic?.creativeTemplateId !== creativeTemplateId // 创意形式
  120. ) {
  121. setAccountCreateLogs(accountCreateLogs.map(item => ({ ...item, pageList: [] })))
  122. }
  123. if (
  124. dynamic.deliveryMode === deliveryMode && // 投放模式
  125. dynamic?.creativeTemplateId === creativeTemplateId // 创意形式
  126. ) {
  127. setAddelivery({ ...addelivery, dynamic })
  128. } else {
  129. setAddelivery({ ...addelivery, dynamic, dynamicMaterialDTos: {}, dynamicCreativesTextDTOS: {} })
  130. }
  131. setNewVisible(false)
  132. clearData()
  133. setIsDqSubmit?.(false)
  134. }}
  135. />}
  136. </div>
  137. }
  138. export default React.memo(Dynamic)