feat: OpenResty 升级提示转到创建网站处 (#647)

pull/655/head
zhengkunwang223 2023-04-14 17:18:48 +08:00 committed by GitHub
parent 059c3a0b80
commit 02577ef746
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 60 additions and 63 deletions

View File

@ -8,7 +8,7 @@
},
]"
/>
<LayoutContent :title="$t('runtime.runtime')" v-loading="loading" :class="{ mask: !versionExist }">
<LayoutContent :title="$t('runtime.runtime')" v-loading="loading">
<template #toolbar>
<el-button type="primary" @click="openCreate">
{{ $t('runtime.create') }}
@ -65,15 +65,6 @@
</ComplexTable>
</template>
</LayoutContent>
<el-card width="30%" v-if="!versionExist" class="mask-prompt">
<span>
{{ $t('runtime.openrestryWarn') }}
<span class="open-warn" @click="goRouter()">
<el-icon><Position /></el-icon>
{{ $t('runtime.toupgrade') }}
</span>
</span>
</el-card>
<CreateRuntime ref="createRef" @close="search" />
</div>
</template>
@ -90,8 +81,6 @@ import CreateRuntime from '@/views/website/runtime/create/index.vue';
import Status from '@/components/status/index.vue';
import i18n from '@/lang';
import { useDeleteData } from '@/hooks/use-delete-data';
import { CheckAppInstalled } from '@/api/modules/app';
import router from '@/routers';
const paginationConfig = reactive({
currentPage: 1,
@ -122,7 +111,6 @@ const buttons = [
const loading = ref(false);
const items = ref<Runtime.RuntimeDTO[]>([]);
const createRef = ref();
const versionExist = ref(false);
const search = async () => {
req.page = paginationConfig.currentPage;
@ -151,44 +139,11 @@ const openDelete = async (row: Runtime.Runtime) => {
search();
};
const onCheck = async () => {
try {
const res = await CheckAppInstalled('openresty');
if (res.data && res.data.version) {
if (compareVersions(res.data.version, '1.21.4')) {
versionExist.value = true;
}
}
} catch (error) {}
};
function compareVersions(version1: string, version2: string): boolean {
const v1 = version1.split('.');
const v2 = version2.split('.');
const len = Math.max(v1.length, v2.length);
for (let i = 0; i < len; i++) {
const num1 = parseInt(v1[i] || '0');
const num2 = parseInt(v2[i] || '0');
if (num1 !== num2) {
return num1 > num2 ? true : false;
}
}
return false;
}
const goRouter = async () => {
router.push({ name: 'AppUpgrade' });
};
onMounted(() => {
search();
timer = setInterval(() => {
search();
}, 10000 * 3);
onCheck();
});
onUnmounted(() => {

View File

@ -41,7 +41,7 @@
</template>
</DrawerHeader>
</template>
<el-row v-loading="loading">
<el-row v-loading="loading" :class="{ mask: !versionExist }">
<el-col :span="22" :offset="1">
<el-alert
v-if="website.type == 'deployment'"
@ -227,13 +227,25 @@
</span>
</template>
<Check ref="preCheckRef"></Check>
<el-card width="30%" v-if="!versionExist" class="mask-prompt">
<span>
{{ $t('runtime.openrestryWarn') }}
</span>
</el-card>
</el-drawer>
</template>
<script lang="ts" setup name="CreateWebSite">
import DrawerHeader from '@/components/drawer-header/index.vue';
import { App } from '@/api/interface/app';
import { GetApp, GetAppDetail, SearchApp, GetAppInstalled, GetAppDetailByID } from '@/api/modules/app';
import {
GetApp,
GetAppDetail,
SearchApp,
GetAppInstalled,
GetAppDetailByID,
CheckAppInstalled,
} from '@/api/modules/app';
import { CreateWebsite, PreCheck } from '@/api/modules/website';
import { Rules } from '@/global/form-rules';
import i18n from '@/lang';
@ -270,7 +282,7 @@ const website = ref({
proxyType: 'tcp',
port: 9000,
});
let rules = ref<any>({
const rules = ref<any>({
primaryDomain: [Rules.domain],
alias: [Rules.linuxName],
type: [Rules.requiredInput],
@ -288,31 +300,31 @@ let rules = ref<any>({
port: [Rules.port],
});
let open = ref(false);
let loading = ref(false);
let groups = ref<Group.GroupInfo[]>([]);
const open = ref(false);
const loading = ref(false);
const groups = ref<Group.GroupInfo[]>([]);
let appInstalles = ref<App.AppInstalled[]>([]);
let appReq = reactive({
const appInstalles = ref<App.AppInstalled[]>([]);
const appReq = reactive({
type: 'website',
page: 1,
pageSize: 20,
});
let apps = ref<App.App[]>([]);
let appVersions = ref<string[]>([]);
let appDetail = ref<App.AppDetail>();
let appParams = ref<App.AppParams>();
let paramKey = ref(1);
let preCheckRef = ref();
let staticPath = ref('');
let runtimeResource = ref('appstore');
const apps = ref<App.App[]>([]);
const appVersions = ref<string[]>([]);
const appDetail = ref<App.AppDetail>();
const appParams = ref<App.AppParams>();
const paramKey = ref(1);
const preCheckRef = ref();
const staticPath = ref('');
const runtimeResource = ref('appstore');
const runtimeReq = ref<Runtime.RuntimeReq>({
page: 1,
pageSize: 100,
status: 'normal',
});
const runtimes = ref<Runtime.RuntimeDTO[]>([]);
const versionExist = ref(true);
const em = defineEmits(['close']);
const handleClose = () => {
@ -326,11 +338,24 @@ const changeType = (type: string) => {
website.value.appInstallId = appInstalles.value[0].id;
}
} else if (type == 'runtime') {
checkNginxVersion();
getRuntimes();
} else {
website.value.appInstallId = undefined;
}
website.value.type = type;
versionExist.value = true;
};
const checkNginxVersion = async () => {
try {
const res = await CheckAppInstalled('openresty');
if (res.data && res.data.version) {
if (!compareVersions(res.data.version, '1.21.4')) {
versionExist.value = false;
}
}
} catch (error) {}
};
const searchAppInstalled = () => {
@ -474,6 +499,23 @@ const changeAlias = (value: string) => {
website.value.alias = value;
};
function compareVersions(version1: string, version2: string): boolean {
const v1 = version1.split('.');
const v2 = version2.split('.');
const len = Math.max(v1.length, v2.length);
for (let i = 0; i < len; i++) {
const num1 = parseInt(v1[i] || '0');
const num2 = parseInt(v2[i] || '0');
if (num1 !== num2) {
return num1 > num2 ? true : false;
}
}
return false;
}
defineExpose({
acceptParams,
});