drawershow.vue 6.02 KB
<template>
  <!-- 弹出框表单 -->
  <el-drawer
    :title="title"
    :visible.sync="open"
    :direction="direction"
    :destroy-on-close="true"
    size="50%"
  >
    <el-form ref="form" :model="form" :rules="rules" label-width="120px">
      <el-row>
        <Field
          :span="20"
          label="员工姓名"
          prop="name"
          v-model="form.name"
          placeholder="请输入员工姓名"
        />
        <Field
          :span="20"
          label="所属公司"
          prop="companyIds"
          v-model="form.companyIds"
          :multiple="true"
          type="select"
          :enum-data="dict.companyIds"
          placeholder="请输入所属公司"
        />
        <Field
          :span="20"
          label="职位"
          prop="positionId"
          v-model="form.positionId"
          type="select"
          :enum-data="dict.positionId"
          placeholder="请输入职位ID"
        />
        <Field
          :span="20"
          label="联系电话"
          prop="phoneNumber"
          v-model="form.phoneNumber"
          placeholder="请输入联系电话"
        />
        <!-- <Field :span="20" label="员工状态" type="select" prop="staffStatus" v-model="form.staffStatus" :enum-data="dict.staffStatus" placeholder="请输入员工状态"/> -->
        <Field :span="20" label="头像" prop="photoPath" placeholder="请输入照片"
          ><imageUpload v-model="form.photoPath" prePath="/file/preview" />
        </Field>
        <Field
          :span="20"
          label="邮件地址"
          prop="email"
          v-model="form.email"
          placeholder="请输入邮件地址"
        />
        <Field
          :span="20"
          label="备注"
          prop="remark"
          v-model="form.remark"
          type="textarea"
          placeholder="请输入备注"
        />
      </el-row>

      <form-buttons
        @submit="submitForm"
        v-if="pageInfo.type != 'view'"
        noCancelBtn
      />
    </el-form>
  </el-drawer>
</template>

<script>
import form from "@/assets/mixins/formdialog";
export default {
  name: "StaffDetail",
  mixins: [form],
  components: {},
  created() {
    this.changePath("staff");
  },
  data() {
    var checkEmail = (rule, value, callback) => {
      let mailReg = /^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(.[a-zA-Z0-9_-])+/;
      if (!value) {
        //如果输入为空直接返回
        callback();
      } else {
        //如果字符串 string 中含有与 RegExpObject 匹配的文本,则返回 true,否则返回 false。
        if (mailReg.test(value)) {
          //匹配成功返回
          callback();
        } else {
          //匹配不成功返回错误显示
          callback(
            new Error("邮箱格式:xx@xx.xx,只含数字、大小写字母、下划线、横杠")
          );
        }
      }
    };
    var checkPhone = (rule, value, callback) => {
      let phoneReg = /^1[3|4|5|6|7|8|9][0-9]{9}$/;
      if (!value) {
        callback();
      } else {
        if (phoneReg.test(value)) {
          callback();
        } else {
          callback(new Error("请输入正确格式的11位电话号码"));
        }
      }
    };
    return {
      // 遮罩层
      loading: true,
      // 弹出层标题
      title: "员工基本信息",
      // 是否显示弹出层
      open: false,
      direction: "rtl",
      toString: ["gender", "staffType", "staffStatus", "source", "positionId"],
      toArrays: ["companyIds"],

      toDate: ["birthday", "entryDate", "regularDate", "leaveDate"],
      // 表单校验
      rules: {
        name: [
          { required: true, message: "请输入员工姓名", trigger: "blur" },
          { max: 64, message: "最多只能录入64个字符", trigger: "blur" },
        ],
        positionId: [
          { required: true, message: "请选择职位", trigger: "blur" },
        ],
        companyIds: [
          { required: true, message: "请选择所属企业", trigger: "blur" },
        ],
        phoneNumber: [
          { required: true, message: "请输入联系电话", trigger: "blur" },
          { validator: checkPhone, trigger: "blur" },
          { max: 11, message: "最多只能录入11个字符", trigger: "blur" },
        ],
        email: [{ validator: checkEmail, trigger: "blur" }],
      },
    };
  },

  methods: {
    /** 编辑 */
    edit(row) {
      this.reset();
      this.query = { id: row.id };
      this.urls.currUrl = "staff/edit";
      this.getData();
      this.pageInfo.type = "edit";
      this.title = "修改员工基本信息";
    },
    /** 新增 */
    add(row) {
      this.reset();
      this.urls.currUrl = "staff/add";
      this.getData();
      this.pageInfo.type = "add";
      this.title = "新增员工基本信息";
    },
    /** 查看*/
    view(row) {
      this.reset();
      this.query = { id: row.id };
      this.urls.currUrl = "staff/view";
      this.getData();
      this.pageInfo.type = "view";
      this.title = "员工基本信息详细";
    },
    /**取消按钮 */
    cancel() {
      this.open = false;
    },
    /**获取数据后弹框 */
    afterRender(data) {
      this.open = true;
    },

    beforeSubmit(data) {
      data.companyIds = data.companyIds.join(",");

      return data;
    },

    afterSubmit(data) {
      this.open = false;
      this.$emit("ok");
    },

    // 表单重置
    reset() {
      this.form = {
        name: "",
        gender: 1,
        birthday: null,
        photoPath: "",
        Email: "",
        phoneNumber: "",
        idCard: "",
        workNum: "",
        companyName: "",
        positionId: null,
        positionName: "",
        staffType: 1,
        staffStatus: 1,
        source: 1,
        registerPath: "",
        entryDate: null,
        regularDate: null,
        leaveDate: null,
        remark: "",
        sumViews: 0,
        viewsByDay: 0,
        sendBusinessCardTimes: 0,
      };
      this.resetForm("form");
    },
    resetForm(refName) {
      if (this.$refs[refName]) {
        this.$refs[refName].resetFields();
      }
    },
  },
};
</script>