FeeModal.vue 6.02 KB
<template>
  <a-modal 
    :title="title"
    :width="800"
    :centered='true'
    :visible="visible"
    :maskClosable="false"
    :confirmLoading="confirmLoading"
    @ok="handleSubmit"
    @cancel="handleCancel"
    cancelText="关闭"
    style="top:20px;"
  >
    <a-spin :spinning="confirmLoading">
      <a-form :form="form">
        <template v-if="!!model.id">
        <a-form-item label="费用编号:" :labelCol="labelCol" :wrapperCol="wrapperCol">
          <a-input placeholder="请输入费用编号" v-decorator="['chargeNo', validatorRules.chargeNo]" :readOnly="true"/>
        </a-form-item>
        </template>
        <a-form-item label="费用名称:" :labelCol="labelCol" :wrapperCol="wrapperCol" hasFeedback >
          <a-input  placeholder="请输入费用名称" v-decorator="['chargeName', validatorRules.chargeName]" />
        </a-form-item>

        <a-form-item label="收费方式:" :labelCol="labelCol" :wrapperCol="wrapperCol" >
          <a-radio-group v-decorator="['chargeType', validatorRules.chargeNo]" @change ="handleChange">
            <a-radio :value="1">按比例收</a-radio>
            <a-radio :value="2">固定收费</a-radio>
          </a-radio-group>
        </a-form-item>
        <template v-if="value == 1">
        <a-form-item label="收费比例(放款额):" :labelCol="labelCol" :wrapperCol="wrapperCol">
          <a-input  placeholder="请输入收费比例(放款额)" v-decorator="['proportion', {}]" addonAfter="%"/>
        </a-form-item>
        <a-form-item label="最高收费:" :labelCol="labelCol" :wrapperCol="wrapperCol" >
          <a-input placeholder="请输入最高收费" v-decorator="['maxMoney', {}]" />
        </a-form-item>
        <a-form-item label="最低收费:" :labelCol="labelCol" :wrapperCol="wrapperCol" >
          <a-input placeholder="请输入最低收费" v-decorator="['minMoney', {}]" />
        </a-form-item>
        </template>
        <template v-if="value == 2">
        <a-form-item label="固定收费(元):" :labelCol="labelCol" :wrapperCol="wrapperCol" >
          <a-input placeholder="请输入固定收费(元)" v-decorator="['fixMoney', {}]" />
        </a-form-item>
        </template>
        <a-form-item label="收费模式:" :labelCol="labelCol" :wrapperCol="wrapperCol" >
          <a-radio-group v-decorator="['timePoint', validatorRules.timePoint]">
            <a-radio :value="1">放款时收</a-radio>
            <a-radio :value="2">还款时收</a-radio>
          </a-radio-group>
        </a-form-item>

        <a-form-item label="银行卡代扣手续费:" :labelCol="labelCol" :wrapperCol="wrapperCol" >
          <a-radio-group v-decorator="['bankCardDebit', validatorRules.bankCardDebit]">
            <a-radio :value="1">是</a-radio>
            <a-radio :value="2">否</a-radio>
          </a-radio-group>
        </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>
</template>

<script>
  import { insertCharge, updateCharge } from '@/api/configApi'
  export default {
    name: "PasswordModal",
    data () {
      return {
        visible: false,
        confirmLoading: false,
        confirmDirty: false,
        title: '',
        value: '',
        validatorRules:{
          chargeNo: {
            rules:[{
              required: true,
              message: '请输入费用编号'
            }]
          },
          chargeName: {
            rules:[{
              required: true,
              pattern: /^[\u4e00-\u9fa5]{4,16}/,
              message: '请输入正确的费用名称'
            }]
          },
          chargeType: {
            rules:[{
              required: true,
              message: '请选择收费方式'
            }]
          },
          timePoint: {
            rules:[{
              required: true,
              message: '请选择收费模式'
            }]
          },
          bankCardDebit: {
            rules:[{
              required: true,
              message: '请选择银行卡代扣手续费'
            }]
          },
        },

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

    methods: {
      handleChange(value){
        this.value = value.target.value
      },
      edit (record) {
        this.model = record;
        console.log(record)
        this.value = record.chargeType;
        this.form.resetFields();
        this.visible = true;
        this.$nextTick(() => {
          this.form.setFieldsValue(record);
        });
      },

      add () {
        this.model = {};
        this.form.resetFields();
        this.visible = true;
        this.$nextTick(() => {
          this.form.setFieldsValue();
        });
      },

      close () {
        this.$emit('close');
        this.visible = false;
        this.disableSubmit = false;
        this.selectedRole = [];
      },
      handleSubmit () {
        // 触发表单验证
        this.form.validateFields((err, values) => {
          if (!err) {
            this.confirmLoading = true;
            let formData = values, promiseFn;
            if(!!this.model.id){ //编辑
              promiseFn = updateCharge(formData);
            }else{
              promiseFn = insertCharge(formData)
            }
            promiseFn.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>