index.vue 5.88 KB
Newer Older
1 2 3
<template>
  <div class="app-container">
    <el-row class="mb8">
4 5
      <el-button type="success" size="mini" icon="el-icon-plus" @click="handleNewScoreRule">{{ $t("添加规则") }}</el-button>
      <el-button type="success" size="mini" icon="el-icon-delete" @click="handleDelScoreRule">{{ $t("删除规则") }}</el-button>
6
    </el-row>
7
    <el-table ref="multipleTable" v-loading="loading" @selection-change="handleSelectionChange" :data="memberLevelList">
8
      <el-table-column type="selection" width="55"></el-table-column>
9 10
      <el-table-column width="140" :label="$t('序号')" align="center" prop="id"></el-table-column>
      <el-table-column :label="$t('等级名称')" align="center" prop="name"></el-table-column>
11

12
      <el-table-column width="140" :label="$t('图标')" align="center" prop="mobile">
13
        <template slot-scope="scope">
14
          <el-image :src="scope.row.icon" style="width: 50px; height: 50px">{{ $t("") }}</el-image>
15 16 17 18
        </template>
      </el-table-column>

      <el-table-column :label="$t('积分范围')" align="center">
19
        <template slot-scope="scope"> {{ scope.row.lowerCount }}-{{ scope.row.upperCount }} </template>
20 21 22
      </el-table-column>
      <el-table-column :label="$t('操作')" align="center">
        <template slot-scope="scope">
23 24
          <el-button size="mini" type="text" icon="el-icon-edit" @click="handleUpdate(scope.row)">{{ $t("修改") }}</el-button>
          <el-button size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)">{{ $t("删除") }}</el-button>
25 26 27 28
        </template>
      </el-table-column>
    </el-table>
    <!-- //分页列表 -->
29
    <pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNo" :limit.sync="queryParams.pageSize" @pagination="handleQueryPagination" />
30

31 32
    <el-dialog :title="$t('添加规则')" :visible.sync="dialogVisible" width="30%" :before-close="handleClose">
      <el-form :model="ruleForm" ref="ruleForm" label-width="100px" class="demo-ruleForm">
33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49
        <el-form-item :label="$t('等级名称')">
          <el-input v-model="ruleForm.name"></el-input>
        </el-form-item>
        <el-form-item :label="$t('积分范围')">
          <el-col :span="11">
            <el-form-item>
              <el-input v-model="ruleForm.lowerCount"></el-input>
            </el-form-item>
          </el-col>
          <el-col class="line" :span="2">{{ $t("至") }}</el-col>
          <el-col :span="11">
            <el-form-item>
              <el-input v-model="ruleForm.upperCount"></el-input>
            </el-form-item>
          </el-col>
        </el-form-item>
        <el-form-item :label="$t('上传图标')">
50
          <image-upload v-model="ruleForm.icon" :fileType="['png', 'jpg', 'jpeg']" :limit="1" />
51 52 53 54
        </el-form-item>
      </el-form>
      <span slot="footer" class="dialog-footer">
        <el-button @click="dialogVisible = false">{{ $t("取 消") }}</el-button>
55
        <el-button type="primary" @click="handelAddNewMemberLevel">{{ $t("确定") }}</el-button>
56 57 58 59 60
      </span>
    </el-dialog>
  </div>
</template>
<script>
61 62 63
import { getDictDatas, DICT_TYPE } from "@/utils/dict"
import { getMemberLevelList, addNewMemberLevel, delMemberLevel, editMemberLevel } from "@/api/ecw/memberManagement"
import ImageUpload from "@/components/ImageUpload"
64 65 66
export default {
  name: "integralRecord",
  components: {
67
    ImageUpload
68 69 70 71 72 73 74 75 76
  },
  data() {
    return {
      dialogVisible: false,
      selectList: [],
      ruleForm: {
        icon: "",
        lowerCount: "",
        name: "",
77
        upperCount: ""
78 79 80 81 82 83
      },
      total: 0,
      loading: true,
      memberLevelList: [],
      queryParams: {
        pageNo: 1,
84 85 86
        pageSize: 10
      }
    }
87 88 89
  },
  computed: {
    isChinese() {
90 91
      return this.$i18n.locale === "zh_CN"
    }
92 93
  },
  created() {
94
    this.handleQuery()
95 96
  },
  activated() {
97
    this.handleQuery()
98 99 100
  },
  methods: {
    handleUpdate(row) {
101 102
      this.ruleForm = { ...row }
      this.dialogVisible = true
103 104
    },
    handleDelete(row) {
105
      let ids = [row.id]
106
      delMemberLevel(ids).then((res) => {
107 108 109 110
        this.$message.success(this.$t("删除成功"))
        this.handleClose()
        this.handleQuery()
      })
111 112 113 114
    },
    handelAddNewMemberLevel() {
      if (this.ruleForm.id) {
        editMemberLevel(this.ruleForm).then((res) => {
115 116 117 118
          this.$message.success(this.$t("更新成功"))
          this.handleClose()
          this.handleQuery()
        })
119
      } else {
120
        let params = { ...this.ruleForm }
121
        addNewMemberLevel(params).then((res) => {
122 123 124 125
          this.$message.success(this.$t("保存成功"))
          this.handleClose()
          this.handleQuery()
        })
126 127 128
      }
    },
    handleSelectionChange(ids) {
129
      this.selectList = ids
130 131
    },
    handleClose() {
132 133
      this.dialogVisible = false
      this.selectList = []
134 135 136 137
      this.ruleForm = {
        icon: "",
        lowerCount: "",
        name: "",
138 139
        upperCount: ""
      }
140 141 142 143
    },
    handleDelScoreRule() {
      if (this.selectList.length > 0) {
        let ids = this.selectList.map((item) => {
144 145
          return item.id
        })
146
        delMemberLevel(ids).then((res) => {
147 148 149 150
          this.$message.success(this.$t("删除成功"))
          this.handleClose()
          this.handleQuery()
        })
151
      } else {
152
        this.$message.warning(this.$t("请先选择要删除的会员等级"))
153 154 155
      }
    },
    handleNewScoreRule() {
156
      this.dialogVisible = true
157 158
    },
    handleQuery() {
159 160
      this.queryParams.pageNo = 1
      let params = { ...this.queryParams }
161
      getMemberLevelList(params).then((res) => {
162 163 164 165
        this.loading = false
        this.memberLevelList = res.data.list
        this.total = res.data.total
      })
166 167
    },
    handleQueryPagination() {
168
      let params = { ...this.queryParams }
169
      getMemberLevelList(params).then((res) => {
170 171 172 173 174 175 176
        this.loading = false
        this.memberLevelList = res.data.list
        this.total = res.data.total
      })
    }
  }
}
177
</script>