|
|
@@ -10,21 +10,25 @@
|
|
|
{{ scope.$index + 1 }}
|
|
|
</template>
|
|
|
</el-table-column>
|
|
|
- <el-table-column label="广告位位置" prop="xx"></el-table-column>
|
|
|
- <el-table-column label="广告位类型" prop="xx">
|
|
|
- <template #default="{ row }"></template>
|
|
|
+ <el-table-column label="广告位位置" prop="space">
|
|
|
+ <template #default="{ row }">{{ spaceCfg[row.space]||'' }}</template>
|
|
|
</el-table-column>
|
|
|
- <el-table-column label="图片" prop="xx">
|
|
|
- <template #default="{ row }"></template>
|
|
|
+ <el-table-column label="广告位类型" prop="type">
|
|
|
+ <template #default="{ row }">{{ typeCfg[row.type]||'' }}</template>
|
|
|
</el-table-column>
|
|
|
- <el-table-column label="广告位标题" prop="xx"></el-table-column>
|
|
|
- <el-table-column label="跳转链接" prop="xx"></el-table-column>
|
|
|
- <el-table-column label="点击量" prop="xx"></el-table-column>
|
|
|
+ <el-table-column label="图片" prop="fileUrl">
|
|
|
+ <template #default="{ row }">
|
|
|
+ <img :src="row.fileUrl" v-if="row.fileUrl" style="width: 130px;height: auto;">
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column label="广告位标题" prop="title"></el-table-column>
|
|
|
+ <el-table-column label="跳转链接" prop="redirect"></el-table-column>
|
|
|
+ <!-- <el-table-column label="点击量" prop="xx"></el-table-column> -->
|
|
|
<el-table-column label="创建时间" prop="createDate"></el-table-column>
|
|
|
- <el-table-column label="排序" prop="xx"></el-table-column>
|
|
|
- <el-table-column label="上架状态" prop="xx">
|
|
|
+ <!-- <el-table-column label="排序" prop="xx"></el-table-column> -->
|
|
|
+ <el-table-column label="上架状态" prop="enable">
|
|
|
<template #default="{ row }">
|
|
|
- <el-switch v-model="row.status" active-color="#33A7A7" inactive-color="#B9C0C8" @change="e=>statusChange(e,row)"></el-switch>
|
|
|
+ <el-switch v-model="row.enable" active-color="#33A7A7" inactive-color="#B9C0C8" @change="e=>statusChange(e,row)"></el-switch>
|
|
|
</template>
|
|
|
</el-table-column>
|
|
|
<el-table-column label="操作" width="200">
|
|
|
@@ -48,20 +52,20 @@
|
|
|
</el-row>
|
|
|
<el-dialog width="40%" :visible.sync="show" :title="dialogTitle" @close="cancel">
|
|
|
<el-form ref="advertRef" :model="advertForm" :rules="advertRules" label-width="100px" style="width: 90%;margin: 0 auto;">
|
|
|
- <el-form-item label="广告位位置" prop="aaa">
|
|
|
- <el-select v-model="advertForm.aaa" placeholder="请选择广告位位置" style="width:100%">
|
|
|
- <el-option label="首页" value="1"></el-option>
|
|
|
- <el-option label="发布问卷" value="2"></el-option>
|
|
|
+ <el-form-item label="广告位位置" prop="space">
|
|
|
+ <el-select v-model="advertForm.space" placeholder="请选择广告位位置" style="width:100%">
|
|
|
+ <el-option label="首页" :value="1"></el-option>
|
|
|
+ <el-option label="发布问卷" :value="2"></el-option>
|
|
|
</el-select>
|
|
|
</el-form-item>
|
|
|
- <el-form-item label="广告位类型" prop="bbb">
|
|
|
- <el-select v-model="advertForm.bbb" placeholder="请选择广告位类型" style="width:100%">
|
|
|
- <el-option label="banner区" value="1"></el-option>
|
|
|
- <el-option label="弹框" value="2"></el-option>
|
|
|
+ <el-form-item label="广告位类型" prop="type">
|
|
|
+ <el-select v-model="advertForm.type" placeholder="请选择广告位类型" style="width:100%">
|
|
|
+ <el-option label="banner区" :value="1"></el-option>
|
|
|
+ <el-option label="弹框" :value="2"></el-option>
|
|
|
</el-select>
|
|
|
</el-form-item>
|
|
|
- <el-form-item label="广告位标题" prop="ccc">
|
|
|
- <el-input v-model="advertForm.ccc" placeholder="请输入广告位标题"></el-input>
|
|
|
+ <el-form-item label="广告位标题" prop="title">
|
|
|
+ <el-input v-model="advertForm.title" placeholder="请输入广告位标题"></el-input>
|
|
|
</el-form-item>
|
|
|
<el-form-item label="配图" prop="" class="red">
|
|
|
<el-upload
|
|
|
@@ -71,18 +75,18 @@
|
|
|
:on-success="uploadFileSuccess"
|
|
|
:on-remove="removeFile"
|
|
|
:before-upload="beforeAvatarUpload"
|
|
|
- :limit="5"
|
|
|
+ :limit="1"
|
|
|
:file-list="fileList">
|
|
|
<i class="el-icon-plus"></i>
|
|
|
</el-upload>
|
|
|
<div class="dialog-tip">图片最小分辨率:702*200</div>
|
|
|
</el-form-item>
|
|
|
- <el-form-item label="跳转链接" prop="eee">
|
|
|
- <el-radio-group v-model="advertForm.eee">
|
|
|
+ <el-form-item label="跳转链接" prop="redirectType">
|
|
|
+ <el-radio-group v-model="advertForm.redirectType">
|
|
|
<el-radio :label="1">微信公众号</el-radio>
|
|
|
<el-radio :label="2">微信小程序</el-radio>
|
|
|
</el-radio-group>
|
|
|
- <el-input v-model="advertForm.fff" placeholder="配置跳转链接"></el-input>
|
|
|
+ <el-input v-model="advertForm.redirect" placeholder="配置跳转链接"></el-input>
|
|
|
</el-form-item>
|
|
|
</el-form>
|
|
|
<div class="demo-drawer__footer" style="display: flex;justify-content: end;">
|
|
|
@@ -98,6 +102,13 @@
|
|
|
import Cookies from "js-cookie"
|
|
|
import { ref, getCurrentInstance, onMounted } from 'vue'
|
|
|
const { proxy } = getCurrentInstance();
|
|
|
+ import {
|
|
|
+ getAdvertList,
|
|
|
+ addAdvert,
|
|
|
+ updateAdvert,
|
|
|
+ getAdvertInfo,
|
|
|
+ deleteAdvert
|
|
|
+ } from '@/api/agent/indexTwo.js'
|
|
|
const title = proxy.$route.meta.title;
|
|
|
const uploadUrl = `${window.SITE_CONFIG["apiURL"]}/sys/oss/uploadFile`
|
|
|
const uploadHeaders = {token:Cookies.get("token")};
|
|
|
@@ -106,6 +117,14 @@
|
|
|
page:1,
|
|
|
limit:10
|
|
|
})
|
|
|
+ const spaceCfg = ref({
|
|
|
+ '1': '首页',
|
|
|
+ '2': '发布问卷'
|
|
|
+ })
|
|
|
+ const typeCfg = ref({
|
|
|
+ '1': 'banner区',
|
|
|
+ '2': '弹框'
|
|
|
+ })
|
|
|
const dataList = ref([])
|
|
|
const total = ref(0)
|
|
|
const loading = ref(false)
|
|
|
@@ -114,16 +133,23 @@
|
|
|
const dialogTitle = ref('新增广告位')
|
|
|
const advertRef = ref(null)
|
|
|
const advertForm = ref({
|
|
|
- id:''
|
|
|
+ id:'',
|
|
|
+ space:'',
|
|
|
+ type:'',
|
|
|
+ title:'',
|
|
|
+ redirectType:1,
|
|
|
+ redirect:'',
|
|
|
+ fileUrl:'',
|
|
|
+ enable:1
|
|
|
})
|
|
|
const advertRules = ref({
|
|
|
- aaa: [
|
|
|
+ space: [
|
|
|
{ required: true, message: '请选择广告位位置', trigger: 'change' }
|
|
|
],
|
|
|
- bbb: [
|
|
|
+ type: [
|
|
|
{ required: true, message: '请选择广告位类型', trigger: 'change' }
|
|
|
],
|
|
|
- ccc: [
|
|
|
+ title: [
|
|
|
{ required: true, message: '请输入广告位标题', trigger: 'blur' }
|
|
|
]
|
|
|
})
|
|
|
@@ -131,9 +157,12 @@
|
|
|
const getList = async () => {
|
|
|
let query = {...queryParams.value};
|
|
|
loading.value = true;
|
|
|
- // const res = await getCoachList(query);
|
|
|
- // dataList.value = res.data.list;
|
|
|
- // total.value = res.data.total;
|
|
|
+ const res = await getAdvertList(query);
|
|
|
+ dataList.value = res.data.list;
|
|
|
+ dataList.value.forEach(item=>{
|
|
|
+ item.enable = item.enable==1?true:false;
|
|
|
+ })
|
|
|
+ total.value = res.data.total;
|
|
|
loading.value = false;
|
|
|
}
|
|
|
const handleSizeChange = (e)=>{
|
|
|
@@ -148,6 +177,13 @@
|
|
|
const reset = () => {
|
|
|
advertForm.value = {
|
|
|
id:'',
|
|
|
+ space:'',
|
|
|
+ type:'',
|
|
|
+ title:'',
|
|
|
+ redirectType:1,
|
|
|
+ redirect:'',
|
|
|
+ fileUrl:'',
|
|
|
+ enable:1
|
|
|
};
|
|
|
proxy.resetForm("advertRef");
|
|
|
}
|
|
|
@@ -158,11 +194,12 @@
|
|
|
}
|
|
|
const handleEdit = (row) => {
|
|
|
reset();
|
|
|
- // getCoachInfo(row.id).then(response => {
|
|
|
+ getAdvertInfo(row.id).then(response => {
|
|
|
advertForm.value = response.data;
|
|
|
+ fileList.value = [{name:'',url:advertForm.value.fileUrl}];
|
|
|
dialogTitle.value = "编辑广告位";
|
|
|
show.value = true;
|
|
|
- // });
|
|
|
+ });
|
|
|
}
|
|
|
|
|
|
const submitForm = () => {
|
|
|
@@ -170,21 +207,22 @@
|
|
|
if (valid) {
|
|
|
buttonLoading.value = true;
|
|
|
if(fileList.value.length===0) return proxy.$message.error('请上传图片');
|
|
|
- // if(advertForm.value.id){
|
|
|
- // updateCoach(advertForm.value).then((res)=>{
|
|
|
- // if(res.code!==0) return proxy.$message.error(res.msg);
|
|
|
- // buttonLoading.value = false;
|
|
|
- // userShow.value = false;
|
|
|
- // getList();
|
|
|
- // })
|
|
|
- // }else{
|
|
|
- // addCoach(advertForm.value).then((res)=>{
|
|
|
- // if(res.code!==0) return proxy.$message.error(res.msg);
|
|
|
- // buttonLoading.value = false;
|
|
|
- // userShow.value = false;
|
|
|
- // getList();
|
|
|
- // })
|
|
|
- // }
|
|
|
+ advertForm.value.fileUrl = fileList.value[0].url;
|
|
|
+ if(advertForm.value.id){
|
|
|
+ updateAdvert(advertForm.value).then((res)=>{
|
|
|
+ if(res.code!==0) return proxy.$message.error(res.msg);
|
|
|
+ buttonLoading.value = false;
|
|
|
+ show.value = false;
|
|
|
+ getList();
|
|
|
+ })
|
|
|
+ }else{
|
|
|
+ addAdvert(advertForm.value).then((res)=>{
|
|
|
+ if(res.code!==0) return proxy.$message.error(res.msg);
|
|
|
+ buttonLoading.value = false;
|
|
|
+ show.value = false;
|
|
|
+ getList();
|
|
|
+ })
|
|
|
+ }
|
|
|
} else {
|
|
|
return false;
|
|
|
}
|
|
|
@@ -195,11 +233,20 @@
|
|
|
reset();
|
|
|
}
|
|
|
async function handleDelete(row) {
|
|
|
- // await proxy?.$modal.confirm('确认删除教练【' + row.realName + '】吗?').finally(() => loading.value = false);
|
|
|
- // let res = await deleteCoach([row.id]);
|
|
|
- // if (res.code === 0) proxy?.$modal.msgSuccess("删除成功");
|
|
|
- // else return proxy?.$modal.msgError(res.msg);
|
|
|
- // await getList();
|
|
|
+ await proxy?.$modal.confirm('确认删除该广告位吗?').finally(() => loading.value = false);
|
|
|
+ let res = await deleteAdvert([row.id]);
|
|
|
+ if (res.code === 0) proxy?.$modal.msgSuccess("删除成功");
|
|
|
+ else return proxy?.$modal.msgError(res.msg);
|
|
|
+ await getList();
|
|
|
+ }
|
|
|
+
|
|
|
+ function statusChange(e,row) {
|
|
|
+ let data = JSON.parse(JSON.stringify(row));
|
|
|
+ data.enable = data.enable?1:0;
|
|
|
+ updateAdvert(data).then((res)=>{
|
|
|
+ if(res.code!==0) return proxy.$message.error(res.msg);
|
|
|
+ getList();
|
|
|
+ })
|
|
|
}
|
|
|
|
|
|
const uploadFileSuccess = e =>{
|
|
|
@@ -208,9 +255,8 @@
|
|
|
}
|
|
|
}
|
|
|
const removeFile = (e) => {
|
|
|
- let url = e[0]?.url||'';
|
|
|
- let idx = fileList.value.find(f=>f.url==url);
|
|
|
- if(idx>-1) fileList.value.splice(idx,1)
|
|
|
+ fileList.value = []
|
|
|
+ advertForm.value.fileUrl = '';
|
|
|
}
|
|
|
const beforeAvatarUpload = (file) => {
|
|
|
// if (!['image/jpeg', 'image/png', 'image/jpg'].includes(file.type)) {
|