sysDictionaryDetail.vue 7.7 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 slot-scope="scope">{{ scope.row.CreatedAt|formatDate }}</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 slot-scope="scope">{{ scope.row.status|formatBoolean }}</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 49

      <el-table-column label="按钮组">
        <template slot-scope="scope">
何秀钢 已提交
50 51
          <el-button size="small" type="primary" @click="updateSysDictionaryDetail(scope.row)">变更</el-button>
          <el-popover v-model="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
            <el-button slot="reference" type="danger" icon="el-icon-delete" size="mini">删除</el-button>
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 75 76 77 78 79 80 81

    <el-dialog :before-close="closeDialog" :visible.sync="dialogFormVisible" title="弹窗操作">
      <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
      <div slot="footer" class="dialog-footer">
Mr.奇淼('s avatar
Mr.奇淼( 已提交
102
        <el-button @click="closeDialog">取 消</el-button>
何秀钢 已提交
103
        <el-button type="primary" @click="enterDialog">确 定</el-button>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
104 105 106 107 108 109 110 111 112 113 114 115
      </div>
    </el-dialog>
  </div>
</template>

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

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

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