addAccount.vue 5.08 KB
<template>
  <div>
    <a-modal
      :title="title"
      :width="800"
      :centered="true"
      :visible="visible"
      :confirmLoading="confirmLoading"
      @ok="handleSubmit"
      @cancel="handleCancel"
      cancelText="关闭"
      style="top:20px;"
      :maskClosable="false"  
    >
      <a-spin :spinning="confirmLoading">
        <a-form :form="form">
          <!-- <a-form-item label="客户主体类型" :labelCol="labelCol" :wrapperCol="wrapperCol">
            <a-input placeholder="请输入参数编号" v-decorator="[ 'username', validatorRules.username]" />
          </a-form-item>-->
          <a-form-item label="客户主体类型:" :labelCol="labelCol" :wrapperCol="wrapperCol">
            <a-select v-decorator="[ 'status', validatorRules.status]" placeholder="请选择客户主体类型">
              <a-select-option value>请选择</a-select-option>
              <a-select-option value="1">个人客户</a-select-option>
              <a-select-option value="2">企业客户</a-select-option>
              <a-select-option value="3">企业法人代表客户</a-select-option>
            </a-select>
          </a-form-item>
          <a-form-item label="客户编号:" :labelCol="labelCol" :wrapperCol="wrapperCol" hasFeedback>
            <a-input placeholder="请输入客户编号" v-decorator="[ 'password', validatorRules.password]" />
          </a-form-item>

          <a-form-item label="客户额度(元):" :labelCol="labelCol" :wrapperCol="wrapperCol">
            <!-- <a-input type="number" placeholder="请输入客户额度" v-decorator="[ 'account', validatorRules.account]" /> -->
            <a-input-number
              style="width:100%"
              id="inputNumber"
              placeholder="请输入客户额度"
              :min="1"
              v-decorator="[ 'account', validatorRules.account]"
            />
          </a-form-item>
          <!-- <a-form-item label="参数替代标志:" :labelCol="labelCol" :wrapperCol="wrapperCol">
            <a-input placeholder="请输入参数替代标志:" v-decorator="[ 'params1', {}]" />
          </a-form-item>
          <a-form-item label="参数含义:" :labelCol="labelCol" :wrapperCol="wrapperCol">
            <a-textarea rows="4" placeholder="备注" v-decorator="['remark']" />
          </a-form-item>-->
        </a-form>
      </a-spin>
    </a-modal>
  </div>
</template>

<script>
import { changPassword } from '@/api/api'
export default {
  name: 'PasswordModal',
  data() {
    return {
      visible: false,
      detailFlag: false,
      title: '',
      confirmLoading: false,
      confirmDirty: false,
      validatorRules: {
        status: {
          rules: [
            {
              required: true,
              message: '请选择客户主体类型'
            }
          ]
        },
        password: {
          rules: [
            {
              required: true,
              message: '请输入客户编号'
              // pattern: /^(?=.*[a-zA-Z])(?=.*\d)(?=.*[~!@#$%^&*()_+`\-={}:";'<>?,./]).{8,}$/,
              // message: '密码由8位数字、大小写字母和特殊符号组成!'
            },
            {
              validator: this.validateToNextPassword
            }
          ]
        },
        account: {
          rules: [
            {
              required: true,
              message: '请输入客户额度'
            }
            // {
            //   validator: this.compareToFirstPassword
            // }
          ]
        }
      },

      model: {
        value: 1,
        value1: 2
      },

      labelCol: {
        xs: { span: 24 },
        sm: { span: 5 }
      },
      wrapperCol: {
        xs: { span: 24 },
        sm: { span: 16 }
      },
      form: this.$form.createForm(this)
    }
  },
  created() {
    console.log('created')
  },

  methods: {
    edit(username, type) {
      this.detailFlag = true

      console.log(111, username, type)
    },

    add(username) {
      this.form.resetFields()
      this.visible = true
      this.model.username = '11'
      this.$nextTick(() => {
        this.form.setFieldsValue({
          status: '',
          account: '',
          password: ''
        })
      })
    },

    onChange() {},

    close() {
      this.$emit('close')
      this.visible = false
      this.detailFlag = false
      this.disableSubmit = false
      this.selectedRole = []
    },
    handleSubmit() {
      // 触发表单验证
      this.form.validateFields((err, values) => {
        console.log(err, values)
        if (!err) {
          this.confirmLoading = true
          let formData = Object.assign(this.model, values)
          changPassword(formData)
            .then(res => {
              if (res.status.statusCode == 0) {
                this.$message.success(res.status.statusReason)
                this.$emit('ok')
              } else {
                this.$message.warning(res.status.statusReason)
              }
            })
            .finally(() => {
              this.confirmLoading = false
              this.close()
            })
        }
      })
    },
    handleCancel() {
      this.close()
    }
  }
}
</script>