Surpriseplus
2022-10-26 62ae55ae397b7997b147a7b946f7ad5f1c78a45d
src/views/userManage/userInfoManage.vue
@@ -35,29 +35,37 @@
        <el-form-item>
          <el-button @click="queryInfo()"
            ><i class="el-icon-search"></i> &nbsp;{{
              $t("operatManage.ELM.search")
              $t('operatManage.ELM.search')
            }}</el-button
          >
        </el-form-item>
        <el-form-item>
          <el-button @click="resetInfo('queryForm')"
            ><i class="el-icon-delete"></i>&nbsp;{{
              $t("operatManage.ELM.reset")
              $t('operatManage.ELM.reset')
            }}</el-button
          >
        </el-form-item>
        <br />
        <el-form-item>
          <el-button type="success" size="small" @click="showAddDialog"
          <el-button
            v-if="menuStatus.insert"
            type="success"
            size="small"
            @click="showAddDialog"
            ><i class="el-icon-plus"></i>&nbsp;{{
              $t("common.append")
              $t('common.append')
            }}</el-button
          >
        </el-form-item>
        <el-form-item>
          <el-button type="danger" size="small" @click="deleteUserInfo"
          <el-button
            v-if="menuStatus.delete"
            type="danger"
            size="small"
            @click="deleteUserInfo"
            ><i class="el-icon-delete"></i>&nbsp;{{
              $t("common.delete")
              $t('common.delete')
            }}</el-button
          >
        </el-form-item>
@@ -182,6 +190,7 @@
          :label="$t('common.operate')"
          width="80px"
          fixed="right"
          v-if="menuStatus.update"
        >
          <template slot-scope="scope">
            <!-- <el-button type="primary" size="small">修改</el-button> -->
@@ -189,7 +198,7 @@
              type="warning"
              @click="editInfo(scope.row)"
              size="mini"
              >{{ $t("common.edit") }}</el-button
              >{{ $t('common.edit') }}</el-button
            >
          </template>
        </el-table-column>
