chenying 4 years ago
parent
commit
1bcd3264ec

+ 129 - 0
src/views/modules/sys/dict-add-or-update.vue

@@ -0,0 +1,129 @@
+<template>
+  <el-dialog
+    :title="!dataForm.id ? '新增' : '修改'"
+    :close-on-click-modal="false"
+    :visible.sync="visible">
+    <el-form :model="dataForm" :rules="dataRule" ref="dataForm" @keyup.enter.native="dataFormSubmit()" label-width="80px">
+      <el-form-item label="字典名称" prop="name">
+        <el-input v-model="dataForm.name" placeholder="字典名称"></el-input>
+      </el-form-item>
+      <el-form-item label="字典码" prop="code">
+        <el-input v-model="dataForm.code" placeholder="字典码"></el-input>
+      </el-form-item>
+      <el-form-item label="字典类型" prop="type" >
+        <el-input v-model="dataForm.type" placeholder="字典类型"></el-input>
+      </el-form-item>
+      <el-form-item label="字典值" prop="value">
+        <el-input v-model="dataForm.value" placeholder="字典值"></el-input>
+      </el-form-item>
+      <el-form-item label="排序" prop="orderNum">
+        <el-input-number v-model="dataForm.orderNum" controls-position="right" :min="0" label="排序号"></el-input-number>
+      </el-form-item>
+      <el-form-item label="删除标记" size="mini" prop="delFlag">
+        <el-radio-group v-model="dataForm.delFlag">
+          <el-radio :label="0">正常</el-radio>
+          <el-radio :label="-1">已删除</el-radio>
+        </el-radio-group>
+      </el-form-item>
+    </el-form>
+    <el-form-item label="备注" prop="remark">
+        <el-input v-model="dataForm.remark" placeholder="备注"></el-input>
+      </el-form-item>
+    <span slot="footer" class="dialog-footer">
+      <el-button @click="visible = false">取消</el-button>
+      <el-button type="primary" @click="dataFormSubmit()">确定</el-button>
+    </span>
+  </el-dialog>
+</template>
+
+<script>
+  export default {
+    data () {
+      return {
+        visible: false,
+        roleList: [],
+        dataForm: {
+          id: 0,
+          name: '',
+          code: '',
+          delFlag: 0,
+          orderNum: 0,
+          remark: '',
+          type: '',
+          value: ''
+        },
+        dataRule: {
+          name: [
+            { required: true, message: '字典名称不能为空', trigger: 'blur' }
+          ],
+          code: [
+            { required: true, message: '字典码不能为空', trigger: 'blur' }
+          ],
+          type: [
+            { required: true, message: '字典类型不能为空', trigger: 'blur' }
+          ],
+          value: [
+            { required: true, message: '字典值不能为空', trigger: 'blur' }
+          ]
+        }
+      }
+    },
+    methods: {
+      init (id) {
+        this.visible = true
+        if (this.dataForm.id) {
+          this.$http({
+            url: this.$http.adornUrl(`/user-service/dict/info/${this.dataForm.id}`),
+            method: 'get',
+            params: this.$http.adornParams()
+          }).then(({data}) => {
+            if (data && data.code === '200') {
+              this.dataForm.name = data.data.name
+              this.dataForm.code = data.data.code
+              this.dataForm.type = data.data.type
+              this.dataForm.value = data.data.value
+              this.dataForm.delFlag = Number(data.data.delFlag)
+              this.dataForm.orderNum = Number(data.data.orderNum)
+              this.dataForm.remark = data.data.remark
+            }
+          })
+        }
+      },
+      // 表单提交
+      dataFormSubmit () {
+        this.$refs['dataForm'].validate((valid) => {
+          if (valid) {
+            this.$http({
+              url: this.$http.adornUrl(`/user-service/dict/${!this.dataForm.id ? 'save' : 'update'}`),
+              method: !this.dataForm.id ? 'post' : 'put',
+              data: this.$http.adornData({
+                'id': this.dataForm.id || undefined,
+                'name': this.dataForm.name,
+                'code': this.dataForm.code,
+                'type': this.dataForm.type,
+                'value': this.dataForm.value,
+                'delFlag': this.dataForm.delFlag,
+                'orderNum': this.dataForm.orderNum,
+                'remark': this.dataForm.remark
+              })
+            }).then(({data}) => {
+              if (data && data.code === '200') {
+                this.$message({
+                  message: '操作成功',
+                  type: 'success',
+                  duration: 1500,
+                  onClose: () => {
+                    this.visible = false
+                    this.$emit('refreshDataList')
+                  }
+                })
+              } else {
+                this.$message.error(data.msg)
+              }
+            })
+          }
+        })
+      }
+    }
+  }
+</script>

+ 181 - 0
src/views/modules/sys/dict.vue

