Bläddra i källkod

内容管理 Banner管理

DESKTOP-O04BTUJ\muzen 3 år sedan
förälder
incheckning
864c41d0ef
2 ändrade filer med 203 tillägg och 47 borttagningar
  1. 73 20
      src/views/content/banner/detail.vue
  2. 130 27
      src/views/content/banner/index.vue

+ 73 - 20
src/views/content/banner/detail.vue

@@ -1,57 +1,110 @@
 <template>
   <div class="app-container">
-    <el-form label-width="110px">
+    <el-form :model="form" label-width="110px">
       <el-form-item label="Banner位置:">
-        <el-select placeholder="请选择Banner位置">
-          <el-option />
+        <el-select v-model="form.type" placeholder="请选择Banner位置">
+          <el-option v-for="item in dict.type.show_the_location" :key="item.value" :label="item.label"
+            :value="Number(item.value)" />
         </el-select>
       </el-form-item>
       <el-form-item label="Banner名称:">
-        <el-input placeholder="请输入Banner名称" />
+        <el-input v-model="form.name" placeholder="请输入Banner名称" />
       </el-form-item>
       <el-form-item label="展示顺序:">
-        <el-select placeholder="请选择展示顺序">
-          <el-option />
-        </el-select>
+        <el-input-number v-model="form.sort" :min="1" />
       </el-form-item>
       <el-form-item label="跳转地址:">
-        <el-radio-group>
-          <el-radio :label="1">内部</el-radio>
-          <el-radio :label="2">外部</el-radio>
+        <el-radio-group v-model="form.forwardType">
+          <el-radio :label="0">内部</el-radio>
+          <el-radio :label="1">外部</el-radio>
         </el-radio-group>
-        <el-select placeholder="请选择跳转位置" style="margin: 15px 0 20px 0">
-          <el-option></el-option>
+        <el-select v-model="form.forwardLocation" v-if="form.forwardType === 0" placeholder="请选择跳转位置"
+          style="margin: 15px 0 20px 0">
+          <el-option v-for="item in dict.type.nav_address_url" :key="item.value" :label="item.label"
+            :value="Number(item.value)" />
         </el-select>
-        <el-input placeholder="请输入跳转链接地址"></el-input>
+        <el-input v-model="form.forwardUrl" placeholder="请输入跳转链接地址"></el-input>
       </el-form-item>
       <el-form-item label="时间:">
-        <el-date-picker type="datetimerange" start-placeholder="开始时间" end-placeholder="结束时间" />
+        <el-date-picker v-model="date" type="datetimerange" start-placeholder="开始时间" end-placeholder="结束时间"
+          value-format="yyyy-MM-dd HH:mm:ss" />
       </el-form-item>
       <el-form-item label="图片上传:">
-        <Upload listType="picture-card" />
+        <Upload listType="picture-card" :url="form.pic" @upload="getUpload" />
       </el-form-item>
     </el-form>
     <div class="form-btn">
       <el-button @click="cancel">取消</el-button>
-      <el-button type="primary">提交</el-button>
+      <el-button type="primary" @click="getSubmit">提交</el-button>
     </div>
   </div>
 </template>
 
 <script>
 import Upload from '@/components/Upload/index'
