mirror of
				https://gitee.com/hhyykk/ipms-sjy.git
				synced 2025-11-04 04:08:43 +08:00 
			
		
		
		
	Merge branch 'master' of https://gitee.com/zhijiantianya/ruoyi-vue-pro into feature/activiti
Conflicts: sql/ruoyi-vue-pro.sql yudao-admin-server/src/main/resources/application.yaml yudao-admin-server/src/main/resources/mybatis-config/mybatis-config.xml yudao-framework/yudao-spring-boot-starter-security/src/main/java/cn/iocoder/yudao/framework/security/core/LoginUser.java yudao-framework/yudao-spring-boot-starter-security/src/main/java/cn/iocoder/yudao/framework/security/core/util/SecurityFrameworkUtils.java
This commit is contained in:
		@@ -2,6 +2,11 @@
 | 
			
		||||
  <div class="login">
 | 
			
		||||
    <el-form ref="loginForm" :model="loginForm" :rules="loginRules" class="login-form">
 | 
			
		||||
      <h3 class="title">芋道后台管理系统</h3>
 | 
			
		||||
      <el-form-item prop="tenantName">
 | 
			
		||||
        <el-input v-model="loginForm.tenantName" type="text" auto-complete="off" placeholder='租户'>
 | 
			
		||||
          <svg-icon slot="prefix" icon-class="tree" class="el-input__icon input-icon" />
 | 
			
		||||
        </el-input>
 | 
			
		||||
      </el-form-item>
 | 
			
		||||
      <el-form-item prop="username">
 | 
			
		||||
        <el-input v-model="loginForm.username" type="text" auto-complete="off" placeholder="账号">
 | 
			
		||||
          <svg-icon slot="prefix" icon-class="user" class="el-input__icon input-icon" />
 | 
			
		||||
@@ -46,6 +51,7 @@
 | 
			
		||||
 | 
			
		||||
<script>
 | 
			
		||||
import { getCodeImg,socialAuthRedirect } from "@/api/login";
 | 
			
		||||
import { getTenantIdByName } from "@/api/system/tenant";
 | 
			
		||||
import Cookies from "js-cookie";
 | 
			
		||||
import { encrypt, decrypt } from '@/utils/jsencrypt'
 | 
			
		||||
import {InfApiErrorLogProcessStatusEnum, SysUserSocialTypeEnum} from "@/utils/constants";
 | 
			
		||||
