target-select.vue 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. <script lang="ts" setup>
  2. /**
  3. * @Name: target-select.vue
  4. * @Description: 自动化-定向规则-生效对象
  5. * @Author: Cheney
  6. */
  7. import AdGroupSelect from '/@/views/components/ad-group-select/index.vue';
  8. interface Props {
  9. mode: string;
  10. data: AutoRule;
  11. useTmpl?: boolean;
  12. campaignId: string;
  13. }
  14. const props = defineProps<Props>();
  15. </script>
  16. <template>
  17. <div>
  18. <span class="custom-title-icon"></span>
  19. <span class="asj-h3">生效对象</span>
  20. <div style="display: flex; flex-direction: column; align-items: flex-start">
  21. <div style="margin: 5px 0">
  22. <span>广告类型:</span>
  23. <el-select v-model="data.campaignType" :disabled="mode === 'edit' || useTmpl">
  24. <el-option label="SP" value="sp"></el-option>
  25. <el-option label="SB" value="sb"></el-option>
  26. <el-option label="SD" value="sd"></el-option>
  27. </el-select>
  28. </div>
  29. <el-radio-group v-model="data.activeModel" :disabled="mode === 'edit' || useTmpl">
  30. <div class="target-radio-group">
  31. <el-radio label="campaign">当前广告活动(所有定向)</el-radio>
  32. <div class="target-radio-group-item">
  33. <el-radio label="adGroup">当前广告活动的指定广告组(所有定向)</el-radio>
  34. <AdGroupSelect
  35. v-show="mode === 'auto' && data.activeModel === 'adGroup'"
  36. v-model="data.campaignAd"
  37. style="padding-left: 23px; width: 450px"
  38. :multiple="true"
  39. :query="{ profileId: '3006125408623189', campaignType: data.campaignType, campaignId: campaignId }">
  40. </AdGroupSelect>
  41. </div>
  42. <div class="target-radio-group-item">
  43. <el-radio label="specified">指定定向</el-radio>
  44. <el-button v-show="mode === 'auto' && data.activeModel === 'specified'" style="margin-left: 20px; color: blue" link
  45. >选择定向</el-button
  46. >
  47. </div>
  48. </div>
  49. </el-radio-group>
  50. </div>
  51. </div>
  52. </template>
  53. <style lang="scss" scoped>
  54. .target-radio-group {
  55. display: flex;
  56. justify-content: flex-start;
  57. flex-direction: column;
  58. .target-radio-group-item {
  59. display: flex;
  60. flex-direction: column;
  61. justify-content: flex-start;
  62. align-items: flex-start;
  63. }
  64. }
  65. .custom-title-icon {
  66. padding-right: 10px;
  67. }
  68. .custom-title-icon:before {
  69. content: '';
  70. width: 4px;
  71. height: 15px;
  72. background: #3569d6;
  73. position: absolute;
  74. transform: translateY(55%);
  75. }
  76. </style>