sysDictionary.vue 7.9 KB
Newer Older
Mr.奇淼('s avatar
Mr.奇淼( 已提交
1 2 3 4 5
<template>
  <div>
    <div class="search-term">
      <el-form :inline="true" :model="searchInfo" class="demo-form-inline">
        <el-form-item label="字典名(中)">
何秀钢 已提交
6
          <el-input v-model="searchInfo.name" placeholder="搜索条件" />
7
        </el-form-item>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
8
        <el-form-item label="字典名(英)">
何秀钢 已提交
9
          <el-input v-model="searchInfo.type" placeholder="搜索条件" />
10 11 12
        </el-form-item>
        <el-form-item label="状态" prop="status">
          <el-select v-model="searchInfo.status" clear placeholder="请选择">
何秀钢 已提交
13 14
            <el-option key="true" label="是" value="true" />
            <el-option key="false" label="否" value="false" />
15 16
          </el-select>
        </el-form-item>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
17
        <el-form-item label="描述">
何秀钢 已提交
18
          <el-input v-model="searchInfo.desc" placeholder="搜索条件" />
19
        </el-form-item>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
20
        <el-form-item>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
21 22
          <el-button size="mini" type="primary" icon="el-icon-search" @click="onSubmit">查询</el-button>
          <el-button size="mini" type="primary" icon="el-icon-plus" @click="openDialog">新增</el-button>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
23 24 25 26
        </el-form-item>
      </el-form>
    </div>
    <el-table
何秀钢 已提交
27
      ref="multipleTable"
Mr.奇淼('s avatar
Mr.奇淼( 已提交
28 29 30 31 32 33
      :data="tableData"
      border
      stripe
      style="width: 100%"
      tooltip-effect="dark"
    >
何秀钢 已提交
34
      <el-table-column type="selection" width="55" />
35
      <el-table-column label="日期" width="180">
何秀钢 已提交
36
        <template slot-scope="scope">{{ scope.row.CreatedAt|formatDate }}</template>
37 38
      </el-table-column>

何秀钢 已提交
39
      <el-table-column label="字典名(中)" prop="name" width="120" />
40

何秀钢 已提交
41
      <el-table-column label="字典名(英)" prop="type" width="120" />
42 43

      <el-table-column label="状态" prop="status" width="120">
何秀钢 已提交
44
        <template slot-scope="scope">{{ scope.row.status|formatBoolean }}</template>
45 46
      </el-table-column>

何秀钢 已提交
47
      <el-table-column label="描述" prop="desc" width="280" />
48

Mr.奇淼('s avatar
Mr.奇淼( 已提交
49 50
      <el-table-column label="按钮组">
        <template slot-scope="scope">
Mr.奇淼('s avatar
Mr.奇淼( 已提交
51 52
          <el-button size="mini" type="success" @click="toDetile(scope.row)">详情</el-button>
          <el-button size="mini" type="primary" @click="updateSysDictionary(scope.row)">变更</el-button>
何秀钢 已提交
53
          <el-popover v-model="scope.row.visible" placement="top" width="160">
Mr.奇淼('s avatar
Mr.奇淼( 已提交
54 55 56 57 58
            <p>确定要删除吗?</p>
            <div style="text-align: right; margin: 0">
              <el-button size="mini" type="text" @click="scope.row.visible = false">取消</el-button>
              <el-button type="primary" size="mini" @click="deleteSysDictionary(scope.row)">确定</el-button>
            </div>
何秀钢 已提交
59
            <el-button slot="reference" type="danger" icon="el-icon-delete" size="mini" style="margin-left:10px">删除</el-button>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
60 61 62 63 64 65 66 67 68 69 70
          </el-popover>
        </template>
      </el-table-column>
    </el-table>

    <el-pagination
      :current-page="page"
      :page-size="pageSize"
      :page-sizes="[10, 30, 50, 100]"
      :style="{float:'right',padding:'20px'}"
      :total="total"
何秀钢 已提交
71
      layout="total, sizes, prev, pager, next, jumper"
Mr.奇淼('s avatar
Mr.奇淼( 已提交
72 73
      @current-change="handleCurrentChange"
      @size-change="handleSizeChange"
何秀钢 已提交
74
    />
Mr.奇淼('s avatar
Mr.奇淼( 已提交
75 76 77

    <el-dialog :before-close="closeDialog" :visible.sync="dialogFormVisible" title="弹窗操作">
      <el-form ref="elForm" :model="formData" :rules="rules" size="medium" label-width="110px">
78 79 80 81 82 83
        <el-form-item label="字典名(中)" prop="name">
          <el-input
            v-model="formData.name"
            placeholder="请输入字典名(中)"
            clearable
            :style="{width: '100%'}"
何秀钢 已提交
84
          />
85 86 87 88 89 90 91
        </el-form-item>
        <el-form-item label="字典名(英)" prop="type">
          <el-input
            v-model="formData.type"
            placeholder="请输入字典名(英)"
            clearable
            :style="{width: '100%'}"
何秀钢 已提交
92
          />
93 94
        </el-form-item>
        <el-form-item label="状态" prop="status" required>
何秀钢 已提交
95
          <el-switch v-model="formData.status" active-text="开启" inactive-text="停用" />
96 97
        </el-form-item>
        <el-form-item label="描述" prop="desc">
何秀钢 已提交
98
          <el-input v-model="formData.desc" placeholder="请输入描述" clearable :style="{width: '100%'}" />
99 100 101
        </el-form-item>
      </el-form>

何秀钢 已提交
102
      <div slot="footer" class="dialog-footer">
Mr.奇淼('s avatar
Mr.奇淼( 已提交
103
        <el-button @click="closeDialog">取 消</el-button>
何秀钢 已提交
104
        <el-button type="primary" @click="enterDialog">确 定</el-button>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
105 106
      </div>
    </el-dialog>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
107 108

    <div style="margin-top:40px;color:red">获取字典且缓存方法已在前端utils/dictionary 已经封装完成 不必自己书写 使用方法查看文件内注释</div>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
109 110 111 112 113
  </div>
</template>

<script>
import {
114 115 116 117 118
  createSysDictionary,
  deleteSysDictionary,
  updateSysDictionary,
  findSysDictionary,
  getSysDictionaryList
何秀钢 已提交
119 120 121
} from '@/api/sysDictionary' //  此处请自行替换地址
import { formatTimeToStr } from '@/utils/date'
import infoList from '@/mixins/infoList'
Mr.奇淼('s avatar
Mr.奇淼( 已提交
122
export default {
何秀钢 已提交
123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140
  name: 'SysDictionary',
  filters: {
    formatDate: function(time) {
      if (time !== null && time !== '') {
        var date = new Date(time)
        return formatTimeToStr(date, 'yyyy-MM-dd hh:mm:ss')
      } else {
        return ''
      }
    },
    formatBoolean: function(bool) {
      if (bool !== null) {
        return bool ? '' : ''
      } else {
        return ''
      }
    }
  },
Mr.奇淼('s avatar
Mr.奇淼( 已提交
141 142 143 144 145
  mixins: [infoList],
  data() {
    return {
      listApi: getSysDictionaryList,
      dialogFormVisible: false,
何秀钢 已提交
146
      type: '',
Mr.奇淼('s avatar
Mr.奇淼( 已提交
147
      formData: {
148 149 150 151
        name: null,
        type: null,
        status: true,
        desc: null
Mr.奇淼('s avatar
Mr.奇淼( 已提交
152 153
      },
      rules: {
154 155 156
        name: [
          {
            required: true,
何秀钢 已提交
157 158
            message: '请输入字典名(中)',
            trigger: 'blur'
159 160 161 162 163
          }
        ],
        type: [
          {
            required: true,
何秀钢 已提交
164 165
            message: '请输入字典名(英)',
            trigger: 'blur'
166 167 168 169 170
          }
        ],
        desc: [
          {
            required: true,
何秀钢 已提交
171 172
            message: '请输入描述',
            trigger: 'blur'
173 174 175
          }
        ]
      }
Mr.奇淼('s avatar
Mr.奇淼( 已提交
176 177
    }
  },
何秀钢 已提交
178 179 180
  async created() {
    this.getTableData()
  },
Mr.奇淼('s avatar
Mr.奇淼( 已提交
181
  methods: {
182 183
    toDetile(row) {
      this.$router.push({
何秀钢 已提交
184
        name: 'dictionaryDetail',
185 186 187
        params: {
          id: row.ID
        }
何秀钢 已提交
188
      })
189
    },
何秀钢 已提交
190
    // 条件搜索前端看此方法
191
    onSubmit() {
何秀钢 已提交
192 193 194 195
      this.page = 1
      this.pageSize = 10
      if (this.searchInfo.status === '') {
        this.searchInfo.status = null
196
      }
何秀钢 已提交
197
      this.getTableData()
198
    },
Mr.奇淼('s avatar
Mr.奇淼( 已提交
199
    async updateSysDictionary(row) {
何秀钢 已提交
200 201 202 203 204
      const res = await findSysDictionary({ ID: row.ID })
      this.type = 'update'
      if (res.code === 0) {
        this.formData = res.data.resysDictionary
        this.dialogFormVisible = true
Mr.奇淼('s avatar
Mr.奇淼( 已提交
205 206 207
      }
    },
    closeDialog() {
何秀钢 已提交
208
      this.dialogFormVisible = false
Mr.奇淼('s avatar
Mr.奇淼( 已提交
209
      this.formData = {
210 211 212 213
        name: null,
        type: null,
        status: true,
        desc: null
何秀钢 已提交
214
      }
Mr.奇淼('s avatar
Mr.奇淼( 已提交
215 216
    },
    async deleteSysDictionary(row) {
何秀钢 已提交
217 218 219
      row.visible = false
      const res = await deleteSysDictionary({ ID: row.ID })
      if (res.code === 0) {
Mr.奇淼('s avatar
Mr.奇淼( 已提交
220
        this.$message({
何秀钢 已提交
221 222 223 224 225
          type: 'success',
          message: '删除成功'
        })
        if (this.tableData.length === 1 && this.page > 1) {
          this.page--
226
        }
何秀钢 已提交
227
        this.getTableData()
Mr.奇淼('s avatar
Mr.奇淼( 已提交
228 229 230
      }
    },
    async enterDialog() {
何秀钢 已提交
231 232 233
      this.$refs['elForm'].validate(async valid => {
        if (!valid) return
        let res
Mr.奇淼('s avatar
Mr.奇淼( 已提交
234
        switch (this.type) {
何秀钢 已提交
235 236 237 238 239 240
          case 'create':
            res = await createSysDictionary(this.formData)
            break
          case 'update':
            res = await updateSysDictionary(this.formData)
            break
Mr.奇淼('s avatar
Mr.奇淼( 已提交
241
          default:
何秀钢 已提交
242 243
            res = await createSysDictionary(this.formData)
            break
Mr.奇淼('s avatar
Mr.奇淼( 已提交
244
        }
何秀钢 已提交
245 246 247
        if (res.code === 0) {
          this.closeDialog()
          this.getTableData()
248
        }
何秀钢 已提交
249
      })
Mr.奇淼('s avatar
Mr.奇淼( 已提交
250 251
    },
    openDialog() {
何秀钢 已提交
252 253
      this.type = 'create'
      this.dialogFormVisible = true
Mr.奇淼('s avatar
Mr.奇淼( 已提交
254 255
    }
  }
何秀钢 已提交
256
}
Mr.奇淼('s avatar
Mr.奇淼( 已提交
257 258 259
</script>

<style>
何秀钢 已提交
260
</style>