Blame view

ant-design-vue-jeecg/src/views/system/modules/SysDepartRoleModal.vue 4.69 KB
1
2
3
4
5
6
7
8
9
10
11
<template>
  <a-modal
    :title="title"
    :width="800"
    :visible="visible"
    :confirmLoading="confirmLoading"
    @ok="handleOk"
    @cancel="handleCancel"
    cancelText="关闭">

    <a-spin :spinning="confirmLoading">
12
      <a-form-model  ref="form" :model="model" :rules="validatorRules">
13
14
        <a-form-model-item
15
16
          :labelCol="labelCol"
          :wrapperCol="wrapperCol"
17
          prop="roleName"
18
          label="部门角色名称">
19
20
21
          <a-input placeholder="请输入部门角色名称" v-model="model.roleName"/>
        </a-form-model-item>
        <a-form-model-item
22
23
          :labelCol="labelCol"
          :wrapperCol="wrapperCol"
24
          prop="roleCode"
25
          label="部门角色编码">
26
          <a-input placeholder="请输入部门角色编码" v-model="model.roleCode"  :read-only="roleCodeRead"/>
27
28
        </a-form-model-item>
        <a-form-model-item
29
30
          :labelCol="labelCol"
          :wrapperCol="wrapperCol"
31
          prop="description"
32
          label="描述">
33
34
          <a-input placeholder="请输入描述" v-model="model.description"/>
        </a-form-model-item>
35
36
      </a-form-model>
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
    </a-spin>
  </a-modal>
</template>

<script>
  import { httpAction } from '@/api/manage'
  import {duplicateCheck } from '@/api/api'

  export default {
    name: "SysDepartRoleModal",
    data () {
      return {
        title:"操作",
        visible: false,
        model: {},
        labelCol: {
          xs: { span: 24 },
          sm: { span: 5 },
        },
        wrapperCol: {
          xs: { span: 24 },
          sm: { span: 16 },
        },
        confirmLoading: false,
        validatorRules:{
62
          roleName:[
63
64
              { required: true, message: '请输入部门角色名称!' },
              { min: 2, max: 30, message: '长度在 2 到 30 个字符', trigger: 'blur' }
65
66
            ],
          roleCode: [
67
68
69
              { required: true, message: '请输入部门角色编码!'},
              { min: 0, max: 64, message: '长度不超过 64 个字符', trigger: 'blur' },
              { validator: this.validateRoleCode}
70
71
            ],
          description: [
72
              { min: 0, max: 126, message: '长度不超过 126 个字符', trigger: 'blur' }
73
            ]
74
75
76
77
78
        },
        url: {
          add: "/sys/sysDepartRole/add",
          edit: "/sys/sysDepartRole/edit",
        },
79
        roleCodeRead:false //编码时候可以编写
80
81
82
83
84
85
86
87
88
89
90
      }
    },
    created () {
    },
    methods: {
      add (departId) {
        this.edit({},departId);
      },
      edit (record,departId) {
        this.departId = departId;
        this.model = Object.assign({}, record);
91
92
93
        //update-begin---author:wangshuai ---date:20220104  for:[JTC-367]我的部门->部门角色 角色编码应该不可修改------------
        this.roleCodeRead = !!this.model.roleCode
        //update-end---author:wangshuai ---date:20220104  for:[JTC-367]我的部门->部门角色 角色编码应该不可修改------------
94
95
96
97
98
        this.visible = true;
      },
      close () {
        this.$emit('close');
        this.visible = false;
99
        this.$refs.form.resetFields()
100
101
102
103
      },
      handleOk () {
        const that = this;
        // 触发表单验证
104
105
        this.$refs.form.validate(valid => {
          if (valid) {
106
107
108
109
110
111
112
113
114
115
            that.confirmLoading = true;
            let httpurl = '';
            let method = '';
            if(!this.model.id){
              httpurl+=this.url.add;
              method = 'post';
            }else{
              httpurl+=this.url.edit;
               method = 'put';
            }
116
117
            this.model.departId = this.departId;
            httpAction(httpurl,this.model,method).then((res)=>{
118
119
120
121
122
123
124
125
126
127
              if(res.success){
                that.$message.success(res.message);
                that.$emit('ok');
              }else{
                that.$message.warning(res.message);
              }
            }).finally(() => {
              that.confirmLoading = false;
              that.close();
            })
128
129
          }else{
            return false;
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
          }
        })
      },
      handleCancel () {
        this.close()
      },
      validateRoleCode(rule, value, callback){
        if(/[\u4E00-\u9FA5]/g.test(value)){
          callback("部门角色编码不可输入汉字!");
        }else{
          var params = {
            tableName: "sys_depart_role",
            fieldName: "role_code",
            fieldVal: value,
            dataId: this.model.id,
          };
          duplicateCheck(params).then((res)=>{
            if(res.success){
              callback();
            }else{
              callback(res.message);
            }
          });
        }
      }
    }
  }
</script>

<style lang="less" scoped>

</style>