feat: 容器编排显示容器状态,编排模板样式优化 (#6534)

Refs #4404
pull/6551/head
John Bro 2024-09-19 18:54:56 +08:00 committed by GitHub
parent 55bec8a911
commit 9caa9c47b4
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
5 changed files with 27 additions and 9 deletions

View File

@ -783,6 +783,7 @@ const message = {
content: 'Content',
contentEmpty: 'Compose content cannot be empty, please enter and try again!',
containerNumber: 'Container number',
containerStatus: 'Container Status',
down: 'Down',
up: 'Up',
composeDetailHelper:

View File

@ -752,6 +752,7 @@ const message = {
content: '',
contentEmpty: '',
containerNumber: '',
containerStatus: '',
down: '',
up: '',
composeDetailHelper: ' compose 1Panel ',

View File

@ -755,6 +755,7 @@ const message = {
content: '',
contentEmpty: '',
containerNumber: '',
containerStatus: '',
down: '',
up: '',
composeDetailHelper: ' compose 1Panel ',

View File

@ -64,12 +64,13 @@
<span v-if="row.createdBy === '1Panel'">1Panel</span>
</template>
</el-table-column>
<el-table-column
:label="$t('container.containerNumber')"
prop="containerNumber"
min-width="80"
fix
/>
<el-table-column :label="$t('container.containerStatus')" min-width="80" fix>
<template #default="scope">
<div>
{{ getContainerStatus(scope.row.containers) }}
</div>
</template>
</el-table-column>
<el-table-column :label="$t('commons.table.createdAt')" prop="createdAt" min-width="80" fix />
<fu-table-operations
width="200px"
@ -173,6 +174,17 @@ const loadDetail = async (row: Container.ComposeInfo) => {
isOnDetail.value = true;
composeDetailRef.value!.acceptParams(params);
};
const getContainerStatus = (containers) => {
const safeContainers = containers || [];
const runningCount = safeContainers.filter((container) => container.state.toLowerCase() === 'running').length;
const totalCount = safeContainers.length;
const statusText = runningCount > 0 ? 'Running' : 'Exited';
if (statusText === 'Exited') {
return `${statusText}`;
} else {
return `${statusText} (${runningCount}/${totalCount})`;
}
};
const backList = async () => {
isOnDetail.value = false;
search();

View File

@ -7,9 +7,7 @@
size="50%"
>
<template #header>
<div class="card-header">
<span>{{ $t('commons.button.view') }}</span>
</div>
<DrawerHeader :header="$t('commons.button.view')" :back="handleClose" />
</template>
<codemirror
:autofocus="true"
@ -38,6 +36,7 @@ import { javascript } from '@codemirror/lang-javascript';
import { oneDark } from '@codemirror/theme-one-dark';
import { ref } from 'vue';
import { Codemirror } from 'vue-codemirror';
import DrawerHeader from '@/components/drawer-header/index.vue';
const extensions = [javascript(), oneDark];
const detailVisible = ref(false);
@ -51,6 +50,10 @@ const acceptParams = (params: DialogProps): void => {
detailVisible.value = true;
};
const handleClose = () => {
detailVisible.value = false;
};
defineExpose({
acceptParams,
});