This commit is contained in:
2023-06-30 17:26:47 +08:00
parent cf3fed6448
commit 6cfa15b7ee

View File

@ -86,7 +86,7 @@
</el-col>
<el-col :span="1.5">
<el-button
:disabled="single || ids[0].initialized === '1'"
:disabled="single || isInit(ids[0])"
icon="Refresh"
plain
type="primary"
@ -105,10 +105,10 @@
:data="tenantList"
@selection-change="handleSelectionChange"
>
<el-table-column align="center" type="selection" width="55" />
<el-table-column align="center" label="公司名称" prop="companyName" />
<el-table-column align="center" label="联系人名称" prop="contactName" />
<el-table-column align="center" label="联系人电话" prop="contactPhone" />
<el-table-column align="center" type="selection" width="55"/>
<el-table-column align="center" label="公司名称" prop="companyName"/>
<el-table-column align="center" label="联系人名称" prop="contactName"/>
<el-table-column align="center" label="联系人电话" prop="contactPhone"/>
<el-table-column
align="center"
label="过期时间"
@ -119,10 +119,10 @@
<span>{{ parseTime(scope.row.expireTime, "{y}-{m}-{d}") }}</span>
</template>
</el-table-column>
<el-table-column align="center" label="用户数量" prop="accountCount" />
<el-table-column align="center" label="用户数量" prop="accountCount"/>
<el-table-column align="center" label="状态">
<template #default="{ row }">
<dict-tag :options="tenantStatusDict" :value="row.status" />
<dict-tag :options="tenantStatusDict" :value="row.status"/>
</template>
</el-table-column>
<el-table-column align="center" label="初始化状态">
@ -130,12 +130,12 @@
<!-- <el-tag :type="row.initialized === '1' ? 'success' : 'warning'"-->
<!-- >{{ row.initialized === "1" ? "是" : "否" }}-->
<!-- </el-tag>-->
<dict-tag :options="initStatusDict" :value="row.initialized" />
<dict-tag :options="initStatusDict" :value="row.initialized"/>
</template>
</el-table-column>
<el-table-column align="center" label="模式">
<template #default="{ row }">
<dict-tag :options="tenantModeDict" :value="row.mode" />
<dict-tag :options="tenantModeDict" :value="row.mode"/>
</template>
</el-table-column>
<el-table-column
@ -207,10 +207,10 @@
>
<el-form ref="tenantRef" :model="form" :rules="rules" label-width="130px">
<el-form-item label="公司名称" prop="companyName">
<el-input v-model="form.companyName" placeholder="请输入公司名称" />
<el-input v-model="form.companyName" placeholder="请输入公司名称"/>
</el-form-item>
<el-form-item label="联系人名称" prop="contactName">
<el-input v-model="form.contactName" placeholder="请输入联系人名称" />
<el-input v-model="form.contactName" placeholder="请输入联系人名称"/>
</el-form-item>
<el-form-item label="联系人电话" prop="contactPhone">
<el-input
@ -219,7 +219,7 @@
/>
</el-form-item>
<el-form-item label="公司地址" prop="address">
<el-input v-model="form.address" placeholder="请输入公司地址" />
<el-input v-model="form.address" placeholder="请输入公司地址"/>
</el-form-item>
<el-form-item label="公司简介" prop="profile">
<el-input
@ -245,7 +245,7 @@
</el-date-picker>
</el-form-item>
<el-form-item label="用户数量" prop="accountCount">
<el-input v-model="form.accountCount" placeholder="请输入用户数量" />
<el-input v-model="form.accountCount" placeholder="请输入用户数量"/>
</el-form-item>
<el-form-item label="备注" prop="remark">
<el-input
@ -326,7 +326,7 @@
</el-select>
</el-form-item>
<el-form-item label="数据库IP" prop="ip">
<el-input v-model="dataSourceForm.ip" />
<el-input v-model="dataSourceForm.ip"/>
</el-form-item>
<el-form-item label="数据库端口" prop="port">
<el-input-number
@ -336,7 +336,7 @@
/>
</el-form-item>
<el-form-item label="数据库名称" prop="dbName">
<el-input v-model="dataSourceForm.dbName" />
<el-input v-model="dataSourceForm.dbName"/>
</el-form-item>
<!-- schemaName 模式名称 仅当数据库类型不是Mysql时显示 -->
<el-form-item
@ -344,13 +344,13 @@
label="模式名称"
prop="schemaName"
>
<el-input v-model="dataSourceForm.schemaName" />
<el-input v-model="dataSourceForm.schemaName"/>
</el-form-item>
<el-form-item label="数据库账号" prop="username">
<el-input v-model="dataSourceForm.username" />
<el-input v-model="dataSourceForm.username"/>
</el-form-item>
<el-form-item label="数据库密码" prop="password">
<el-input v-model="dataSourceForm.password" />
<el-input v-model="dataSourceForm.password"/>
</el-form-item>
<el-form-item label="使用" prop="isPrimary">
<el-switch
@ -370,7 +370,7 @@
showDatasourceAdvanced ? 90 : 0
}deg);transition: all 0.3s;`"
>
<ArrowRight />
<ArrowRight/>
</el-icon>
<span>
<!-- 显示或隐藏高级选项 -->
@ -382,13 +382,13 @@
<div v-if="showDatasourceAdvanced">
<!-- initCount minCount maxCount -->
<el-form-item label="初始化连接数" prop="initCount">
<el-input-number v-model="dataSourceForm.initCount" :min="0" />
<el-input-number v-model="dataSourceForm.initCount" :min="0"/>
</el-form-item>
<el-form-item label="最小连接数" prop="minCount">
<el-input-number v-model="dataSourceForm.minCount" :min="0" />
<el-input-number v-model="dataSourceForm.minCount" :min="0"/>
</el-form-item>
<el-form-item label="最大连接数" prop="maxCount">
<el-input-number v-model="dataSourceForm.maxCount" :min="0" />
<el-input-number v-model="dataSourceForm.maxCount" :min="0"/>
</el-form-item>
</div>
</Transition>
@ -491,20 +491,15 @@ import {
updateDatasource,
updateTenant,
} from "@/api/tenant/tenant";
import { getCurrentInstance, reactive, ref, toRefs } from "vue";
import { ElMessage, ElMessageBox } from "element-plus";
import {
database_type_dict,
initStatusDict,
tenantModeDict,
tenantStatusDict,
} from "@/constant/dict";
import {getCurrentInstance, reactive, ref, toRefs} from "vue";
import {ElMessage, ElMessageBox} from "element-plus";
import {database_type_dict, initStatusDict, tenantModeDict, tenantStatusDict,} from "@/constant/dict";
import DictTag from "@/components/DictTag/index.vue";
import { cloneDeep } from "lodash-es";
import { ArrowRight } from "@element-plus/icons-vue";
import { useRouter } from "vue-router";
import {cloneDeep} from "lodash-es";
import {ArrowRight} from "@element-plus/icons-vue";
import {useRouter} from "vue-router";
const { proxy } = getCurrentInstance();
const {proxy} = getCurrentInstance();
const router = useRouter();
const tenantList = ref([]);
@ -543,7 +538,7 @@ const data = reactive({
},
rules: {
companyName: [
{ required: true, message: "公司名称不能为空", trigger: "blur" },
{required: true, message: "公司名称不能为空", trigger: "blur"},
],
},
tenantSettingForm: {},
@ -615,6 +610,13 @@ const {
} = toRefs(data);
const datasource = ref([]);
const isInit = (tenantId) => {
console.log(tenantId)
console.log((tenantList.value.find(el => el.tenantId === tenantId)?.initialized === '1'))
return (tenantList.value.find(el => el.tenantId === tenantId)?.initialized === '1')
}
/** 查询租户列表 */
function getList() {
loading.value = true;
@ -854,7 +856,8 @@ function handleDelete(row) {
getList();
proxy.$modal.msgSuccess("删除成功");
})
.catch(() => {});
.catch(() => {
});
}
/** 导出按钮操作 */