Przeglądaj źródła

广告位管理接口联调完成

htc 1 dzień temu
rodzic
commit
d38ef6006f
2 zmienionych plików z 142 dodań i 58 usunięć
  1. 39 1
      src/api/agent/indexTwo.js
  2. 103 57
      src/views/modules/advertising.vue

+ 39 - 1
src/api/agent/indexTwo.js

@@ -118,4 +118,42 @@ export function getBillAmountList() {
   })
 }
 // ------end 账单明细
-// ---end 商业模式管理
+// ---end 商业模式管理
+
+// ---start 广告位管理
+export function getAdvertList(query) {
+  return request({
+    url: `/core/advertisement/manage/page`,
+    method: 'get',
+    params: query
+  })
+}
+
+export function addAdvert(data) {
+  return request({
+    url: '/core/advertisement/manage',
+    method: 'post',
+    data
+  })
+}
+export function updateAdvert(data) {
+  return request({
+    url: '/core/advertisement/manage',
+    method: 'put',
+    data
+  })
+}
+export function getAdvertInfo(id) {
+  return request({
+    url: `/core/advertisement/manage/${id}`,
+    method: 'get'
+  })
+}
+export function deleteAdvert(data) {
+  return request({
+    url: `/core/advertisement/manage`,
+    method: 'delete',
+    data
+  })
+}
+// ---end 广告位管理

+ 103 - 57
src/views/modules/advertising.vue

@@ -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)) {