Blame view

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

    <a-spin :spinning="confirmLoading">
13
      <a-form-model ref="form" :model="model" :rules="validatorRules">
14
15
        <a-form-model-item
16
17
          :labelCol="labelCol"
          :wrapperCol="wrapperCol"
18
19
          prop="code"
          required
20
          label="职务编码">
21
22
23
          <a-input placeholder="请输入职务编码" v-model="model.code" :read-only="readOnly"/>
        </a-form-model-item>
        <a-form-model-item
24
25
          :labelCol="labelCol"
          :wrapperCol="wrapperCol"
26
27
          prop="name"
          required
28
          label="职务名称">
29
30
31
          <a-input placeholder="请输入职务名称" v-model="model.name"/>
        </a-form-model-item>
        <a-form-model-item
32
33
          :labelCol="labelCol"
          :wrapperCol="wrapperCol"
34
35
          prop="postRank"
          required
36
37
38
39
40
          label="职级"
        >
          <j-dict-select-tag
            placeholder="请选择职级"
            dictCode="position_rank"
41
            v-model="model.postRank"
42
          />
43
        </a-form-model-item>
44
45
      </a-form-model>
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
    </a-spin>
  </a-modal>
</template>

<script>
  import pick from 'lodash.pick'
  import { httpAction } from '@/api/manage'
  import { duplicateCheck } from '@/api/api'
  import JDictSelectTag from '@/components/dict/JDictSelectTag'

  let validatorCodeTimer = null

  export default {
    name: 'SysPositionModal',
    components: { JDictSelectTag },
    data() {
      return {
        title: '操作',
        visible: false,
        model: {},
        labelCol: {
          xs: { span: 24 },
          sm: { span: 5 },
        },
        wrapperCol: {
          xs: { span: 24 },
          sm: { span: 16 },
        },
        confirmLoading: false,
        validatorRules: {
76
          code: [
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
              { required: true, message: '请输入职务编码' },
              {
                validator: (rule, value, callback) => {
                  // 函数消抖的简单实现,防止一段时间内发送多次请求
                  if (validatorCodeTimer) {
                    // 停止上次开启的定时器
                    clearTimeout(validatorCodeTimer)
                  }
                  validatorCodeTimer = setTimeout(() => {
                    duplicateCheck({
                      tableName: 'sys_position',
                      fieldName: 'code',
                      fieldVal: value,
                      dataId: this.model.id
                    }).then((res) => {
                      if (res.success) {
                        callback()
                      } else {
                        callback(res.message)
                      }
                    }).catch(console.error)
                  }, 300)
                }
              }
101
102
103
            ],
          name: [{ required: true, message: '请输入职务名称' }] ,
          postRank:  [{ required: true, message: '请选择职级' }] ,
104
105
106
107
108
        },
        url: {
          add: '/sys/position/add',
          edit: '/sys/position/edit',
        },
109
        readOnly:false
110
111
112
113
114
115
116
117
118
119
120
      }
    },
    created() {
    },
    methods: {
      add() {
        this.edit({})
      },
      edit(record) {
        this.model = Object.assign({}, record)
        this.visible = true
121
122
123
124
125
        if(record.id){
          this.readOnly=true
        }else{
          this.readOnly=false
        }
126
127
128
129
      },
      close() {
        this.$emit('close')
        this.visible = false
130
        this.$refs.form.resetFields();
131
132
133
134
      },
      handleOk() {
        const that = this
        // 触发表单验证
135
136
        this.$refs.form.validate(valid => {
          if (valid) {
137
138
139
140
141
142
143
144
145
146
147
            that.confirmLoading = true
            let httpurl = ''
            let method = ''
            if (!this.model.id) {
              httpurl += this.url.add
              method = 'post'
            } else {
              httpurl += this.url.edit
              method = 'put'
            }
148
            httpAction(httpurl, this.model, method).then((res) => {
149
150
151
152
153
154
155
156
157
158
              if (res.success) {
                that.$message.success(res.message)
                that.$emit('ok')
              } else {
                that.$message.warning(res.message)
              }
            }).finally(() => {
              that.confirmLoading = false
              that.close()
            })
159
160
          }else{
            return false;
161
162
163
164
165
166
167
168
169
170
171
172
173
174
          }
        })
      },
      handleCancel() {
        this.close()
      },


    }
  }
</script>

<style lang="less" scoped>
175
</style>