@@ -0,0 +1,181 @@
+<template>
+  <div class="mod-user">
+    <el-form :inline="true" :model="dataForm" @keyup.enter.native="getDataList()">
+      <el-form-item>
+        <el-input v-model="dataForm.userName" placeholder="字典名称" clearable></el-input>
+      </el-form-item>
+      <el-form-item>
+        <el-button @click="getDataList()">查询</el-button>
+        <el-button v-if="isAuth('sys:user:save')" type="primary" @click="addOrUpdateHandle()">新增</el-button>
+        <el-button v-if="isAuth('sys:user:delete')" type="danger" @click="deleteHandle()" :disabled="dataListSelections.length <= 0">批量删除</el-button>
+      </el-form-item>
+    </el-form>
+    <el-table
+      :data="dataList"
+      border
+      v-loading="dataListLoading"
+      @selection-change="selectionChangeHandle"
+      style="width: 100%;">
+      <el-table-column
+        type="selection"
+        header-align="center"
+        align="center"
+        width="50">
+      </el-table-column>
+      <el-table-column
+        prop="name"
+        header-align="center"
+        align="center"
+        label="字典名称">
+      </el-table-column>
+      <el-table-column
+        prop="code"
+        header-align="center"
+        align="center"
+        label="字典码">
+      </el-table-column>
+      <el-table-column
+        prop="type"
+        header-align="center"
+        align="center"
+        label="字典类型">
+      </el-table-column>
+      <el-table-column
+        prop="value"
+        header-align="center"
+        align="center"
+        label="字典值">
+      </el-table-column>
+      <el-table-column
+        prop="remark"
+        header-align="center"
+        align="center"
+        label="备注">
+      </el-table-column>
+      <el-table-column
+        fixed="right"
+        header-align="center"
+        align="center"
+        width="150"
+        label="操作">
+        <template slot-scope="scope">
+          <el-button v-if="isAuth('sys:user:update')" type="text" size="small" @click="addOrUpdateHandle(scope.row.id)">修改</el-button>
+          <el-button v-if="isAuth('sys:user:delete')" type="text" size="small" @click="deleteHandle(scope.row.id)">删除</el-button>
+        </template>
+      </el-table-column>
+    </el-table>
+    <el-pagination
+      @size-change="sizeChangeHandle"
+      @current-change="currentChangeHandle"
+      :current-page="pageIndex"
+      :page-sizes="[10, 20, 50, 100]"
+      :page-size="pageSize"
+      :total="totalPage"
+      layout="total, sizes, prev, pager, next, jumper">
+    </el-pagination>
+    <!-- 弹窗, 新增 / 修改 -->
+    <add-or-update v-if="addOrUpdateVisible" ref="addOrUpdate" @refreshDataList="getDataList"></add-or-update>
+  </div>
+</template>
+
+<script>
+  import AddOrUpdate from './dict-add-or-update'
+  export default {
+    data () {
+      return {
+        dataForm: {
+          userName: ''
+        },
+        dataList: [],
+        pageIndex: 1,
+        pageSize: 10,
+        totalPage: 0,
+        dataListLoading: false,
+        dataListSelections: [],
+        addOrUpdateVisible: false
+      }
+    },
+    components: {
+      AddOrUpdate
+    },
+    activated () {
+      this.getDataList()
+    },
+    methods: {
+      // 获取数据列表
+      getDataList () {
+        this.dataListLoading = true
+        this.$http({
+          url: this.$http.adornUrl('/user-service/dict/list'),
+          method: 'get',
+          params: this.$http.adornParams({
+            'current': this.pageIndex,
+            'size': this.pageSize,
+            'name': this.dataForm.userName
+          })
+        }).then(({data}) => {
+          if (data && data.code === '200') {
+            this.dataList = data.data.records
+            this.totalPage = Number(data.data.pages)
+          } else {
+            this.dataList = []
+            this.totalPage = 0
+          }
+          this.dataListLoading = false
+        })
+      },
+      // 每页数
+      sizeChangeHandle (val) {
+        this.pageSize = val
+        this.pageIndex = 1
+        this.getDataList()
+      },
+      // 当前页
+      currentChangeHandle (val) {
+        this.pageIndex = val
+        this.getDataList()
+      },
+      // 多选
+      selectionChangeHandle (val) {
+        this.dataListSelections = val
+      },
+      // 新增 / 修改
+      addOrUpdateHandle (id) {
+        this.addOrUpdateVisible = true
+        this.$nextTick(() => {
+          this.$refs.addOrUpdate.init(id)
+        })
+      },
+      // 删除
+      deleteHandle (id) {
+        var userIds = id ? [id] : this.dataListSelections.map(item => {
+          return item.id
+        })
+        this.$confirm(`确定对[id=${userIds.join(',')}]进行[${id ? '删除' : '批量删除'}]操作?`, '提示', {
+          confirmButtonText: '确定',
+          cancelButtonText: '取消',
+          type: 'warning'
+        }).then(() => {
+          this.$http({
+            url: this.$http.adornUrl('/user-service/dict/delete'),
+            method: 'DELETE',
+            data: this.$http.adornData(userIds, false)
+          }).then(({data}) => {
+            if (data && data.code === '200') {
+              this.$message({
+                message: '操作成功',
+                type: 'success',
+                duration: 1500,
+                onClose: () => {
+                  this.getDataList()
+                }
+              })
+            } else {
+              this.$message.error(data.msg)
+            }
+          })
+        }).catch(() => {})
+      }
+    }
+  }
+</script>

+ 1 - 1
src/views/modules/sys/user.vue

@@ -170,7 +170,7 @@
         }).then(() => {
           this.$http({
             url: this.$http.adornUrl('/user-service/user/delete'),
-            method: 'post',
+            method: 'DELETE',
             data: this.$http.adornData(userIds, false)
           }).then(({data}) => {
             if (data && data.code === '200') {