123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181 |
- import * as api from './api'
- import {AddReq, CreateCrudOptionsProps, CreateCrudOptionsRet, DelReq, EditReq, UserPageQuery} from '@fast-crud/fast-crud'
- import {inject} from 'vue'
- import {BaseColumn} from '/@/views/adManage/utils/commonTabColumn.js'
- import {parseQueryParams} from '/@/views/adManage/utils/tools'
- 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',
- borderRight: 'none',
- },
- cellStyle: {
- border: 'none',
- borderBottom: '0.5px solid #ddd',
- },
- showSummary: true,
- stripe: false
- },
- container: {
- fixedHeight: false
- },
- actionbar: {
- show: false,
- buttons: {
- add: {
- show: false
- },
- }
- },
- 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: {
- iconRight: 'Delete',
- type: 'text',
- text: null
- // show: hasPermissions('dictionary:Delete'),
- },
- },
- },
- columns: {
- id: {
- title: 'ID',
- column: {
- show: false
- },
- form: {
- show: false
- }
- },
- campaignName: {
- title: '广告活动',
- column: {
- width: '210px',
- fixed: 'left',
- align: 'center',
- },
- search: {
- show: true,
- component: {
- props: {
- clearable: true
- }
- }
- },
- form: {
- rules: [{required: true, message: '必填项'}]
- }
- },
- placement: {
- title: '广告位',
- column: {
- align: 'center',
- width: '160px',
- formatter: (row) => {
- switch (row.value) {
- case 'top':
- return '搜索结果顶部(首页)'
- case 'rest_of_search':
- return '搜索结果的其余位置'
- case 'product_page':
- return '商品页面'
- default:
- return '暂无数据'
- }
- }
- }
- },
- dynBidStrategy: {
- title: '竞价策略',
- column: {
- align: 'center',
- width: '160px',
- formatter: (row) => {
- switch (row.value) {
- case 'MANUAL':
- return '固定竞价'
- case 'AUTO_FOR_SALES':
- return '动态竞价-提高和降低'
- case 'LEGACY_FOR_SALES':
- return '动态竞价-仅降低'
- default:
- return '暂无数据'
- }
- }
- }
- },
- bidAdjustment: {
- title: '竞价调整',
- column: {
- align: 'right',
- width: '100px',
- formatter: (row) => {
- if (row.value != null) {
- return row.value
- } else {
- return '--'
- }
- }
- }
- },
- ...BaseColumn
- }
- }
- }
- }
|