You need to sign in or sign up before continuing.
sysDictionaryDetail.vue 7.4 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.label" placeholder="搜索条件" />
Mr.奇淼('s avatar
Mr.奇淼( 已提交
7 8
        </el-form-item>
        <el-form-item label="字典值">
何秀钢 已提交
9
          <el-input v-model="searchInfo.value" placeholder="搜索条件" />
Mr.奇淼('s avatar
Mr.奇淼( 已提交
10 11 12
        </el-form-item>
        <el-form-item label="启用状态" prop="status">
          <el-select v-model="searchInfo.status" placeholder="请选择">
何秀钢 已提交
13 14
            <el-option key="true" label="是" value="true" />
            <el-option key="false" label="否" value="false" />
Mr.奇淼('s avatar
Mr.奇淼( 已提交
15 16 17
          </el-select>
        </el-form-item>
        <el-form-item>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
18
          <el-button size="mini" type="primary" icon="el-icon-search" @click="onSubmit">查询</el-button>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
19 20
        </el-form-item>
        <el-form-item>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
21
          <el-button size="mini" type="primary" icon="el-icon-plus" @click="openDialog">新增字典项</el-button>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
22 23 24 25
        </el-form-item>
      </el-form>
    </div>
    <el-table
何秀钢 已提交
26
      ref="multipleTable"
Mr.奇淼('s avatar
Mr.奇淼( 已提交
27 28 29 30 31 32
      :data="tableData"
      border
      stripe
      style="width: 100%"
      tooltip-effect="dark"
    >
何秀钢 已提交
33
      <el-table-column type="selection" width="55" />
Mr.奇淼('s avatar
Mr.奇淼( 已提交
34
      <el-table-column label="日期" width="180">
35
        <template #default="scope">{{ formatDate(scope.row.CreatedAt) }}</template>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
36 37
      </el-table-column>

何秀钢 已提交
38
      <el-table-column label="展示值" prop="label" width="120" />
Mr.奇淼('s avatar
Mr.奇淼( 已提交
39

何秀钢 已提交
40
      <el-table-column label="字典值" prop="value" width="120" />
Mr.奇淼('s avatar
Mr.奇淼( 已提交
41 42

      <el-table-column label="启用状态" prop="status" width="120">
43
        <template #default="scope">{{ formatBoolean(scope.row.status) }}</template>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
44 45
      </el-table-column>

何秀钢 已提交
46
      <el-table-column label="排序标记" prop="sort" width="120" />
Mr.奇淼('s avatar
Mr.奇淼( 已提交
47 48

      <el-table-column label="按钮组">
49
        <template #default="scope">
何秀钢 已提交
50
          <el-button size="small" type="primary" @click="updateSysDictionaryDetail(scope.row)">变更</el-button>
51
          <el-popover v-model:visible="scope.row.visible" placement="top" width="160">
Mr.奇淼('s avatar
Mr.奇淼( 已提交
52 53 54 55 56
            <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="deleteSysDictionaryDetail(scope.row)">确定</el-button>
            </div>
57 58 59
            <template #reference>
              <el-button type="danger" icon="el-icon-delete" size="mini">删除</el-button>
            </template>
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
    <el-dialog v-model="dialogFormVisible" :before-close="closeDialog" title="弹窗操作">
Mr.奇淼('s avatar
Mr.奇淼( 已提交
77 78 79 80 81 82 83
      <el-form ref="elForm" :model="formData" :rules="rules" size="medium" label-width="110px">
        <el-form-item label="展示值" prop="label">
          <el-input
            v-model="formData.label"
            placeholder="请输入展示值"
            clearable
            :style="{width: '100%'}"
何秀钢 已提交
84
          />
Mr.奇淼('s avatar
Mr.奇淼( 已提交
85 86 87 88 89 90 91 92 93
        </el-form-item>
        <el-form-item label="字典值" prop="value">
          <el-input-number
            v-model.number="formData.value"
            step-strictly
            :step="1"
            placeholder="请输入字典值"
            clearable
            :style="{width: '100%'}"
何秀钢 已提交
94
          />
Mr.奇淼('s avatar
Mr.奇淼( 已提交
95 96
        </el-form-item>
        <el-form-item label="启用状态" prop="status" required>
何秀钢 已提交
97
          <el-switch v-model="formData.status" active-text="开启" inactive-text="停用" />
Mr.奇淼('s avatar
Mr.奇淼( 已提交
98 99
        </el-form-item>
        <el-form-item label="排序标记" prop="sort">
何秀钢 已提交
100
          <el-input-number v-model.number="formData.sort" placeholder="排序标记" />
Mr.奇淼('s avatar
Mr.奇淼( 已提交
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>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
109 110 111 112 113 114 115 116 117 118 119
    </el-dialog>
  </div>
</template>

<script>
import {
  createSysDictionaryDetail,
  deleteSysDictionaryDetail,
  updateSysDictionaryDetail,
  findSysDictionaryDetail,
  getSysDictionaryDetailList
何秀钢 已提交
120 121
} from '@/api/sysDictionaryDetail' //  此处请自行替换地址
import infoList from '@/mixins/infoList'
Mr.奇淼('s avatar
Mr.奇淼( 已提交
122 123

export default {
何秀钢 已提交
124
  name: 'SysDictionaryDetail',
Mr.奇淼('s avatar
Mr.奇淼( 已提交
125 126 127 128 129
  mixins: [infoList],
  data() {
    return {
      listApi: getSysDictionaryDetailList,
      dialogFormVisible: false,
何秀钢 已提交
130
      type: '',
Mr.奇淼('s avatar
Mr.奇淼( 已提交
131 132 133 134 135 136 137 138 139 140
      formData: {
        label: null,
        value: null,
        status: true,
        sort: null
      },
      rules: {
        label: [
          {
            required: true,
何秀钢 已提交
141 142
            message: '请输入展示值',
            trigger: 'blur'
Mr.奇淼('s avatar
Mr.奇淼( 已提交
143 144 145 146 147
          }
        ],
        value: [
          {
            required: true,
何秀钢 已提交
148 149
            message: '请输入字典值',
            trigger: 'blur'
Mr.奇淼('s avatar
Mr.奇淼( 已提交
150 151 152 153 154
          }
        ],
        sort: [
          {
            required: true,
何秀钢 已提交
155 156
            message: '排序标记',
            trigger: 'blur'
Mr.奇淼('s avatar
Mr.奇淼( 已提交
157 158 159 160 161
          }
        ]
      }
    }
  },
何秀钢 已提交
162 163 164 165
  created() {
    this.searchInfo.sysDictionaryID = Number(this.$route.params.id)
    this.getTableData()
  },
Mr.奇淼('s avatar
Mr.奇淼( 已提交
166
  methods: {
何秀钢 已提交
167
    // 条件搜索前端看此方法
Mr.奇淼('s avatar
Mr.奇淼( 已提交
168
    onSubmit() {
何秀钢 已提交
169 170 171 172
      this.page = 1
      this.pageSize = 10
      if (this.searchInfo.status === '') {
        this.searchInfo.status = null
Mr.奇淼('s avatar
Mr.奇淼( 已提交
173
      }
何秀钢 已提交
174
      this.getTableData()
Mr.奇淼('s avatar
Mr.奇淼( 已提交
175 176
    },
    async updateSysDictionaryDetail(row) {
何秀钢 已提交
177 178 179 180 181
      const res = await findSysDictionaryDetail({ ID: row.ID })
      this.type = 'update'
      if (res.code === 0) {
        this.formData = res.data.resysDictionaryDetail
        this.dialogFormVisible = true
Mr.奇淼('s avatar
Mr.奇淼( 已提交
182 183 184
      }
    },
    closeDialog() {
何秀钢 已提交
185
      this.dialogFormVisible = false
Mr.奇淼('s avatar
Mr.奇淼( 已提交
186 187 188 189 190
      this.formData = {
        label: null,
        value: null,
        status: true,
        sort: null,
何秀钢 已提交
191 192
        sysDictionaryID: ''
      }
Mr.奇淼('s avatar
Mr.奇淼( 已提交
193 194
    },
    async deleteSysDictionaryDetail(row) {
何秀钢 已提交
195 196 197
      row.visible = false
      const res = await deleteSysDictionaryDetail({ ID: row.ID })
      if (res.code === 0) {
Mr.奇淼('s avatar
Mr.奇淼( 已提交
198
        this.$message({
何秀钢 已提交
199 200 201 202 203
          type: 'success',
          message: '删除成功'
        })
        if (this.tableData.length === 1 && this.page > 1) {
          this.page--
204
        }
何秀钢 已提交
205
        this.getTableData()
Mr.奇淼('s avatar
Mr.奇淼( 已提交
206 207 208
      }
    },
    async enterDialog() {
何秀钢 已提交
209 210 211 212
      this.formData.sysDictionaryID = Number(this.$route.params.id)
      this.$refs['elForm'].validate(async valid => {
        if (!valid) return
        let res
Mr.奇淼('s avatar
Mr.奇淼( 已提交
213
        switch (this.type) {
何秀钢 已提交
214 215 216 217 218 219
          case 'create':
            res = await createSysDictionaryDetail(this.formData)
            break
          case 'update':
            res = await updateSysDictionaryDetail(this.formData)
            break
Mr.奇淼('s avatar
Mr.奇淼( 已提交
220
          default:
何秀钢 已提交
221 222
            res = await createSysDictionaryDetail(this.formData)
            break
Mr.奇淼('s avatar
Mr.奇淼( 已提交
223
        }
何秀钢 已提交
224
        if (res.code === 0) {
Mr.奇淼('s avatar
Mr.奇淼( 已提交
225
          this.$message({
何秀钢 已提交
226 227 228 229 230
            type: 'success',
            message: '创建/更改成功'
          })
          this.closeDialog()
          this.getTableData()
Mr.奇淼('s avatar
Mr.奇淼( 已提交
231
        }
何秀钢 已提交
232
      })
Mr.奇淼('s avatar
Mr.奇淼( 已提交
233 234
    },
    openDialog() {
何秀钢 已提交
235 236
      this.type = 'create'
      this.dialogFormVisible = true
Mr.奇淼('s avatar
Mr.奇淼( 已提交
237 238
    }
  }
何秀钢 已提交
239
}
Mr.奇淼('s avatar
Mr.奇淼( 已提交
240 241 242
</script>

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