Ver código fonte

运营管理 启动页

DESKTOP-O04BTUJ\muzen 3 anos atrás
pai
commit
33a0fb3315

+ 106 - 18
src/views/operation/startPage/detail.vue

@@ -2,56 +2,144 @@
   <div class="app-container">
     <el-form label-width="100px">
       <el-form-item label="启动页名称:">
-        <el-input placeholder="请输入启动页名称" />
+        <el-input v-model="form.name" placeholder="请输入启动页名称" />
       </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" @change="getchecked" />
       </el-form-item>
-      <el-form-item label="持续时间:">
-        <el-select placeholder="请选择持续时间">
-          <el-option />
+      <el-form-item label="跳转方式:">
+        <el-select v-model="form.forwardType" placeholder="请选择跳转方式">
+          <el-option v-for="item in dict.type.nav_address_type" :key="item.value" :label="item.label"
+            :value="Number(item.value)" />
         </el-select>
       </el-form-item>
-      <el-form-item label="跳转方式:">
-        <el-select placeholder="请选择跳转方式">
-          <el-option />
+      <el-form-item label="持续时间:">
+        <el-select v-model="form.time" placeholder="请选择持续时间">
+          <el-option v-for="item in dict.type.time_of_duration" :key="item.value" :label="item.label"
+            :value="Number(item.value)" />
         </el-select>
       </el-form-item>
       <el-form-item label="能否跳过:">
-        <el-select placeholder="请选择能否跳过">
-          <el-option />
+        <el-select v-model="form.isStep" placeholder="请选择能否跳过" :disabled="disabled">
+          <el-option v-for="item in dict.type.yes_no_pass" :key="item.value" :label="item.label"
+            :value="Number(item.value)" />
         </el-select>
       </el-form-item>
       <el-form-item label="跳转地址:">
-        <el-input placeholder="请输入跳转地址" />
+        <el-input v-model="form.forwardUrl" placeholder="请输入跳转地址" />
       </el-form-item>
       <el-form-item label="启动页图片:">
-        <Upload listType="picture-card" measure="375*812" />
+        <Upload listType="picture-card" measure="375*812" :url="form.pic" @upload="getUpload" />
       </el-form-item>
     </el-form>
     <div class="form-btn">
-      <el-button>取消</el-button>
-      <el-button type="primary">提交</el-button>
+      <el-button @click="cancel">取消</el-button>
+      <el-button type="primary" @click="getSubmit">提交</el-button>
     </div>
   </div>
 </template>
 
 <script>
 import Upload from '@/components/Upload/index'
+import { submit, detail, edit, checked } from '@/api/operation/startPage'
 export default {
-  components:{
+  dicts: ['time_of_duration', 'nav_address_type', 'yes_no_pass'],
+  components: {
     Upload
   },
   data() {
     return {
-
+      // 表单
+      form: {},
+      date: [],
+      // 是否禁用
+      disabled: false,
+    }
+  },
+  watch: {
+    'form.time'(val) {
+      if (val === 0) {
+        this.form.isStep = 0
+        this.disabled = true
+      } else {
+        delete this.form.isStep
+        this.disabled = false
+      }
     }
-  }
+  },
+  mounted() {
+    if (this.$route.query.id) {
+      this.getList()
+    }
+  },
+  methods: {
+    // 详情
+    getList() {
+      detail({
+        id: this.$route.query.id
+      }).then(res => {
+        if (res.code === 0) {
+          this.form = res.data
+          this.form.id = this.$route.query.id
+          this.date = [res.data.startTime, res.data.endTime]
+        }
+      })
+    },
+
+    // 新增
+    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()
+          }
+        })
+      }
+    },
+
+    // 判断生效日期
+    getchecked(e) {
+      this.date = []
+      checked({
+        startTime: e[0],
+        endTime: e[1]
+      }).then(res => {
+        if (res.code === 0) {
+          if (res.data) {
+            this.date = e
+            this.form.startTime = e[0]
+            this.form.endTime = e[1]
+          } else {
+            this.$message.error('该日期范围存在启动页')
+          }
+        }
+      })
+    },
+
+    // 上传
+    getUpload(e) {
+      this.form.pic = e.file
+    },
+
+    // 取消
+    cancel() {
+      this.$tab.closeOpenPage("/operation/startPage");
+    },
+  },
 }
 </script>
 
 <style lang="scss" scoped>
-.el-form{
+.el-form {
   width: 500px;
 }
 </style>

+ 98 - 16
src/views/operation/startPage/index.vue

@@ -3,54 +3,136 @@
     <!-- 搜索 -->
     <el-form inline label-width="100px" size="mini">
       <el-form-item label="当前状态:">
-        <el-select placeholder="请选择当前状态">
-          <el-option />
+        <el-select v-model="form.status" placeholder="请选择当前状态" clearable>
+          <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-select v-model="form.forwardType" placeholder="请选择跳转页面" clearable>
+          <el-option v-for="item in dict.type.nav_address_type" :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-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 :data="tableData">
-      <el-table-column label="启动页名称" align="center" />
-      <el-table-column label="启动页图片" align="center"></el-table-column>
-      <el-table-column label="生效期" align="center" />
-      <el-table-column label="跳转" align="center" />
-      <el-table-column label="当前状态" align="center" />
+      <el-table-column label="启动页名称" prop="name" align="center" />
+      <el-table-column label="启动页图片" align="center">
+        <template slot-scope="scope">
+          <el-image :src="scope.row.pic" :previewSrcList="[scope.row.pic]" style="width: 50px" />
+        </template>
+      </el-table-column>
+      <el-table-column label="生效期" align="center">
+        <template slot-scope="scope">
+          <span>{{ scope.row.startTime}} - {{ scope.row.endTime }}</span>
+        </template>
+      </el-table-column>
+      <el-table-column label="跳转" prop="forwardType" align="center" :formatter="forwardFomatter" />
+      <el-table-column label="当前状态" prop="currentStatus" align="center" :formatter="currentFormatter" />
       <el-table-column label="操作" align="center">
         <template slot-scope="scope">
           <el-button type="text" @click="getDetail(scope.row)">编辑</el-button>
+          <el-button type="delete" @click="getDelete(scope.row)">删除</el-button>
         </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, remove } from '@/api/operation/startPage'
 export default {
+  dicts: ['nav_address_type', 'on_off_out'],
   data() {
     return {
-      tableData:[{
-        id:1
-      }]
+      // 遮罩层
+      loading: false,
+      // 表单
+      form: {
+        pageNum: 1,
+        pageSize: 10
+      },
+      // 列表
+      tableData: [],
+      total: 0,
     }
   },
-  methods:{
-    getDetail(row){
+  mounted() {
+    this.getList()
+  },
+  methods: {
+    // 搜索
+    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
+        }
+      })
+    },
+
+    // 新增 编辑
+    getDetail(row) {
       this.$router.push({
         path: '/operation/startPage/detail',
         query: {
           id: row.id
         }
       })
+    },
+
+    // 删除
+    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('取消删除!')
+      })
+    },
+
+    // 字典翻译
+    forwardFomatter(row) {
+      return this.selectDictLabel(this.dict.type.nav_address_type, row.forwardType)
+    },
+    currentFormatter(row) {
+      return this.selectDictLabel(this.dict.type.on_off_out, row.currentStatus)
     }
   }
 }