+import { submit, detail, edit } from '@/api/content/banner'
 export default {
-  components:{
+  dicts: ['nav_address_url', 'show_the_location'],
+  components: {
     Upload
   },
   data() {
     return {
-
+      date: '',
+      form: {
+        sort: 1,
+        forwardType: 0
+      }
+    }
+  },
+  watch: {
+    date(val) {
+      this.form.startTime = val[0]
+      this.form.endTime = val[1]
+    }
+  },
+  mounted() {
+    if (this.$route.query.id) {
+      this.getList()
     }
   },
   methods: {
-    cancel(){
+    // 详情
+    getList() {
+      detail({
+        id: this.$route.query.id
+      }).then(res => {
+        if (res.code === 0) {
+          this.form = res.data
+          this.date = [res.data.startTime, res.data.endTime]
+        }
+      })
+    },
+    // 上传
+    getUpload(e) {
+      this.form.pic = e.file
+    },
+    // 取消
+    cancel() {
       this.$tab.closeOpenPage("/content/banner");
+    },
+    // 提交
+    getSubmit() {
+      if (this.$route.query.id) {
+        edit(this.form).then(res => {
+          if (res.code === 0) {
+            this.$message.success('修改成功!')
+            this.cancel()
+          }
+        })
+      } else {
+        submit(this.form).then(res => {
+          if (res.code === 0) {
+            this.$message.success('新增成功!')
+            this.cancel()
+          }
+        })
+      }
     }
   }
 }
@@ -61,7 +114,7 @@ export default {
 .el-form {
   width: 500px;
 }
-.form-btn{
+.form-btn {
   margin-left: 110px;
 }
 </style>

+ 130 - 27
src/views/content/banner/index.vue

@@ -3,63 +3,166 @@
     <!-- 搜索 -->
     <el-form inline label-width="110px" size="mini">
       <el-form-item label="Banner名称:">
-        <el-input placeholder="请输入名称" />
+        <el-input v-model="form.name" placeholder="请输入名称" />
       </el-form-item>
       <el-form-item label="展示位置:">
-        <el-select placeholder="请选择展示位置">
-          <el-option></el-option>
+        <el-select v-model="form.type" placeholder="请选择展示位置">
+          <el-option v-for="item in dict.type.show_the_location" :key="item.value" :label="item.label"
+            :value="item.value" />
         </el-select>
       </el-form-item>
       <el-form-item label="当前状态:">
-        <el-select placeholder="请选择当前状态">
-          <el-option></el-option>
+        <el-select v-model="form.status" placeholder="请选择当前状态">
+          <el-option v-for="item in dict.type.on_off_out" :key="item.value" :label="item.label"
+            :value="item.value" />
         </el-select>
       </el-form-item>
       <el-form-item label="上/下架:">
-        <el-select placeholder="请选择上/下架状态">
-          <el-option></el-option>
+        <el-select v-model="form.shelfStatus" placeholder="请选择上/下架状态">
+          <el-option v-for="item in dict.type.top_bottom_shelves" :key="item.value" :label="item.label"
+            :value="item.value" />
         </el-select>
       </el-form-item>
       <el-form-item>
-        <el-button type="primary" icon="el-icon-search">搜索</el-button>
-        <el-button icon="el-icon-refresh">重置</el-button>
-        <el-button type="primary" icon="el-icon-plus" plain @click="getDetail()">新增</el-button>
+        <el-button type="primary" icon="el-icon-search" @click="getSearch">搜索</el-button>
+        <el-button icon="el-icon-refresh" @click="getRefresh">重置</el-button>
+        <el-button type="primary" icon="el-icon-plus" plain @click="getDetail">新增</el-button>
       </el-form-item>
     </el-form>
     <!-- 列表 -->
-    <el-table>
-      <el-table-column label="Banner名称" align="center"></el-table-column>
-      <el-table-column label="Banner位置" align="center"></el-table-column>
-      <el-table-column label="轮播顺序" align="center"></el-table-column>
-      <el-table-column label="图片" align="center"></el-table-column>
-      <el-table-column label="当前状态" align="center"></el-table-column>
-      <el-table-column label="上/下架" align="center"></el-table-column>
-      <el-table-column label="开始时间" align="center"></el-table-column>
-      <el-table-column label="结束时间" align="center"></el-table-column>
+    <el-table :data="tableData" v-loading="loading">
+      <el-table-column label="Banner名称" prop="name" align="center" />
+      <el-table-column label="Banner位置" prop="type" align="center" :formatter="typeFormatter" />
+      <el-table-column label="轮播顺序" prop="sort" align="center" />
+      <el-table-column label="图片" align="center" width="100px">
+        <template slot-scope="scope">
+          <el-image :src="scope.row.pic" />
+        </template>
+      </el-table-column>
+      <el-table-column label="当前状态" prop="currentStatus" align="center" :formatter="currentFormatter" />
+      <el-table-column label="上/下架" prop="status" align="center" :formatter="statusFormatter" />
+      <el-table-column label="开始时间" prop="startTime" align="center" />
+      <el-table-column label="结束时间" prop="endTime" align="center" />
       <el-table-column label="操作" align="center">
-        <template>
-          <el-button type="text">编辑</el-button>
-          <el-button type="text">下架</el-button>
-          <el-button type="text">上架</el-button>
-          <el-button type="delete">删除</el-button>
+        <template slot-scope="scope">
+          <el-button v-if="scope.row.status === 1" type="text" @click="getChange(scope.row, 0)">下架</el-button>
+          <div v-else>
+            <el-button type="text" @click="getDetail(scope.row)">编辑</el-button>
+            <el-button type="text" @click="getChange(scope.row, 1)">上架</el-button>
+            <el-button v-if="scope.row.status === 0" type="delete" @click="getDelete(scope.row)">删除
+            </el-button>
+          </div>
         </template>
       </el-table-column>
     </el-table>
+    <pagination v-show="total>0" :total="total" :page.sync="form.pageNum" :limit.sync="form.pageSize"
+      @pagination="getList" />
   </div>
 </template>
 
 <script>
+import { page, changeStatus, remove } from '@/api/content/banner'
 export default {
+  dicts: ['on_off_out', 'top_bottom_shelves', 'show_the_location'],
   data() {
     return {
-
+      // 遮罩层
+      loading: false,
+      // 表单
+      form: {
+        pageNum: 1,
+        pageSize: 10
+      },
+      total: 0,
+      // 列表
+      tableData: []
     }
   },
+  mounted() {
+    this.getList()
+  },
   methods: {
-    getDetail(){
+    // 搜索
+    getSearch() {
+      this.form.pageNum = 1
+      this.form.pageSize = 10
+      this.getList()
+    },
+
+    // 重置
+    getRefresh() {
+      this.form = {
+        pageNum: 1,
+        pageSize: 10
+      }
+      this.getList()
+    },
+
+    // 分页
+    getList() {
+      this.loading = true
+      page(this.form).then(res => {
+        if (res.code === 0) {
+          this.tableData = res.data.records
+          this.total = res.data.total
+          this.loading = false
+        }
+      })
+    },
+
+    // 上下架
+    getChange(row, status) {
+      let tips = status === 0 ? '下架' : '上架'
+      changeStatus({
+        id: row.id,
+        status: status
+      }).then(res => {
+        if (res.code === 0) {
+          this.$message.success(`${tips}成功!`)
+          this.getList()
+        }
+      })
+    },
+
+    // 删除
+    getDelete(row) {
+      this.$confirm(`是否删除${row.name}`, '提示', {
+        confirmButtonText: '确认',
+        cancelButtonText: '取消',
+        type: 'warning'
+      }).then(() => {
+        remove({
+          id: row.id
+        }).then(res => {
+          if (res.code === 0) {
+            this.$message.success('删除成功!')
+            this.getList()
+          }
+        })
+      }).catch(() => {
+        this.$message.info('取消删除!')
+      })
+    },
+
+    // 新增 编辑
+    getDetail(row) {
       this.$router.push({
-        path: '/content/banner/detail'
+        path: '/content/banner/detail',
+        query: {
+          id: row.id
+        }
       })
+    },
+
+    // 字典翻译
+    statusFormatter(row) {
+      return this.selectDictLabel(this.dict.type.top_bottom_shelves, row.status)
+    },
+    typeFormatter(row) {
+      return this.selectDictLabel(this.dict.type.show_the_location, row.type)
+    },
+    currentFormatter(row) {
+      return this.selectDictLabel(this.dict.type.on_off_out, row.currentStatus)
     }
   }
 }