add.vue 6.25 KB
<template>
  <el-dialog :title="title" :visible.sync="open" v-if="open" width="500px" append-to-body>
    <el-form ref="form" :model="form" :rules="rules" label-width="100px">
      <el-form-item label="用户名称" prop="name">
        <el-input v-model="form.name" placeholder="请输入用户名称" :disabled='disabled' />
      </el-form-item>
      <el-form-item label="手机号码" prop="cellPhone">
        <el-input v-model="form.cellPhone" placeholder="请输入手机号码" :disabled='disabled' />
      </el-form-item>
      <el-form-item label="身份证号码" prop="idCard">
        <el-input v-model="form.idCard" placeholder="请输入身份证号码" :disabled='disabled' />
      </el-form-item>
      <el-form-item label="来源产品" prop="source">
        <el-select v-model="form.source" placeholder="来源产品" clearable size="small" :disabled='disabled'>
          <el-option v-for="(item, index) in labelProduct" :key="index" :label="item.name" :value="item.businessCode"
            @keyup.enter.native="handleQuery" />
        </el-select>
      </el-form-item>
      <el-form-item label="名单类型" prop="rollType">
        <el-select v-model="form.rollType" placeholder="名单类型" clearable size="small" :disabled='disabled'>
          <el-option v-for="dict in dict.type.name_roll_type" :key="dict.value" :label="dict.label" :value="dict.value">
          </el-option>
        </el-select>
      </el-form-item>
      <el-form-item label="加入原因" prop="remarks">
        <el-input v-model="form.remarks" type="textarea" placeholder="请输加入原因" :disabled='disabled' />
      </el-form-item>
      <el-form-item label="解除时间" prop="unsealTime">
        <el-date-picker v-model="value2" type="datetime" placeholder="选择日期时间" align="right"
          :picker-options="pickerOptions" :disabled='disabled'>
        </el-date-picker>
      </el-form-item>
    </el-form>
    <div slot="footer" class="dialog-footer" v-if="!disabled">
      <el-button type="primary" @click="submitForm">确 定</el-button>
      <el-button @click="cancel">取 消</el-button>
    </div>
  </el-dialog>
</template>

<script>
import { rollListHistoryModify,businessSourcePage } from "@/api/postList/list";
export default {
  name: 'addMobile',
  dicts: ['sys_normal_disable', 'name_roll_type'],
  props: [

  ],
  data() {
    return {
      imageUrl: '',
      labelProduct: [],
      open: false,
      // 弹出层标题
      title: "",
      // 表单参数
      form: {},
      disabled: true,
      // 表单校验
      rules: {
        name: [
          { required: true, message: "客户名称不能为空", trigger: "blur" }
        ],
        cellPhone: [
          { required: true, message: "手机号码不能为空", trigger: "blur" }
        ],
        idCard: [
          { required: true, message: "身份证号码不能为空", trigger: "blur" }
        ],
        source: [
          { required: true, message: "来源产品不能为空", trigger: "blur" }
        ],
        rollType: [
          { required: true, message: "名单类型不能为空", trigger: "blur" }
        ],
        remarks: [
          { required: true, message: "加入原因不能为空", trigger: "blur" }
        ]
      },
      pickerOptions: {
        shortcuts: [{
          text: '今天',
          onClick(picker) {
            picker.$emit('pick', new Date());
          }
        }, {
          text: '昨天',
          onClick(picker) {
            const date = new Date();
            date.setTime(date.getTime() - 3600 * 1000 * 24);
            picker.$emit('pick', date);
          }
        }, {
          text: '一周前',
          onClick(picker) {
            const date = new Date();
            date.setTime(date.getTime() - 3600 * 1000 * 24 * 7);
            picker.$emit('pick', date);
          }
        }]
      },
      value2: '',
      id: ''
    }
  },
  methods: {
    // 取消按钮
    cancel() {
      this.open = false;
      this.form = {}
    },
    add() {
      this.open = true;
      this.form = {}
      this.id = ''
      var lis = {
        pageNum: 1,
        pageSize: 10000,
      }
      businessSourcePage(lis).then(response => {
        this.labelProduct = response.rows
      });
    },
    edit(res) {
      this.form = res
      this.open = true;
      this.value2 = res.unsealTime
      this.id = res.id
      var lis = {
        pageNum: 1,
        pageSize: 10000,
      }
      businessSourcePage(lis).then(response => {
        this.labelProduct = response.rows
      });
    },
    see(res) {
      this.form = res
      this.open = true;
      var lis = {
        pageNum: 1,
        pageSize: 10000,
      }
      businessSourcePage(lis).then(response => {
        this.labelProduct = response.rows
      });
    },
    handleAvatarSuccess(res, file) {
      this.imageUrl = URL.createObjectURL(file.raw);
    },
    beforeAvatarUpload(file) {
      const isJPG = file.type === 'image/jpeg';
      const isLt2M = file.size / 1024 / 1024 < 2;

      if (!isJPG) {
        this.$message.error('上传头像图片只能是 JPG 格式!');
      }
      if (!isLt2M) {
        this.$message.error('上传头像图片大小不能超过 2MB!');
      }
      return isJPG && isLt2M;
    },
    /** 提交按钮 */
    submitForm: function () {
      this.$refs["form"].validate(valid => {
        this.form.unsealTime = this.value2
        this.form.type = 'PERSON'
        this.form.id = this.id
        if (valid) {
          rollListHistoryModify(this.form).then(response => {
            if (response.code == 200) {
              this.$modal.msgSuccess(response.msg);
              this.open = false;
              this.$emit("getList")
            } else {
              this.$modal.msgSuccess(response.msg);
            }
          });
        }
      });
    },
  }
}
</script>

<style>
.box1 {
  display: flex;
  justify-content: space-around;
  width: 100%;
}

.avatar-uploader .el-upload {
  border: 1px dashed #d9d9d9;
  border-radius: 6px;
  cursor: pointer;
  position: relative;
  overflow: hidden;
}

.avatar-uploader .el-upload:hover {
  border-color: #409EFF;
}

.avatar-uploader-icon {
  font-size: 28px;
  color: #8c939d;
  width: 178px;
  height: 178px;
  line-height: 178px;
  text-align: center;
}

.avatar {
  width: 178px;
  height: 178px;
  display: block;
}
</style>