2022-08-17 17:46:49 +08:00
|
|
|
<template>
|
2022-10-08 18:32:02 +08:00
|
|
|
<div>
|
|
|
|
<el-card class="topCard">
|
|
|
|
<el-radio-group v-model="activeNames">
|
|
|
|
<el-radio-button class="topButton" size="large" label="container">
|
|
|
|
{{ $t('container.container') }}
|
|
|
|
</el-radio-button>
|
|
|
|
<el-radio-button class="topButton" size="large" label="image">
|
|
|
|
{{ $t('container.image') }}
|
|
|
|
</el-radio-button>
|
|
|
|
<el-radio-button class="topButton" size="large" label="network">
|
|
|
|
{{ $t('container.network') }}
|
|
|
|
</el-radio-button>
|
2022-10-11 17:46:52 +08:00
|
|
|
<el-radio-button class="topButton" size="large" label="volume">
|
|
|
|
{{ $t('container.volume') }}
|
2022-10-08 18:32:02 +08:00
|
|
|
</el-radio-button>
|
2022-10-09 16:17:15 +08:00
|
|
|
<el-radio-button class="topButton" size="large" label="repo">
|
|
|
|
{{ $t('container.repo') }}
|
|
|
|
</el-radio-button>
|
2022-10-17 09:10:06 +08:00
|
|
|
<el-radio-button class="topButton" size="large" label="compose">
|
|
|
|
{{ $t('container.compose') }}
|
|
|
|
</el-radio-button>
|
|
|
|
<el-radio-button class="topButton" size="large" label="composeTemplate">
|
|
|
|
{{ $t('container.composeTemplate') }}
|
2022-10-08 18:32:02 +08:00
|
|
|
</el-radio-button>
|
|
|
|
</el-radio-group>
|
|
|
|
</el-card>
|
|
|
|
<Container v-if="activeNames === 'container'" />
|
2022-10-09 16:17:15 +08:00
|
|
|
<Repo v-if="activeNames === 'repo'" />
|
2022-10-10 15:14:49 +08:00
|
|
|
<Image v-if="activeNames === 'image'" />
|
2022-10-11 14:20:51 +08:00
|
|
|
<Network v-if="activeNames === 'network'" />
|
2022-10-11 17:46:52 +08:00
|
|
|
<Volume v-if="activeNames === 'volume'" />
|
2022-10-17 09:10:06 +08:00
|
|
|
<ComposeTemplate v-if="activeNames === 'composeTemplate'" />
|
2022-10-08 18:32:02 +08:00
|
|
|
</div>
|
2022-08-17 17:46:49 +08:00
|
|
|
</template>
|
|
|
|
|
|
|
|
<script lang="ts" setup>
|
2022-10-08 18:32:02 +08:00
|
|
|
import { ref } from 'vue';
|
|
|
|
import Container from '@/views/container/container/index.vue';
|
2022-10-09 16:17:15 +08:00
|
|
|
import Repo from '@/views/container/repo/index.vue';
|
2022-10-10 15:14:49 +08:00
|
|
|
import Image from '@/views/container/image/index.vue';
|
2022-10-11 14:20:51 +08:00
|
|
|
import Network from '@/views/container/network/index.vue';
|
2022-10-11 17:46:52 +08:00
|
|
|
import Volume from '@/views/container/volume/index.vue';
|
2022-10-17 09:10:06 +08:00
|
|
|
import ComposeTemplate from '@/views/container/compose/template/index.vue';
|
2022-10-08 18:32:02 +08:00
|
|
|
|
|
|
|
const activeNames = ref('container');
|
2022-08-17 17:46:49 +08:00
|
|
|
</script>
|
2022-10-08 18:32:02 +08:00
|
|
|
|
|
|
|
<style>
|
|
|
|
.topCard {
|
|
|
|
--el-card-border-color: var(--el-border-color-light);
|
|
|
|
--el-card-border-radius: 4px;
|
|
|
|
--el-card-padding: 0px;
|
|
|
|
--el-card-bg-color: var(--el-fill-color-blank);
|
|
|
|
}
|
|
|
|
.topButton .el-radio-button__inner {
|
|
|
|
display: inline-block;
|
|
|
|
line-height: 1;
|
|
|
|
white-space: nowrap;
|
|
|
|
vertical-align: middle;
|
|
|
|
background: var(--el-button-bg-color, var(--el-fill-color-blank));
|
|
|
|
border: 0;
|
|
|
|
font-weight: 350;
|
|
|
|
border-left: 0;
|
|
|
|
color: var(--el-button-text-color, var(--el-text-color-regular));
|
|
|
|
text-align: center;
|
|
|
|
box-sizing: border-box;
|
|
|
|
outline: 0;
|
|
|
|
margin: 0;
|
|
|
|
position: relative;
|
|
|
|
cursor: pointer;
|
|
|
|
transition: var(--el-transition-all);
|
|
|
|
-webkit-user-select: none;
|
|
|
|
user-select: none;
|
|
|
|
padding: 8px 15px;
|
|
|
|
font-size: var(--el-font-size-base);
|
|
|
|
border-radius: 0;
|
|
|
|
}
|
|
|
|
</style>
|