123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309 |
- import * as api from './api'
- import {dict, UserPageQuery, AddReq, DelReq, EditReq, compute, CreateCrudOptionsProps, CreateCrudOptionsRet} from '@fast-crud/fast-crud'
- import {inject} from 'vue'
- import {BaseColumn} from '/@/views/adManage/utils/commonTabColumn.js'
- import {dynBidStrategyEnum} from '/@/views/adManage/utils/enum.js'
- import {parseQueryParams} from '/@/views/adManage/utils/tools.js'
- import XEUtils from 'xe-utils'
- export const createCrudOptions = function ({crudExpose, context}: CreateCrudOptionsProps): CreateCrudOptionsRet {
- const pageRequest = async (query: UserPageQuery) => {
- const params = parseQueryParams(context.value)
- XEUtils.assign(query, params)
- return await api.GetList(query)
- }
- const editRequest = async ({form, row}: EditReq) => {
- form.id = row.id
- return await api.UpdateObj(form)
- }
- const delRequest = async ({row}: DelReq) => {
- return await api.DelObj(row.id)
- }
- const addRequest = async ({form}: AddReq) => {
- return await api.AddObj(form)
- }
- //权限判定
- const hasPermissions = inject('$hasPermissions')
- return {
- crudOptions: {
- table: {
- height: 800,
- headerCellStyle: {
- backgroundColor: '#f6f7fa', // 直接设置背景颜色
- height: '20px',
- // border: '0.5px solid #ddd',
- },
- cellStyle: {
- border: 'none',
- borderBottom: '0.5px solid #ddd',
- },
- showSummary: true,
- },
- container: {
- fixedHeight: false
- },
- actionbar: {
- show: true,
- buttons: {
- add: {
- show: false
- },
- create: {
- text: '新建广告活动',
- type: 'primary',
- show: true,
- click() {
- }
- }
- }
- },
- search: {
- show: false
- },
- toolbar: {
- buttons: {
- search: {
- show: true
- },
- compact: {
- show: false
- }
- }
- },
- request: {
- pageRequest,
- addRequest,
- editRequest,
- delRequest,
- },
- rowHandle: {
- fixed: 'right',
- width: 80,
- buttons: {
- view: {
- show: false,
- },
- edit: {
- iconRight: 'Edit',
- type: 'text',
- text: null
- // show: hasPermissions('dictionary:Update'),
- },
- remove: {
- show: false
- // iconRight: 'Delete',
- // type: 'text',
- // text: null
- // show: hasPermissions('dictionary:Delete'),
- },
- },
- },
- columns: {
- id: {
- title: 'ID',
- column: {
- show: false
- },
- form: {
- show: false
- }
- },
- campaignName: {
- title: '广告活动名称',
- column: {
- width: '200px',
- fixed: 'left',
- align: 'left',
- renderHeader() {
- return (
- <span>
- <el-tooltip placement="top" content="广告活动是一组使用共同广告预算的广告组。广告组用于组织商品(广告),以便您实现所需的业务目标。">
- <span>
- <el-icon size="14" style="display:inline-block; padding-top:2px; margin-right:3px;"><InfoFilled/></el-icon>
- </span>
- </el-tooltip>
- <span>广告活动名称</span>
- </span>
- )
- }
- },
- search: {
- show: true,
- component: {
- props: {
- clearable: true
- }
- }
- },
- form: {
- rules: [{required: true, message: '必填项'}]
- }
- },
- targetingType: {
- title: '投放类型',
- column: {
- width: '100px',
- align: 'center'
- },
- type: 'dict-select',
- search: {
- show: true
- },
- dict: dict({
- data: [
- {value: 'AUTO', label: '自动'},
- {value: 'MANUAL', label: '手动'},
- ]
- })
- },
- state: {
- title: '状态',
- column: {
- width: '90px',
- align: 'center'
- },
- type: 'dict-select',
- search: {
- show: true
- },
- dict: dict({
- data: [
- {value: 'PAUSED', label: '已暂停', color: 'warning'},
- {value: 'ENABLED', label: '投放中', color: 'success'},
- ]
- })
- },
- dynBidStrategy: {
- title: '竞价策略',
- form: {
- show: false,
- },
- column: {
- width: '160px'
- },
- type: 'dict-select',
- dict: dict({
- data: dynBidStrategyEnum
- })
- },
- startDate: {
- title: '开始日期',
- column: {
- width: '100px',
- align: 'center'
- },
- },
- endDate: {
- title: '结束日期',
- column: {
- width: '100px',
- align: 'center',
- formatter: (row) => {
- if (row.value !== null) {
- return row.value
- } else {
- return '--'
- }
- }
- },
- },
- portfolioName: {
- title: '广告组合',
- column: {
- width: '130px',
- align: 'center'
- }
- },
- dailyBudget: {
- title: '预算',
- column: {
- width: '100px',
- align: 'center',
- formatter: (row) => {
- if (row.value !== null) {
- return row.value
- } else {
- return '--'
- }
- }
- }
- },
- suggestedBudget: {
- title: '建议预算',
- form: {
- show: false
- },
- column: {
- width: '100px',
- align: 'center'
- }
- },
- percentTimeInBudget: {
- title: '预算活跃时间均值',
- column: {
- minWidth: 160,
- renderHeader() {
- return (
- <span>
- <el-tooltip placement="top" content="预算覆盖每天投放时长占比的平均值。">
- <span>
- <el-icon size="14" style="display:inline-block; padding-top:2px; margin-right:3px;"><InfoFilled/></el-icon>
- </span>
- </el-tooltip>
- <span>预算活跃时间均值</span>
- </span>
- )
- }
- },
- form: {
- show: false
- }
- },
- MissedImpressions: {
- title: '预计错过的曝光',
- form: {
- show: false
- },
- column: {
- width: 180,
- align: 'center',
- renderHeader() {
- return (
- <span>
- <el-tooltip placement="top" content="平均每笔订单的花费,系统计算,花费/广告订单量">
- <span>
- <el-icon size="14" style="display:inline-block; padding-top:2px; margin-right:3px;"><InfoFilled/></el-icon>
- </span>
- </el-tooltip>
- <span>订单成本</span>
- </span>
- )
- }
- },
- },
- MissedClicks: {
- title: '预计错过的点击',
- form: {
- show: false
- },
- column: {
- width: 180
- },
- },
- MissedSales: {
- title: '预计错过的销售',
- form: {
- show: false
- },
- column: {
- width: 180
- },
- },
- ...BaseColumn
- }
- }
- }
- }
|