diff --git a/src/components/setting/setting-clash.tsx b/src/components/setting/setting-clash.tsx index eee2e1187fc759f124f830b046e86eb5d9815327..3825e87c992f1c4dd36f6829bd347b2d8507ab37 100644 --- a/src/components/setting/setting-clash.tsx +++ b/src/components/setting/setting-clash.tsx @@ -8,12 +8,13 @@ import { Switch, Select, MenuItem, + Typography, } from "@mui/material"; -import { getClashConfig, updateConfigs } from "../../services/api"; -import { SettingList, SettingItem } from "./setting"; -import { patchClashConfig } from "../../services/cmds"; -import { atomClashPort } from "../../states/setting"; import { ApiType } from "../../services/types"; +import { atomClashPort } from "../../states/setting"; +import { patchClashConfig } from "../../services/cmds"; +import { SettingList, SettingItem } from "./setting"; +import { getClashConfig, getVersion, updateConfigs } from "../../services/api"; import GuardState from "./guard-state"; import Notice from "../notice"; @@ -68,6 +69,15 @@ const SettingClash = ({ onError }: Props) => { { wait: 1000 } ); + // get clash core version + const [clashVer, setClashVer] = useState(""); + useEffect(() => { + getVersion().then((res) => { + const { premium, version } = res; + setClashVer(premium ? `${version} Premium` : version); + }); + }, []); + return ( <SettingList title="Clash Setting"> <SettingItem> @@ -128,6 +138,11 @@ const SettingClash = ({ onError }: Props) => { <TextField autoComplete="off" size="small" sx={{ width: 120 }} /> </GuardState> </SettingItem> + + <SettingItem> + <ListItemText primary="Clash core" /> + <Typography sx={{ py: 1 }}>{clashVer}</Typography> + </SettingItem> </SettingList> ); };