|
@@ -4,7 +4,8 @@ import { Route, Routes } from "react-router-dom";
|
|
import { useRecoilState } from "recoil";
|
|
import { useRecoilState } from "recoil";
|
|
import { createTheme, List, Paper, ThemeProvider } from "@mui/material";
|
|
import { createTheme, List, Paper, ThemeProvider } from "@mui/material";
|
|
import { atomPaletteMode } from "../states/setting";
|
|
import { atomPaletteMode } from "../states/setting";
|
|
-import { getVergeConfig } from "../services/command";
|
|
|
|
|
|
+import { getClashInfo, getVergeConfig } from "../services/cmds";
|
|
|
|
+import { initAxios } from "../services/api";
|
|
import LogoSvg from "../assets/image/logo.svg";
|
|
import LogoSvg from "../assets/image/logo.svg";
|
|
import LogPage from "./log";
|
|
import LogPage from "./log";
|
|
import HomePage from "./home";
|
|
import HomePage from "./home";
|
|
@@ -12,7 +13,7 @@ import ProfilePage from "./profile";
|
|
import ProxyPage from "./proxy";
|
|
import ProxyPage from "./proxy";
|
|
import SettingPage from "./setting";
|
|
import SettingPage from "./setting";
|
|
import ConnectionsPage from "./connections";
|
|
import ConnectionsPage from "./connections";
|
|
-import ListItemLink from "../components/list-item-link";
|
|
|
|
|
|
+import LayoutItem from "../components/layout-item";
|
|
import Traffic from "../components/traffic";
|
|
import Traffic from "../components/traffic";
|
|
|
|
|
|
const routers = [
|
|
const routers = [
|
|
@@ -42,6 +43,12 @@ const Layout = () => {
|
|
const [mode, setMode] = useRecoilState(atomPaletteMode);
|
|
const [mode, setMode] = useRecoilState(atomPaletteMode);
|
|
const { data: vergeConfig } = useSWR("getVergeConfig", getVergeConfig);
|
|
const { data: vergeConfig } = useSWR("getVergeConfig", getVergeConfig);
|
|
|
|
|
|
|
|
+ useEffect(() => {
|
|
|
|
+ getClashInfo()
|
|
|
|
+ .then((result) => initAxios(result?.controller ?? {}))
|
|
|
|
+ .catch(() => console.error("can not initialize clash verge"));
|
|
|
|
+ }, []);
|
|
|
|
+
|
|
useEffect(() => {
|
|
useEffect(() => {
|
|
setMode(vergeConfig?.theme_mode ?? "light");
|
|
setMode(vergeConfig?.theme_mode ?? "light");
|
|
}, [vergeConfig?.theme_mode]);
|
|
}, [vergeConfig?.theme_mode]);
|
|
@@ -95,9 +102,9 @@ const Layout = () => {
|
|
|
|
|
|
<List sx={{ userSelect: "none" }}>
|
|
<List sx={{ userSelect: "none" }}>
|
|
{routers.map((router) => (
|
|
{routers.map((router) => (
|
|
- <ListItemLink key={router.label} to={router.link}>
|
|
|
|
|
|
+ <LayoutItem key={router.label} to={router.link}>
|
|
{router.label}
|
|
{router.label}
|
|
- </ListItemLink>
|
|
|
|
|
|
+ </LayoutItem>
|
|
))}
|
|
))}
|
|
</List>
|
|
</List>
|
|
|
|
|