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>
何秀钢 已提交
21
          <el-button type="primary" @click="onSubmit">查询</el-button>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
22 23
        </el-form-item>
        <el-form-item>
何秀钢 已提交
24
          <el-button type="primary" @click="openDialog">新增字典</el-button>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
25 26 27 28
        </el-form-item>
      </el-form>
    </div>
    <el-table
何秀钢 已提交
29
      ref="multipleTable"
Mr.奇淼('s avatar
Mr.奇淼( 已提交
30 31 32 33 34 35
      :data="tableData"
      border
      stripe
      style="width: 100%"
      tooltip-effect="dark"
    >
何秀钢 已提交
36
      <el-table-column type="selection" width="55" />
37
      <el-table-column label="日期" width="180">
何秀钢 已提交
38
        <template slot-scope="scope">{{ scope.row.CreatedAt|formatDate }}</template>
39 40
      </el-table-column>

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

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

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

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

Mr.奇淼('s avatar
Mr.奇淼( 已提交
51 52
      <el-table-column label="按钮组">
        <template slot-scope="scope">
何秀钢 已提交
53 54 55
          <el-button size="small" type="success" @click="toDetile(scope.row)">详情</el-button>
          <el-button size="small" type="primary" @click="updateSysDictionary(scope.row)">变更</el-button>
          <el-popover v-model="scope.row.visible" placement="top" width="160">
Mr.奇淼('s avatar
Mr.奇淼( 已提交
56 57 58 59 60
            <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>
何秀钢 已提交
61
            <el-button slot="reference" type="danger" icon="el-icon-delete" size="mini" style="margin-left:10px">删除</el-button>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
62 63 64 65 66 67 68 69 70 71 72
          </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"
何秀钢 已提交
73
      layout="total, sizes, prev, pager, next, jumper"
Mr.奇淼('s avatar
Mr.奇淼( 已提交
74 75
      @current-change="handleCurrentChange"
      @size-change="handleSizeChange"
何秀钢 已提交
76
    />
Mr.奇淼('s avatar
Mr.奇淼( 已提交
77 78 79

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

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

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

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

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