@@ -448,8 +457,8 @@
<script>
var encrypt = new JSEncrypt();
import { mapActions } from "vuex";
import MyBread from "../../components/MyBread.vue";
import { mapActions } from 'vuex';
import MyBread from '../../components/MyBread.vue';
import {
  queryDepTree,
  queryPageUser,
@@ -458,7 +467,7 @@
  updateUser,
  updatePwd,
  selectByUserid,
} from "../../api/api";
} from '../../api/api';
export default {
  //import引入的组件需要注入到对象中才能使用
  components: {
@@ -466,132 +475,137 @@
  },
  data() {
    let validName = (rule, value, callback) => {
      if (value === "" || value === null || value === undefined) {
        return callback(new Error("请输入密码"));
      if (value === '' || value === null || value === undefined) {
        return callback(new Error('请输入密码'));
      } else {
        callback();
      }
    };
    let validatePass = (rule, value, callback) => {
      if (value === "" || value === undefined) {
        callback(new Error("请再次输入密码"));
      if (value === '' || value === undefined) {
        callback(new Error('请再次输入密码'));
      } else if (value !== this.editForm.pwd) {
        callback(new Error("两次输入密码不一致!"));
        callback(new Error('两次输入密码不一致!'));
      } else {
        callback();
      }
    };
    let resetPass = (rule, value, callback) => {
      if (value === "" || value === undefined) {
        callback(new Error("请再次输入密码"));
      if (value === '' || value === undefined) {
        callback(new Error('请再次输入密码'));
      } else if (value !== this.pwdForm.newPwd) {
        callback(new Error("两次输入密码不一致!"));
        callback(new Error('两次输入密码不一致!'));
      } else {
        callback();
      }
    };
    return {
      menuStatus: {
        delete: false,
        insert: false,
        update: false,
      },
      isNewUser: false,
      currentPage: 1,
      pageSize: 10,
      pageIndex: 1,
      defaultProps: {
        children: "children",
        label: "name",
        children: 'children',
        label: 'name',
      },
      queryForm: {
        uname: "",
        uname: '',
        depid: null,
        depName: "",
        depName: '',
      },
      tableData: [],
      fullscreenLoading: false,
      count: 0,
      formLabelWidth: "100px",
      formLabelWidth: '100px',
      dialogFormVisible: false,
      initialForm: "",
      behavior: "",
      initialForm: '',
      behavior: '',
      multipleSelection: [],
      resetPwd: false,
      editForm: {
        uid: "",
        uname: "",
        oldPwd: "",
        pwd: "",
        checkPass: "",
        uid: '',
        uname: '',
        oldPwd: '',
        pwd: '',
        checkPass: '',
        sex: null,
        natives: "",
        natives: '',
        depid: null,
        idcard: "",
        job: "",
        edu: "",
        addr: "",
        email: "",
        contact: "",
        idcard: '',
        job: '',
        edu: '',
        addr: '',
        email: '',
        contact: '',
        status: null,
        bak: "",
        salt: "",
        bak: '',
        salt: '',
      },
      pwdForm: {
        adminPwd: "",
        newPwd: "",
        checkPwd: "",
        adminPwd: '',
        newPwd: '',
        checkPwd: '',
        ids: [],
      },
      treeOptions: [],
      statusOpt: [
        {
          value: 0,
          label: "正常",
          label: '正常',
        },
        {
          value: 1,
          label: "禁用",
          label: '禁用',
        },
        {
          value: 2,
          label: "删除",
          label: '删除',
        },
        {
          value: 3,
          label: "申请",
          label: '申请',
        },
        {
          value: 4,
          label: "拒批",
          label: '拒批',
        },
      ],
      depList: [],
      sexOpt: [
        {
          value: 0,
          label: "女",
          label: '女',
        },
        {
          value: 1,
          label: "男",
          label: '男',
        },
        {
          value: -1,
          label: "未知",
          label: '未知',
        },
      ],
      rules: {
        uid: [
          { required: true, validator: validName, trigger: "blur" },
          { required: true, validator: validName, trigger: 'blur' },
          {
            trigger: "blur",
            trigger: 'blur',
            validator: (rule, value, callback) => {
              var reg = new RegExp(/^[a-zA-Z0-9_]{0,15}$/); //字符串正则表达式 4到14位(字母,数字,下划线,减号)
              if (!reg.test(value)) {
                callback(
                  new Error("账号必须由字母,数字或下划线,长度不得超过16位")
                  new Error('账号必须由字母,数字或下划线,长度不得超过16位')
                );
              } else {
                selectByUserid({ uid: value }).then((res) => {
                  if (res.result != null) {
                    this.isNewUser = false;
                    callback(new Error("账号已存在"));
                    callback(new Error('账号已存在'));
                  } else {
                    this.isNewUser = true;
                    callback();
@@ -604,16 +618,16 @@
        pwd: [
          {
            required: true,
            message: "请输入密码",
            message: '请输入密码',
            transform: (value) => value,
            trigger: "blur",
            trigger: 'blur',
          },
          {
            type: "string",
            message: "请输入不包含空格的字符",
            trigger: "blur",
            type: 'string',
            message: '请输入不包含空格的字符',
            trigger: 'blur',
            transform(value) {
              if (value && value.indexOf(" ") === -1) {
              if (value && value.indexOf(' ') === -1) {
                return value;
              } else {
                return false;
@@ -621,14 +635,14 @@
            },
          },
          {
            trigger: "blur",
            trigger: 'blur',
            validator: (rule, value, callback) => {
              var regex = new RegExp("");
              var regex = new RegExp('');
              var passwordreg =
                /^(?![a-zA-Z]+$)(?![A-Z0-9]+$)(?![A-Z\W!@#$%^&*`~()\\-_+=,.?;<>]+$)(?![a-z0-9]+$)(?![a-z\W!@#$%^&*`~()\\-_+=,.?;<>]+$)(?![0-9\W!@#$%^&*`~()\\-_+=,.?;<>]+$)[a-zA-Z0-9\W!@#$%^&*`~()\\-_+=,.?;<>]{8,20}$/;
              if (!passwordreg.test(value)) {
                callback(
                  new Error("密码必须由数字、字母、特殊字符组合,请输入8-20位")
                  new Error('密码必须由数字、字母、特殊字符组合,请输入8-20位')
                );
              } else {
                callback();
@@ -637,21 +651,21 @@
          },
        ],
        checkPass: [
          { required: true, validator: validatePass, trigger: "blur" },
          { required: true, validator: validatePass, trigger: 'blur' },
        ],
        adminPwd: [{ validator: validName, trigger: "blur" }],
        adminPwd: [{ validator: validName, trigger: 'blur' }],
        newPwd: [
          {
            message: "请输入密码",
            message: '请输入密码',
            transform: (value) => value,
            trigger: "blur",
            trigger: 'blur',
          },
          {
            type: "string",
            message: "请输入不包含空格的字符",
            trigger: "blur",
            type: 'string',
            message: '请输入不包含空格的字符',
            trigger: 'blur',
            transform(value) {
              if (value && value.indexOf(" ") === -1) {
              if (value && value.indexOf(' ') === -1) {
                return value;
              } else {
                return false;
@@ -659,14 +673,14 @@
            },
          },
          {
            trigger: "blur",
            trigger: 'blur',
            validator: (rule, value, callback) => {
              var regex = new RegExp("");
              var regex = new RegExp('');
              var passwordreg =
                /^(?![a-zA-Z]+$)(?![A-Z0-9]+$)(?![A-Z\W!@#$%^&*`~()\\-_+=,.?;<>]+$)(?![a-z0-9]+$)(?![a-z\W!@#$%^&*`~()\\-_+=,.?;<>]+$)(?![0-9\W!@#$%^&*`~()\\-_+=,.?;<>]+$)[a-zA-Z0-9\W!@#$%^&*`~()\\-_+=,.?;<>]{8,20}$/;
              if (!passwordreg.test(value)) {
                callback(
                  new Error("密码必须由数字、字母、特殊字符组合,请输入8-20位")
                  new Error('密码必须由数字、字母、特殊字符组合,请输入8-20位')
                );
              } else {
                callback();
@@ -674,12 +688,12 @@
            },
          },
        ],
        checkPwd: [{ validator: resetPass, trigger: "blur" }],
        checkPwd: [{ validator: resetPass, trigger: 'blur' }],
      },
    };
  },
  methods: {
    ...mapActions(["login", "getpublickey"]),
    ...mapActions(['login', 'getpublickey']),
    getUserInfo(params) {
      queryDepTree()
        .then((res) => {
@@ -717,7 +731,7 @@
      return cloneData.filter((father) => {
        // 循环所有项
        let branchArr = cloneData.filter((child) => father.id == child.pid); // 对比ID,分别上下级菜单,并返回数据
        branchArr.length > 0 ? (father.children = branchArr) : ""; // 给父级添加一个children属性,并赋值
        branchArr.length > 0 ? (father.children = branchArr) : ''; // 给父级添加一个children属性,并赋值
        return father.pid == 0; // 返回一级菜单
      });
    },
@@ -738,7 +752,7 @@
          this.tableData = res.result;
          this.count = res.count;
        } else {
          console.log("查询接口报错");
          console.log('查询接口报错');
          this.$notify.error({
            title: res.code,
            message: res.result,
@@ -752,7 +766,7 @@
    },
    //新增按钮
    showAddDialog() {
      this.behavior = "新增用户";
      this.behavior = '新增用户';
      this.editForm = {};
      this.dialogFormVisible = true;
    },
@@ -778,8 +792,8 @@
                if (res.code == 200) {
                  this.getUserInfo(1, 10);
                  this.$message({
                    message: "添加成功",
                    type: "success",
                    message: '添加成功',
                    type: 'success',
                  });
                  this.editForm = {};
                  this.dialogFormVisible = false;
@@ -787,21 +801,21 @@
              }, 500);
            })
            .catch((res) => {
              alert("修改失败,请重试!");
              alert('修改失败,请重试!');
              this.fullscreenLoading = false;
            });
        } else {
          console.log("error submit!!");
          console.log('error submit!!');
          return false;
        }
      });
    },
    //删除按钮
    deleteUserInfo() {
      this.$confirm("此操作将删除已选中的用户, 是否继续?", "提示", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning",
      this.$confirm('此操作将删除已选中的用户, 是否继续?', '提示', {
        confirmButtonText: '确定',
        cancelButtonText: '取消',
        type: 'warning',
      })
        .then(() => {
          var std = [];
@@ -812,22 +826,22 @@
            .then((res) => {
              if (res.code == 200) {
                this.$message({
                  type: "success",
                  message: "删除成功!",
                  type: 'success',
                  message: '删除成功!',
                });
                this.multipleSelection = [];
                this.getUserInfo(1, 10);
              } else {
                this.$message.error("删除失败");
                this.$message.error('删除失败');
              }
            })
            .catch(() => {
              this.$message.error("删除失败");
              this.$message.error('删除失败');
              this.multipleSelection = [];
            });
        })
        .catch(() => {
          this.$message("已取消删除");
          this.$message('已取消删除');
        });
    },
    //重置密码
@@ -837,7 +851,7 @@
        std.push(this.multipleSelection[i].id);
      }
      if (std.length == 0) {
        alert("请先选择用户");
        alert('请先选择用户');
        return;
      }
      this.pwdForm.ids = std;
@@ -864,13 +878,13 @@
                if (res.code == 200) {
                  this.getUserInfo(1, 10);
                  this.$message({
                    message: "修改成功",
                    type: "success",
                    message: '修改成功',
                    type: 'success',
                  });
                  this.pwdForm = {
                    adminPwd: "",
                    newPwd: "",
                    checkPwd: "",
                    adminPwd: '',
                    newPwd: '',
                    checkPwd: '',
                    ids: [],
                  };
                  this.multipleSelection = [];
@@ -879,7 +893,7 @@
              }, 500);
            })
            .catch((res) => {
              alert("修改失败,请重试!");
              alert('修改失败,请重试!');
              this.fullscreenLoading = false;
            });
        } else {
@@ -891,9 +905,9 @@
    editInfo(row) {
      delete row.updateTime;
      delete row.updateUser;
      row.pwd = "";
      row.pwd = '';
      this.initialForm = JSON.stringify(row);
      this.behavior = "修改信息";
      this.behavior = '修改信息';
      this.editForm = JSON.parse(JSON.stringify(row));
      this.dialogFormVisible = true;
    },
@@ -903,31 +917,31 @@
    },
    //关闭弹出框
    handleClose(done) {
      this.$confirm("确认关闭?")
      this.$confirm('确认关闭?')
        .then((_) => {
          this.editForm = {
            uid: "",
            uname: "",
            oldPwd: "",
            pwd: "",
            checkPass: "",
            uid: '',
            uname: '',
            oldPwd: '',
            pwd: '',
            checkPass: '',
            sex: null,
            natives: "",
            natives: '',
            depid: null,
            idcard: "",
            job: "",
            edu: "",
            addr: "",
            email: "",
            contact: "",
            idcard: '',
            job: '',
            edu: '',
            addr: '',
            email: '',
            contact: '',
            status: null,
            bak: "",
            salt: "",
            bak: '',
            salt: '',
          };
          this.pwdForm = {
            adminPwd: "",
            newPwd: "",
            checkPwd: "",
            adminPwd: '',
            newPwd: '',
            checkPwd: '',
            ids: [],
          };
@@ -953,8 +967,8 @@
                if (res.code == 200) {
                  this.getUserInfo(1, 10);
                  this.$message({
                    message: "修改成功",
                    type: "success",
                    message: '修改成功',
                    type: 'success',
                  });
                  this.editForm = {};
                  this.dialogFormVisible = false;
@@ -962,11 +976,11 @@
              }, 500);
            })
            .catch((res) => {
              alert("修改失败,请重试!");
              alert('修改失败,请重试!');
              this.fullscreenLoading = false;
            });
        } else {
          console.log("error submit!!");
          console.log('error submit!!');
          return false;
        }
      });
@@ -991,11 +1005,34 @@
      this.currentPage = val;
      this.queryInfo();
    },
    showPermsMenu(res) {
      console.log(res.tag);
      switch (res.tag) {
        case '/delete':
          this.menuStatus.delete = true;
          break;
        case '/insert':
          this.menuStatus.insert = true;
          break;
        case '/update':
          this.menuStatus.update = true;
          break;
      }
    },
  },
  mounted() {
    this.getUserInfo(1, 10);
    this.getpublickey();
  },
  created() {
    var val = this.$store.state.currentPerms;
    var permsEntity = this.$store.state.permsEntity;
    for (var i = 0; i < permsEntity.length; i++) {
      if (permsEntity[i].perms == val) {
        this.showPermsMenu(permsEntity[i]);
      }
    }
  },
};
</script>
<style>