add.vue 5.43 KB
Newer Older
xulili's avatar
xulili committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43
<template>
  <el-dialog
    custom-class="party-dialog"
    title="新建账号"
    :visible.sync="dialogVisible"
    width="720px"
    :before-close="handleClose"
  >
    <div class="dialog-content">
      <el-form
        ref="form"
        :model="form"
        :rules="rules"
        label-width="80px"
        label-position="top"
        class="party-form"
      >
        <div class="form-row">
          <el-form-item label="系统用户名" prop="userName">
            <el-input v-model="form.userName" placeholder="请填写"></el-input>
          </el-form-item>
          <el-form-item label="所在机构" prop="orgId">
            <el-select v-model="form.orgId" filterable placeholder="请选择">
              <el-option
                v-for="item in organList"
                :key="item.id"
                :label="item.name"
                :value="item.id"
              >
              </el-option>
            </el-select>
          </el-form-item>
        </div>
        <el-form-item label="账号有效期" prop="permanent">
          <el-radio-group v-model="form.permanent">
            <el-radio :label="true">永久有效</el-radio>
            <el-radio :label="false">设置有效期</el-radio>
          </el-radio-group>
          <div v-if="!form.permanent">
            <el-date-picker
              class="mt16"
              v-model="form.date"
              type="daterange"
xulili's avatar
xulili committed
44
              value-format="yyyy-MM-dd"
xulili's avatar
xulili committed
45 46
              range-separator="至"
              start-placeholder="开始日期"
xulili's avatar
xulili committed
47 48
              end-placeholder="结束日期"
            >
xulili's avatar
xulili committed
49 50 51 52 53 54
            </el-date-picker>
          </div>
        </el-form-item>
        <el-form-item label="账号类型" prop="roleList">
          <el-checkbox-group v-model="form.roleList" :min="1">
            <el-checkbox
xulili's avatar
xulili committed
55
              v-for="(item, index) in rolesList"
xulili's avatar
xulili committed
56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81
              :key="index"
              :label="item.id"
            >
              {{ item.name }}
            </el-checkbox>
          </el-checkbox-group>
        </el-form-item>
      </el-form>
    </div>
    <div slot="footer" class="dialog-footer btn-group">
      <el-button @click="handleClose()">取 消</el-button>
      <el-button type="primary" @click="handleSubmit()">确 定</el-button>
    </div>
  </el-dialog>
</template>
<script>
export default {
  data() {
    return {
      dialogVisible: false,
      form: {
        userName: "",
        orgId: "",
        permanent: true,
        date: "",
        roleList: [],
xulili's avatar
xulili committed
82
        type: 1, //1.用户账号 2.平台单位单位管理员账号 3.机顶盒账号 4.运维账号
xulili's avatar
xulili committed
83 84 85 86 87 88 89 90 91 92 93
      },
      rules: {
        userName: [
          { required: true, message: "请选择系统用户名", trigger: "change" },
        ],
        orgId: [
          { required: true, message: "请输入所在机构", trigger: "change" },
        ],
        permanent: [
          { required: true, message: "请选择账号有效期", trigger: "change" },
        ],
xulili's avatar
xulili committed
94 95 96 97 98 99 100 101
        roleList: [
          {
            type: "array",
            required: true,
            message: "请选择账号类型",
            trigger: "change",
          },
        ],
xulili's avatar
xulili committed
102 103 104
      },
    };
  },
xulili's avatar
xulili committed
105 106 107 108 109 110
  props: {
    organList: {
      type: Array,
      default: () => {
        return [];
      },
xulili's avatar
xulili committed
111
    },
xulili's avatar
xulili committed
112 113 114 115 116
    rolesList: {
      type: Array,
      default: () => {
        return [];
      },
xulili's avatar
xulili committed
117
    },
xulili's avatar
xulili committed
118 119 120
  },
  mounted() {},
  methods: {
xulili's avatar
xulili committed
121 122 123 124
    // 弹窗关闭
    handleClose() {
      this.$confirm("确认关闭?")
        .then((_) => {
xulili's avatar
xulili committed
125
          this.handleReset();
xulili's avatar
xulili committed
126 127 128
        })
        .catch((_) => {});
    },
xulili's avatar
xulili committed
129 130 131 132 133 134 135 136 137 138 139
    handleReset() {
      this.dialogVisible = false;
      this.$refs.form.resetFields();
      this.form = {
        userName: "",
        orgId: "",
        permanent: true,
        date: "",
        roleList: [],
        type: 1,
      };
xulili's avatar
xulili committed
140 141
    },
    // 提交
xulili's avatar
xulili committed
142
    handleSubmit() {
xulili's avatar
xulili committed
143 144 145
      // 校验用户输入值
      this.$refs.form.validate((valid) => {
        if (valid) {
xulili's avatar
xulili committed
146 147 148 149 150 151 152 153
          let user = {};
          if (!this.form.permanent && !this.form.date) {
            this.$message.error("请选择有效期");
            return false;
          }
          if (!this.form.permanent) {
            user.effectiveDate = this.form.date[0];
            user.exiredDate = this.form.date[1];
xulili's avatar
xulili committed
154 155 156
          }
          user.userName = this.form.userName;
          user.orgId = this.form.orgId;
xulili's avatar
xulili committed
157
          user.roleList = this.form.roleList;
xulili's avatar
xulili committed
158
          user.permanent = this.form.permanent;
xulili's avatar
xulili committed
159
          user.type = this.form.type;
xulili's avatar
xulili committed
160 161 162 163 164 165 166 167 168
          this.$https(
            {
              method: "post",
              url: "tUser/add",
              authType: this.backToken,
            },
            user
          )
            .then((res) => {
xulili's avatar
xulili committed
169 170 171 172 173 174 175 176
              if (res.status == 200) {
                if (res.data.resultCode == 200) {
                  this.$message({
                    type: "success",
                    message: res.data.message,
                  });
                  this.handleReset();
                  this.$emit("success", true);
xulili's avatar
xulili committed
177
                } else {
xulili's avatar
xulili committed
178 179
                  this.$message.error(res.data.message);
                }
xulili's avatar
xulili committed
180
              } else {
xulili's avatar
xulili committed
181 182
                this.$message.error(res.data);
              }
xulili's avatar
xulili committed
183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201
            })
            .catch((err) => {
              console.log(res);
            });
        } else {
          console.log("error submit!!");
          return false;
        }
      });
    },
  },
};
</script>
<style lang="less" scoped>
.form-row {
  display: flex;
  justify-content: space-between;
}
</style>