Feat: background support warp & baseinfo.vue support id copy

This commit is contained in:
unitwk 2024-02-05 15:07:49 +08:00
parent 8a9089c298
commit 41fbee2317
5 changed files with 49 additions and 19 deletions

View File

@ -91,7 +91,7 @@ export default class Instance extends EventEmitter {
this.forceExec(new FunctionDispatcher()); this.forceExec(new FunctionDispatcher());
} }
if (cfg?.enableRcon !== this.config.enableRcon) { if (cfg?.enableRcon != null && cfg?.enableRcon !== this.config.enableRcon) {
if (this.status() != Instance.STATUS_STOP) if (this.status() != Instance.STATUS_STOP)
throw new Error($t("运行中状态无法启用或关闭 RCON 协议")); throw new Error($t("运行中状态无法启用或关闭 RCON 协议"));
configureEntityParams(this.config, cfg, "enableRcon", Boolean); configureEntityParams(this.config, cfg, "enableRcon", Boolean);

View File

@ -65,6 +65,8 @@ declare module 'vue' {
ATypographyTitle: typeof import('ant-design-vue/es')['TypographyTitle'] ATypographyTitle: typeof import('ant-design-vue/es')['TypographyTitle']
AUpload: typeof import('ant-design-vue/es')['Upload'] AUpload: typeof import('ant-design-vue/es')['Upload']
BetweenMenus: typeof import('./src/components/BetweenMenus.vue')['default'] BetweenMenus: typeof import('./src/components/BetweenMenus.vue')['default']
BgWarp: typeof import('./src/components/BgWarp.vue')['default']
BgWrap: typeof import('./src/components/BgWrap.vue')['default']
CardError: typeof import('./src/components/CardError.vue')['default'] CardError: typeof import('./src/components/CardError.vue')['default']
CardOperator: typeof import('./src/components/CardOperator.vue')['default'] CardOperator: typeof import('./src/components/CardOperator.vue')['default']
CardPanel: typeof import('./src/components/CardPanel.vue')['default'] CardPanel: typeof import('./src/components/CardPanel.vue')['default']

View File

@ -9,10 +9,13 @@ import { Button, Select, Input, Table } from "ant-design-vue";
import MyselfInfoDialog from "./components/MyselfInfoDialog.vue"; import MyselfInfoDialog from "./components/MyselfInfoDialog.vue";
import { closeAppLoading } from "./tools/dom"; import { closeAppLoading } from "./tools/dom";
import { useLayoutConfigStore } from "./stores/useLayoutConfig"; import { useLayoutConfigStore } from "./stores/useLayoutConfig";
import BgWrap from "./components/BgWrap.vue";
const { isDarkTheme } = useAppConfigStore(); const { isDarkTheme } = useAppConfigStore();
const { getSettingsConfig, hasBgImage } = useLayoutConfigStore(); const { getSettingsConfig, hasBgImage } = useLayoutConfigStore();
const GLOBAL_COMPONENTS = [InputDialogProvider, MyselfInfoDialog];
function setBackground(url: string) { function setBackground(url: string) {
const body = document.querySelector("body"); const body = document.querySelector("body");
if (body) { if (body) {
@ -46,14 +49,15 @@ onMounted(async () => {
</script> </script>
<template> <template>
<BgWrap v-if="hasBgImage" />
<AppConfigProvider :has-bg-image="hasBgImage"> <AppConfigProvider :has-bg-image="hasBgImage">
<!-- App Container -->
<div class="global-app-container"> <div class="global-app-container">
<AppHeader></AppHeader> <AppHeader />
<RouterView :key="$route.fullPath" /> <RouterView :key="$route.fullPath" />
</div> </div>
<!-- Global Components --> <!-- Global Components -->
<InputDialogProvider></InputDialogProvider> <component :is="component" v-for="(component, index) in GLOBAL_COMPONENTS" :key="index" />
<MyselfInfoDialog></MyselfInfoDialog>
</AppConfigProvider> </AppConfigProvider>
</template> </template>

View File

@ -0,0 +1,14 @@
<template>
<div class="global-bg-wrap"></div>
</template>
<style scoped>
.global-bg-wrap {
background-color: rgba(0, 0, 0, 0.348);
position: fixed;
left: 0px;
right: 0px;
bottom: 0px;
top: 0px;
}
</style>

View File

@ -61,6 +61,8 @@ onMounted(async () => {
{{ t("TXT_CODE_68831be6") }}{{ instanceTypeText }} {{ t("TXT_CODE_68831be6") }}{{ instanceTypeText }}
</a-typography-paragraph> </a-typography-paragraph>
<a-typography-paragraph> <a-typography-paragraph>
<div style="display: flex; gap: 10px">
<div>
<span>{{ t("TXT_CODE_e70a8e24") }}</span> <span>{{ t("TXT_CODE_e70a8e24") }}</span>
<span v-if="isRunning" class="color-success"> <span v-if="isRunning" class="color-success">
<CheckCircleOutlined /> <CheckCircleOutlined />
@ -73,6 +75,11 @@ onMounted(async () => {
<span v-else> <span v-else>
{{ statusText }} {{ statusText }}
</span> </span>
</div>
<div>
<span> {{ t("TXT_CODE_ad30f3c5") }}{{ instanceInfo?.started }} </span>
</div>
</div>
</a-typography-paragraph> </a-typography-paragraph>
<a-typography-paragraph> <a-typography-paragraph>
{{ t("TXT_CODE_46f575ae") }}{{ parseTimestamp(instanceInfo?.config.lastDatetime) }} {{ t("TXT_CODE_46f575ae") }}{{ parseTimestamp(instanceInfo?.config.lastDatetime) }}
@ -103,15 +110,18 @@ onMounted(async () => {
<a-typography-paragraph> <a-typography-paragraph>
{{ t("TXT_CODE_8b8e08a6") }}{{ parseTimestamp(instanceInfo?.config.createDatetime) }} {{ t("TXT_CODE_8b8e08a6") }}{{ parseTimestamp(instanceInfo?.config.createDatetime) }}
</a-typography-paragraph> </a-typography-paragraph>
<a-typography-paragraph>
{{ t("TXT_CODE_ad30f3c5") }}{{ instanceInfo?.started }}
</a-typography-paragraph>
<a-typography-paragraph> <a-typography-paragraph>
<span>{{ t("TXT_CODE_cec321b4") }}{{ instanceInfo?.config.oe.toUpperCase() }} </span> <span>{{ t("TXT_CODE_cec321b4") }}{{ instanceInfo?.config.oe.toUpperCase() }} </span>
<span class="ml-6"> <span class="ml-6">
{{ t("TXT_CODE_400a4210") }}{{ instanceInfo?.config.ie.toUpperCase() }} {{ t("TXT_CODE_400a4210") }}{{ instanceInfo?.config.ie.toUpperCase() }}
</span> </span>
</a-typography-paragraph> </a-typography-paragraph>
<a-typography-paragraph>
<a-typography-text> {{ t("实例ID") }} </a-typography-text>
<a-typography-text :copyable="{ text: instanceInfo?.instanceUuid }"> </a-typography-text>
<a-typography-text class="ml-10"> {{ t("节点ID") }} </a-typography-text>
<a-typography-text :copyable="{ text: daemonId }"> </a-typography-text>
</a-typography-paragraph>
</template> </template>
</CardPanel> </CardPanel>