@@ -60,9 +66,29 @@ export default {
 | 
			
		||||
        password: "admin123",
 | 
			
		||||
        rememberMe: false,
 | 
			
		||||
        code: "",
 | 
			
		||||
        uuid: ""
 | 
			
		||||
        uuid: "",
 | 
			
		||||
        tenantName: "芋道源码",
 | 
			
		||||
      },
 | 
			
		||||
      loginRules: {
 | 
			
		||||
        tenantName: [
 | 
			
		||||
          { required: true, trigger: "blur", message: "租户不能为空" },
 | 
			
		||||
          {
 | 
			
		||||
            validator: (rule, value, callback) => {
 | 
			
		||||
              // debugger
 | 
			
		||||
              getTenantIdByName(value).then(res => {
 | 
			
		||||
                const tenantId = res.data;
 | 
			
		||||
                if (tenantId >= 0) {
 | 
			
		||||
                  // 设置租户
 | 
			
		||||
                  Cookies.set("tenantId", tenantId);
 | 
			
		||||
                  callback();
 | 
			
		||||
                } else {
 | 
			
		||||
                  callback('租户不存在');
 | 
			
		||||
                }
 | 
			
		||||
              });
 | 
			
		||||
            },
 | 
			
		||||
            trigger: 'blur'
 | 
			
		||||
          }
 | 
			
		||||
        ],
 | 
			
		||||
        username: [
 | 
			
		||||
          { required: true, trigger: "blur", message: "用户名不能为空" }
 | 
			
		||||
        ],
 | 
			
		||||
@@ -103,25 +129,31 @@ export default {
 | 
			
		||||
      const username = Cookies.get("username");
 | 
			
		||||
      const password = Cookies.get("password");
 | 
			
		||||
      const rememberMe = Cookies.get('rememberMe')
 | 
			
		||||
      const tenantName = Cookies.get('tenantName');
 | 
			
		||||
      this.loginForm = {
 | 
			
		||||
        username: username === undefined ? this.loginForm.username : username,
 | 
			
		||||
        password: password === undefined ? this.loginForm.password : decrypt(password),
 | 
			
		||||
        rememberMe: rememberMe === undefined ? false : Boolean(rememberMe)
 | 
			
		||||
        rememberMe: rememberMe === undefined ? false : Boolean(rememberMe),
 | 
			
		||||
        tenantName: tenantName === undefined ? this.loginForm.tenantName : tenantName,
 | 
			
		||||
      };
 | 
			
		||||
    },
 | 
			
		||||
    handleLogin() {
 | 
			
		||||
      this.$refs.loginForm.validate(valid => {
 | 
			
		||||
        if (valid) {
 | 
			
		||||
          this.loading = true;
 | 
			
		||||
          // 设置 Cookie
 | 
			
		||||
          if (this.loginForm.rememberMe) {
 | 
			
		||||
            Cookies.set("username", this.loginForm.username, { expires: 30 });
 | 
			
		||||
            Cookies.set("password", encrypt(this.loginForm.password), { expires: 30 });
 | 
			
		||||
            Cookies.set('rememberMe', this.loginForm.rememberMe, { expires: 30 });
 | 
			
		||||
            Cookies.set('tenantName', this.loginForm.tenantName, { expires: 30 });
 | 
			
		||||
          } else {
 | 
			
		||||
            Cookies.remove("username");
 | 
			
		||||
            Cookies.remove("password");
 | 
			
		||||
            Cookies.remove('rememberMe');
 | 
			
		||||
            Cookies.remove('tenantName');
 | 
			
		||||
          }
 | 
			
		||||
          // 发起登陆
 | 
			
		||||
          this.$store.dispatch("Login", this.loginForm).then(() => {
 | 
			
		||||
            this.$router.push({ path: this.redirect || "/" }).catch(()=>{});
 | 
			
		||||
          }).catch(() => {
 | 
			
		||||
@@ -167,7 +199,7 @@ export default {
 | 
			
		||||
.login-form {
 | 
			
		||||
  border-radius: 6px;
 | 
			
		||||
  background: #ffffff;
 | 
			
		||||
  width: 400px;
 | 
			
		||||
  width: 500px;
 | 
			
		||||
  padding: 25px 25px 5px 25px;
 | 
			
		||||
  .el-input {
 | 
			
		||||
    height: 38px;
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										259
									
								
								yudao-admin-ui/src/views/system/tenant/index.vue
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										259
									
								
								yudao-admin-ui/src/views/system/tenant/index.vue
									
									
									
									
									
										Executable file
									
								
							@@ -0,0 +1,259 @@
 | 
			
		||||
<template>
 | 
			
		||||
  <div class="app-container">
 | 
			
		||||
 | 
			
		||||
    <!-- 搜索工作栏 -->
 | 
			
		||||
    <el-form :model="queryParams" ref="queryForm" :inline="true" v-show="showSearch" label-width="68px">
 | 
			
		||||
      <el-form-item label="租户名" prop="name">
 | 
			
		||||
        <el-input v-model="queryParams.name" placeholder="请输入租户名" clearable size="small" @keyup.enter.native="handleQuery"/>
 | 
			
		||||
      </el-form-item>
 | 
			
		||||
      <el-form-item label="联系人" prop="contactName">
 | 
			
		||||
        <el-input v-model="queryParams.contactName" placeholder="请输入联系人" clearable size="small" @keyup.enter.native="handleQuery"/>
 | 
			
		||||
      </el-form-item>
 | 
			
		||||
      <el-form-item label="联系手机" prop="contactMobile">
 | 
			
		||||
        <el-input v-model="queryParams.contactMobile" placeholder="请输入联系手机" clearable size="small" @keyup.enter.native="handleQuery"/>
 | 
			
		||||
      </el-form-item>
 | 
			
		||||
      <el-form-item label="租户状态" prop="status">
 | 
			
		||||
        <el-select v-model="queryParams.status" placeholder="请选择租户状态" clearable size="small">
 | 
			
		||||
          <el-option v-for="dict in this.getDictDatas(DICT_TYPE.SYS_COMMON_STATUS)"
 | 
			
		||||
                       :key="dict.value" :label="dict.label" :value="dict.value"/>
 | 
			
		||||
        </el-select>
 | 
			
		||||
      </el-form-item>
 | 
			
		||||
      <el-form-item label="创建时间">
 | 
			
		||||
        <el-date-picker v-model="dateRangeCreateTime" size="small" style="width: 240px" value-format="yyyy-MM-dd"
 | 
			
		||||
                        type="daterange" range-separator="-" start-placeholder="开始日期" end-placeholder="结束日期" />
 | 
			
		||||
      </el-form-item>
 | 
			
		||||
      <el-form-item>
 | 
			
		||||
        <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
 | 
			
		||||
        <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
 | 
			
		||||
      </el-form-item>
 | 
			
		||||
    </el-form>
 | 
			
		||||
 | 
			
		||||
    <!-- 操作工具栏 -->
 | 
			
		||||
    <el-row :gutter="10" class="mb8">
 | 
			
		||||
      <el-col :span="1.5">
 | 
			
		||||
        <el-button type="primary" plain icon="el-icon-plus" size="mini" @click="handleAdd"
 | 
			
		||||
                   v-hasPermi="['system:tenant:create']">新增</el-button>
 | 
			
		||||
      </el-col>
 | 
			
		||||
      <el-col :span="1.5">
 | 
			
		||||
        <el-button type="warning" plain icon="el-icon-download" size="mini" @click="handleExport"
 | 
			
		||||
                   v-hasPermi="['system:tenant:export']">导出</el-button>
 | 
			
		||||
      </el-col>
 | 
			
		||||
      <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
 | 
			
		||||
    </el-row>
 | 
			
		||||
 | 
			
		||||
    <!-- 列表 -->
 | 
			
		||||
    <el-table v-loading="loading" :data="list">
 | 
			
		||||
      <el-table-column label="租户编号" align="center" prop="id" />
 | 
			
		||||
      <el-table-column label="租户名" align="center" prop="name" />
 | 
			
		||||
      <el-table-column label="联系人" align="center" prop="contactName" />
 | 
			
		||||
      <el-table-column label="联系手机" align="center" prop="contactMobile" />
 | 
			
		||||
      <el-table-column label="租户状态" align="center" prop="status">
 | 
			
		||||
        <template slot-scope="scope">
 | 
			
		||||
          <span>{{ getDictDataLabel(DICT_TYPE.SYS_COMMON_STATUS, scope.row.status) }}</span>
 | 
			
		||||
        </template>
 | 
			
		||||
      </el-table-column>
 | 
			
		||||
      <el-table-column label="创建时间" align="center" prop="createTime" width="180">
 | 
			
		||||
        <template slot-scope="scope">
 | 
			
		||||
          <span>{{ parseTime(scope.row.createTime) }}</span>
 | 
			
		||||
        </template>
 | 
			
		||||
      </el-table-column>
 | 
			
		||||
      <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
 | 
			
		||||
        <template slot-scope="scope">
 | 
			
		||||
          <el-button size="mini" type="text" icon="el-icon-edit" @click="handleUpdate(scope.row)"
 | 
			
		||||
                     v-hasPermi="['system:tenant:update']">修改</el-button>
 | 
			
		||||
          <el-button size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)"
 | 
			
		||||
                     v-hasPermi="['system:tenant:delete']">删除</el-button>
 | 
			
		||||
        </template>
 | 
			
		||||
      </el-table-column>
 | 
			
		||||
    </el-table>
 | 
			
		||||
    <!-- 分页组件 -->
 | 
			
		||||
    <pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNo" :limit.sync="queryParams.pageSize"
 | 
			
		||||
                @pagination="getList"/>
 | 
			
		||||
 | 
			
		||||
    <!-- 对话框(添加 / 修改) -->
 | 
			
		||||
    <el-dialog :title="title" :visible.sync="open" width="500px" append-to-body>
 | 
			
		||||
      <el-form ref="form" :model="form" :rules="rules" label-width="80px">
 | 
			
		||||
        <el-form-item label="租户名" prop="name">
 | 
			
		||||
          <el-input v-model="form.name" placeholder="请输入租户名" />
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
        <el-form-item label="联系人" prop="contactName">
 | 
			
		||||
          <el-input v-model="form.contactName" placeholder="请输入联系人" />
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
        <el-form-item label="联系手机" prop="contactMobile">
 | 
			
		||||
          <el-input v-model="form.contactMobile" placeholder="请输入联系手机" />
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
        <el-form-item label="租户状态" prop="status">
 | 
			
		||||
          <el-radio-group v-model="form.status">
 | 
			
		||||
            <el-radio v-for="dict in this.getDictDatas(DICT_TYPE.SYS_COMMON_STATUS)"
 | 
			
		||||
                      :key="dict.value" :label="parseInt(dict.value)">{{dict.label}}</el-radio>
 | 
			
		||||
          </el-radio-group>
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
      </el-form>
 | 
			
		||||
      <div slot="footer" class="dialog-footer">
 | 
			
		||||
        <el-button type="primary" @click="submitForm">确 定</el-button>
 | 
			
		||||
        <el-button @click="cancel">取 消</el-button>
 | 
			
		||||
      </div>
 | 
			
		||||
    </el-dialog>
 | 
			
		||||
  </div>
 | 
			
		||||
</template>
 | 
			
		||||
 | 
			
		||||
<script>
 | 
			
		||||
import { createTenant, updateTenant, deleteTenant, getTenant, getTenantPage, exportTenantExcel } from "@/api/system/tenant";
 | 
			
		||||
import { SysCommonStatusEnum } from '@/utils/constants'
 | 
			
		||||
 | 
			
		||||
export default {
 | 
			
		||||
  name: "Tenant",
 | 
			
		||||
  components: {
 | 
			
		||||
  },
 | 
			
		||||
  data() {
 | 
			
		||||
    return {
 | 
			
		||||
      // 遮罩层
 | 
			
		||||
      loading: true,
 | 
			
		||||
      // 显示搜索条件
 | 
			
		||||
      showSearch: true,
 | 
			
		||||
      // 总条数
 | 
			
		||||
      total: 0,
 | 
			
		||||
      // 租户列表
 | 
			
		||||
      list: [],
 | 
			
		||||
      // 弹出层标题
 | 
			
		||||
      title: "",
 | 
			
		||||
      // 是否显示弹出层
 | 
			
		||||
      open: false,
 | 
			
		||||
      dateRangeCreateTime: [],
 | 
			
		||||
      // 查询参数
 | 
			
		||||
      queryParams: {
 | 
			
		||||
        pageNo: 1,
 | 
			
		||||
        pageSize: 10,
 | 
			
		||||
        name: null,
 | 
			
		||||
        contactName: null,
 | 
			
		||||
        contactMobile: null,
 | 
			
		||||
        status: undefined,
 | 
			
		||||
      },
 | 
			
		||||
      // 表单参数
 | 
			
		||||
      form: {},
 | 
			
		||||
      // 表单校验
 | 
			
		||||
      rules: {
 | 
			
		||||
        name: [{ required: true, message: "租户名不能为空", trigger: "blur" }],
 | 
			
		||||
        contactName: [{ required: true, message: "联系人不能为空", trigger: "blur" }],
 | 
			
		||||
        status: [{ required: true, message: "租户状态(0正常 1停用)不能为空", trigger: "blur" }],
 | 
			
		||||
      }
 | 
			
		||||
    };
 | 
			
		||||
  },
 | 
			
		||||
  created() {
 | 
			
		||||
    this.getList();
 | 
			
		||||
  },
 | 
			
		||||
  methods: {
 | 
			
		||||
    /** 查询列表 */
 | 
			
		||||
    getList() {
 | 
			
		||||
      this.loading = true;
 | 
			
		||||
      // 处理查询参数
 | 
			
		||||
      let params = {...this.queryParams};
 | 
			
		||||
      this.addBeginAndEndTime(params, this.dateRangeCreateTime, 'createTime');
 | 
			
		||||
      // 执行查询
 | 
			
		||||
      getTenantPage(params).then(response => {
 | 
			
		||||
        this.list = response.data.list;
 | 
			
		||||
        this.total = response.data.total;
 | 
			
		||||
        this.loading = false;
 | 
			
		||||
      });
 | 
			
		||||
    },
 | 
			
		||||
    /** 取消按钮 */
 | 
			
		||||
    cancel() {
 | 
			
		||||
      this.open = false;
 | 
			
		||||
      this.reset();
 | 
			
		||||
    },
 | 
			
		||||
    /** 表单重置 */
 | 
			
		||||
    reset() {
 | 
			
		||||
      this.form = {
 | 
			
		||||
        id: undefined,
 | 
			
		||||
        name: undefined,
 | 
			
		||||
        contactName: undefined,
 | 
			
		||||
        contactMobile: undefined,
 | 
			
		||||
        status: SysCommonStatusEnum.ENABLE,
 | 
			
		||||
      };
 | 
			
		||||
      this.resetForm("form");
 | 
			
		||||
    },
 | 
			
		||||
    /** 搜索按钮操作 */
 | 
			
		||||
    handleQuery() {
 | 
			
		||||
      this.queryParams.pageNo = 1;
 | 
			
		||||
      this.getList();
 | 
			
		||||
    },
 | 
			
		||||
    /** 重置按钮操作 */
 | 
			
		||||
    resetQuery() {
 | 
			
		||||
      this.dateRangeCreateTime = [];
 | 
			
		||||
      this.resetForm("queryForm");
 | 
			
		||||
      this.handleQuery();
 | 
			
		||||
    },
 | 
			
		||||
    /** 新增按钮操作 */
 | 
			
		||||
    handleAdd() {
 | 
			
		||||
      this.reset();
 | 
			
		||||
      this.open = true;
 | 
			
		||||
      this.title = "添加租户";
 | 
			
		||||
    },
 | 
			
		||||
    /** 修改按钮操作 */
 | 
			
		||||
    handleUpdate(row) {
 | 
			
		||||
      this.reset();
 | 
			
		||||
      const id = row.id;
 | 
			
		||||
      getTenant(id).then(response => {
 | 
			
		||||
        this.form = response.data;
 | 
			
		||||
        this.open = true;
 | 
			
		||||
        this.title = "修改租户";
 | 
			
		||||
      });
 | 
			
		||||
    },
 | 
			
		||||
    /** 提交按钮 */
 | 
			
		||||
    submitForm() {
 | 
			
		||||
      this.$refs["form"].validate(valid => {
 | 
			
		||||
        if (!valid) {
 | 
			
		||||
          return;
 | 
			
		||||
        }
 | 
			
		||||
        // 修改的提交
 | 
			
		||||
        if (this.form.id != null) {
 | 
			
		||||
          updateTenant(this.form).then(response => {
 | 
			
		||||
            this.msgSuccess("修改成功");
 | 
			
		||||
            this.open = false;
 | 
			
		||||
            this.getList();
 | 
			
		||||
          });
 | 
			
		||||
          return;
 | 
			
		||||
        }
 | 
			
		||||
        // 添加的提交
 | 
			
		||||
        createTenant(this.form).then(response => {
 | 
			
		||||
          this.msgSuccess("新增成功");
 | 
			
		||||
          this.open = false;
 | 
			
		||||
          this.getList();
 | 
			
		||||
        });
 | 
			
		||||
      });
 | 
			
		||||
    },
 | 
			
		||||
    /** 删除按钮操作 */
 | 
			
		||||
    handleDelete(row) {
 | 
			
		||||
      const id = row.id;
 | 
			
		||||
      this.$confirm('是否确认删除租户编号为"' + id + '"的数据项?', "警告", {
 | 
			
		||||
          confirmButtonText: "确定",
 | 
			
		||||
          cancelButtonText: "取消",
 | 
			
		||||
          type: "warning"
 | 
			
		||||
        }).then(function() {
 | 
			
		||||
          return deleteTenant(id);
 | 
			
		||||
        }).then(() => {
 | 
			
		||||
          this.getList();
 | 
			
		||||
          this.msgSuccess("删除成功");
 | 
			
		||||
        })
 | 
			
		||||
    },
 | 
			
		||||
    /** 导出按钮操作 */
 | 
			
		||||
    handleExport() {
 | 
			
		||||
      // 处理查询参数
 | 
			
		||||
      let params = {...this.queryParams};
 | 
			
		||||
      params.pageNo = undefined;
 | 
			
		||||
      params.pageSize = undefined;
 | 
			
		||||
      this.addBeginAndEndTime(params, this.dateRangeCreateTime, 'createTime');
 | 
			
		||||
      // 执行导出
 | 
			
		||||
      this.$confirm('是否确认导出所有租户数据项?', "警告", {
 | 
			
		||||
          confirmButtonText: "确定",
 | 
			
		||||
          cancelButtonText: "取消",
 | 
			
		||||
          type: "warning"
 | 
			
		||||
        }).then(function() {
 | 
			
		||||
          return exportTenantExcel(params);
 | 
			
		||||
        }).then(response => {
 | 
			
		||||
          this.downloadExcel(response, '租户.xls');
 | 
			
		||||
        })
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
};
 | 
			
		||||
</script>
 | 
			
		||||
		Reference in New Issue
	
	Block a user