index.vue 6.99 KB
<template>
  <div class="payreturnPage">
    <!-- 搜索 -->
    <div class="formSearch">
      <!-- 搜索条件 -->
      <el-form :inline="true" :model="query" class="demo-form-inline">
        <el-form-item label="活动名称">
          <el-input v-model="query.politeName" placeholder="请输入活动名称" />
        </el-form-item>
        <el-form-item label="活动状态">
          <el-select v-model="query.state" placeholder="请选择活动状态">
            <el-option
              v-for="item in activityStatusSelect"
              :key="item.index"
              :label="item.label"
              :value="item.value"
            />
          </el-select>
        </el-form-item>
        <el-form-item>
          <el-button type="primary" plain @click="search">查询</el-button>
          <el-button plain @click="clear">重置</el-button>
          <el-button type="primary" plain @click="addActivity">新建活动</el-button>
        </el-form-item>
      </el-form>
    </div>
    <!-- 表格 -->
    <div class="tableBox">
      <el-table
        ref="multipleTable"
        :data="tableData"
        border
        :header-cell-style="{ background: '#EEF3FF', color: '#333333' }"
        tooltip-effect="dark"
        style="width: 100%"
      >
        <el-table-column prop="politeName" label="活动名称" align="center" width="220" />
        <el-table-column prop="time" label="起止时间" align="center" />
        <el-table-column prop="remark" label="备注" align="center" />
        <el-table-column label="活动状态" align="center">
          <template slot-scope="scope">
            <span v-if="scope.row.state == 0">未开始</span>
            <span v-if="scope.row.state == 1">进行中</span>
            <span v-if="scope.row.state == 2">已结束</span>
            <!-- <span v-if="scope.row.state == 2">待开始</span>
            <span v-if="scope.row.state == 3">进行中</span>
            <span v-if="scope.row.state == 4">已结束</span> -->
          </template>
        </el-table-column>
        <!-- <el-table-column prop="discountMode" label="营销方式">
          <template slot-scope="scope">
            <span v-if="scope.row.discountMode == 1">满减</span>
            <span v-if="scope.row.discountMode == 2">优惠券</span>
          </template>
        </el-table-column> -->
        <el-table-column label="操作" align="center" show-overflow-tooltip>
          <template slot-scope="scope">
            <div class="btnList">
              <el-button type="text" @click="details(scope.row)">详情</el-button>
              <el-button v-if="scope.row.state != 2" type="text" @click="editActivity(scope.row)">编辑</el-button>
              <el-button v-if="scope.row.state != 2" type="text" @click="endActivity(scope.row)">结束</el-button>
              <el-button v-if="scope.row.state == 2" type="text" @click="delActivity(scope.row)">删除</el-button>
            </div>
          </template>
        </el-table-column>
      </el-table>
      <div class="fenye">
        <el-pagination
          :current-page="query.page"
          :page-sizes="[10, 20, 50, 100]"
          :page-size="10"
          layout="total, sizes, prev, pager, next, jumper"
          :total="total"
          @size-change="handleSizeChange"
          @current-change="handleCurrentChange"
        />
      </div>
    </div>

    <el-dialog
      :title="editForm ? '修改优惠券活动' : '新增优惠券活动'"
      :visible.sync="activityVisible"
      width="50%"
      center
      :close-on-click-modal="false"
      @close="closeModal"
    >
      <AddActive
        ref="childCon"
        :activity-form="activityForm"
        :is-edit="editForm"
        @cancel="activityVisible = false"
        @refersh="refersh('activityVisible')"
      />
    </el-dialog>
    <el-dialog
      :title="'支付有礼活动详情'"
      :visible.sync="activityDetailVisible"
      width="74%"
      center
      :close-on-click-modal="false"
      @close="cleanForm('activityDetailVisible')"
    >
      <ActivityDetail ref="activityDetail" :activity-id="activityForm.politeId" />
    </el-dialog>
  </div>
</template>

<script>
import AddActive from '@/views/active/politelist/politeAdd.vue'
import ActivityDetail from '@/views/active/politelist/politeDetail.vue'

import {
  getPoliteData,
  endPoliteActivity,
  delPoliteActivity
} from '@/api/active/active_polite.js'
export default {
  components: {
    AddActive,
    ActivityDetail
  },
  data () {
    return {
      query: {
        politeName: '', // 活动名称
        // 活动状态 0-报名未开始 1-报名进行中 2-活动待开始 3-活动进行中 4-活动已结束
        state: '',
        page: 1,
        pageSize: 10
      },
      total: 1,
      tableData: [],
      activityStatusSelect: [
        {
          index: 0,
          label: '未开始',
          value: 0
        },
        {
          index: 1,
          label: '进行中',
          value: 1
        },
        {
          index: 2,
          label: '已结束',
          value: 2
        }
      ],
      activityVisible: false,
      editForm: 0,
      activityDetailVisible: false,
      activityForm: {}
    }
  },
  created () {
    this.getAll()
  },
  methods: {
    async getAll () {
      const res = await getPoliteData(this.query)
      this.tableData = res.data.list
      this.total = res.data.total
    },
    handleSizeChange (val) {
      this.query.pageSize = val
      this.getAll()
    },
    handleCurrentChange (val) {
      this.query.page = val
      this.getAll()
    },
    search () {
      this.total = 1
      this.query.page = 1
      this.getAll()
    },
    clear () {
      this.query = {
        politeName: '', // 活动名称
        // 活动状态 0-报名未开始 1-报名进行中 2-活动待开始 3-活动进行中 4-活动已结束
        state: '',
        page: 1,
        pageSize: 10
      }
    },
    details (row) {
      this.activityForm = row
      this.activityDetailVisible = true
    },
    // 添加活动
    addActivity () {
      this.editForm = 0
      this.activityVisible = true
    },
    editActivity (row) {
      this.editForm = 1
      this.activityForm = row
      this.activityVisible = true
    },
    // 停止
    async endActivity (row) {
      const res = await endPoliteActivity({ politeId: row.politeId })
      if (res.code === '') {
        this.$message({
          message: '结束成功',
          type: 'success'
        })
        this.getAll()
      }
    },
    // 删除
    async delActivity (row) {
      const res = await delPoliteActivity({ politeId: row.politeId })
      if (res.code === '') {
        this.$message({
          message: '删除成功',
          type: 'success'
        })
        this.getAll()
      }
    },
    cleanForm (attr) {
      attr = false
    },
    refersh (attr) {
      this[attr] = false
      this.getAll()
    },
    closeModal () {
      this.$refs.childCon.reset()
    }
  }
}
</script>

<style lang="scss" scoped>
.payreturnPage{
  padding: 30px;
  .tableBox{
    .fenye{
      margin: 20px;
    }
  }
}
</style>