sysDictionaryDetail.vue 7.3 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.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>
P
piexlmax 已提交
18 19 20 21
      <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.奇淼( 已提交
22 23
    </div>
    <el-table
何秀钢 已提交
24
      ref="multipleTable"
Mr.奇淼('s avatar
Mr.奇淼( 已提交
25 26 27 28 29 30
      :data="tableData"
      border
      stripe
      style="width: 100%"
      tooltip-effect="dark"
    >
何秀钢 已提交
31
      <el-table-column type="selection" width="55" />
Mr.奇淼('s avatar
Mr.奇淼( 已提交
32
      <el-table-column label="日期" width="180">
33
        <template #default="scope">{{ formatDate(scope.row.CreatedAt) }}</template>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
34 35
      </el-table-column>

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

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

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

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

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

74
    <el-dialog v-model="dialogFormVisible" :before-close="closeDialog" title="弹窗操作">
Mr.奇淼('s avatar
Mr.奇淼( 已提交
75 76 77 78 79 80 81
      <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%'}"
何秀钢 已提交
82
          />
Mr.奇淼('s avatar
Mr.奇淼( 已提交
83 84 85 86 87 88 89 90 91
        </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%'}"
何秀钢 已提交
92
          />
Mr.奇淼('s avatar
Mr.奇淼( 已提交
93 94
        </el-form-item>
        <el-form-item label="启用状态" prop="status" required>
何秀钢 已提交
95
          <el-switch v-model="formData.status" active-text="开启" inactive-text="停用" />
Mr.奇淼('s avatar
Mr.奇淼( 已提交
96 97
        </el-form-item>
        <el-form-item label="排序标记" prop="sort">
何秀钢 已提交
98
          <el-input-number v-model.number="formData.sort" placeholder="排序标记" />
Mr.奇淼('s avatar
Mr.奇淼( 已提交
99 100
        </el-form-item>
      </el-form>
101 102 103 104 105 106
      <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.奇淼( 已提交
107 108 109 110 111 112 113 114 115 116 117
    </el-dialog>
  </div>
</template>

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

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

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