tt_pac.vue 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. <template>
  2. <component
  3. is="a-modal"
  4. v-model:visible="visible"
  5. :width="tool.getDevice() === 'mobile' ? '100%' : '600px'"
  6. :title="title"
  7. :mask-closable="false"
  8. :ok-loading="loading"
  9. @cancel="close"
  10. @before-ok="submit">
  11. <!-- 表单信息 start -->
  12. <a-form ref="formRef" :model="formData" :rules="rules" :auto-label-width="true">
  13. <a-form-item label="推送游戏" field="game_id">
  14. <a-select v-model="formData.game_id" placeholder="请选择推送游戏" @change="handleGameChange">
  15. <a-option v-for="item in gamePackageOptions" :key="item.game_id" :value="item.game_id" :label="item.name" />
  16. </a-select>
  17. </a-form-item>
  18. <a-form-item label="推送头条分包" field="fb">
  19. <a-switch v-model="formData.fb" />
  20. </a-form-item>
  21. <a-form-item label="推送转化跟踪" field="zh">
  22. <a-switch v-model="formData.zh" />
  23. </a-form-item>
  24. <a-form-item label="头条账号" field="advertiser_id">
  25. <a-select v-model="formData.advertiser_id" placeholder="请选择头条账号">
  26. <a-option
  27. v-for="item in ttAccountOptions"
  28. :key="item.advertiser_id"
  29. :value="item.advertiser_id"
  30. :label="item.advertiser_name" />
  31. </a-select>
  32. </a-form-item>
  33. </a-form>
  34. <!-- 表单信息 end -->
  35. </component>
  36. </template>
  37. <script setup>
  38. import { ref, reactive, computed } from 'vue'
  39. import { Message, Modal } from '@arco-design/web-vue'
  40. import tool from '@/utils/tool'
  41. import api from '@/api/system/post'
  42. import { request } from '@/utils/request'
  43. import commonApi from '../../api/common'
  44. import agentSiteApi from '../../api/advert/agentSite'
  45. const emit = defineEmits(['success'])
  46. // 引用定义
  47. const formRef = ref()
  48. const mode = ref('')
  49. const visible = ref(false)
  50. const loading = ref(false)
  51. const siteIds = ref()
  52. const ttAccountOptions = ref([])
  53. const gamePackageOptions = ref([])
  54. let title = computed(() => {
  55. return '推送头条分包和转化'
  56. })
  57. // 表单初始值
  58. const initialFormData = {
  59. id: '',
  60. game_id: '',
  61. fb: true,
  62. zh: true,
  63. remark: '',
  64. }
  65. // 表单信息
  66. const formData = reactive({ ...initialFormData })
  67. // 设置批量数据
  68. const setSiteIds = async (value) => {
  69. siteIds.value = value
  70. }
  71. // 验证规则
  72. const rules = {
  73. game_id: [{ required: true, message: '推送游戏不能为空' }],
  74. advertiser_id: [{ required: true, message: '头条账号不能为空' }],
  75. }
  76. // 打开弹框
  77. const open = async (type = 'ks') => {
  78. mode.value = type
  79. // 重置表单数据
  80. Object.assign(formData, initialFormData)
  81. formRef.value.clearValidate()
  82. formRef.value.resetFields()
  83. visible.value = true
  84. await initPage()
  85. }
  86. // 初始化页面数据
  87. const initPage = async () => {
  88. await getGamePackageOptions()
  89. await getTtAccountOptions()
  90. }
  91. // 游戏ID改变
  92. const handleGameChange = (value) => {
  93. const gameData = gamePackageOptions.value.find((item) => item.game_id === value)
  94. formData.id = gameData.id
  95. }
  96. // 获取母包列表
  97. const getGamePackageOptions = async () => {
  98. const res = await commonApi.getPackageOptionsApi({ media_id: 1 })
  99. if (res.code === 200) {
  100. gamePackageOptions.value = res.data
  101. }
  102. }
  103. // 获取头条账号Options
  104. const getTtAccountOptions = async () => {
  105. const res = await agentSiteApi.getTtAccountOptionsApi()
  106. if (res.code === 200) {
  107. ttAccountOptions.value = res.data
  108. }
  109. }
  110. // 设置数据
  111. const setFormData = async (data) => {
  112. for (const key in formData) {
  113. if (data[key] != null && data[key] != undefined) {
  114. formData[key] = data[key]
  115. }
  116. }
  117. }
  118. // 数据保存
  119. const submit = async (done) => {
  120. const validate = await formRef.value?.validate()
  121. if (!validate) {
  122. loading.value = true
  123. let data = { ...formData }
  124. console.log(data)
  125. let result = {}
  126. // 推送
  127. result = await agentSiteApi.ttPushNewEventApi({
  128. site_ids: siteIds.value,
  129. game_package_id: data.id,
  130. geme_id: data.game_id,
  131. fb: data.fb,
  132. zh: data.zh,
  133. advertiser_id: data.advertiser_id,
  134. })
  135. if (result.code === 200) {
  136. // Message.success("操作成功");
  137. Modal.info({
  138. title: '推送结果',
  139. content: result.data.message,
  140. })
  141. emit('success')
  142. done(true)
  143. }
  144. // 防止连续点击提交
  145. setTimeout(() => {
  146. loading.value = false
  147. }, 500)
  148. }
  149. done(false)
  150. }
  151. // 关闭弹窗
  152. const close = () => (visible.value = false)
  153. defineExpose({ open, setFormData, setSiteIds })
  154. </script>