sysDictionary.vue 7.5 KB
Newer Older
Mr.奇淼('s avatar
Mr.奇淼( 已提交
1 2 3
<template>
  <div>
    <div class="search-term">
P
piexlmax 已提交
4
      <el-form :inline="true" :model="searchInfo">
Mr.奇淼('s avatar
Mr.奇淼( 已提交
5
        <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>
P
piexlmax 已提交
21 22 23 24
      <div class="gva-btn-list">
        <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>
      </div>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
25 26
    </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 #default="scope">{{ formatDate(scope.row.CreatedAt) }}</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 #default="scope">{{ formatBoolean(scope.row.status) }}</template>
45 46
      </el-table-column>

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

Mr.奇淼('s avatar
Mr.奇淼( 已提交
49
      <el-table-column label="按钮组">
50
        <template #default="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:visible="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 60 61
            <template #reference>
              <el-button type="danger" icon="el-icon-delete" size="mini" style="margin-left:10px">删除</el-button>
            </template>
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
    <el-dialog v-model="dialogFormVisible" :before-close="closeDialog" title="弹窗操作">
Mr.奇淼('s avatar
Mr.奇淼( 已提交
79
      <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
        </el-form-item>
      </el-form>
103 104 105 106 107 108
      <template #footer>
        <div class="dialog-footer">
          <el-button @click="closeDialog">取 消</el-button>
          <el-button type="primary" @click="enterDialog">确 定</el-button>
        </div>
      </template>
109

Mr.奇淼('s avatar
Mr.奇淼( 已提交
110
    </el-dialog>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
111 112

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

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

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