123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180 |
- import useSWR from "swr";
- import { useRef } from "react";
- import { useTranslation } from "react-i18next";
- import { IconButton, Tooltip } from "@mui/material";
- import { PrivacyTipRounded, Settings, InfoRounded } from "@mui/icons-material";
- import { checkService } from "@/services/cmds";
- import { useVerge } from "@/hooks/use-verge";
- import { DialogRef, Switch } from "@/components/base";
- import { SettingList, SettingItem } from "./mods/setting-comp";
- import { GuardState } from "./mods/guard-state";
- import { ServiceViewer } from "./mods/service-viewer";
- import { SysproxyViewer } from "./mods/sysproxy-viewer";
- import { TunViewer } from "./mods/tun-viewer";
- import getSystem from "@/utils/get-system";
- interface Props {
- onError?: (err: Error) => void;
- }
- const SettingSystem = ({ onError }: Props) => {
- const { t } = useTranslation();
- const { verge, mutateVerge, patchVerge } = useVerge();
- // service mode
- const { data: serviceStatus } = useSWR("checkService", checkService, {
- revalidateIfStale: false,
- shouldRetryOnError: false,
- focusThrottleInterval: 36e5, // 1 hour
- });
- const serviceRef = useRef<DialogRef>(null);
- const sysproxyRef = useRef<DialogRef>(null);
- const tunRef = useRef<DialogRef>(null);
- const {
- enable_tun_mode,
- enable_auto_launch,
- enable_service_mode,
- enable_silent_start,
- enable_system_proxy,
- } = verge ?? {};
- const onSwitchFormat = (_e: any, value: boolean) => value;
- const onChangeData = (patch: Partial<IVergeConfig>) => {
- mutateVerge({ ...verge, ...patch }, false);
- };
- return (
- <SettingList title={t("System Setting")}>
- <SysproxyViewer ref={sysproxyRef} />
- <TunViewer ref={tunRef} />
- <ServiceViewer ref={serviceRef} enable={!!enable_service_mode} />
- <SettingItem
- label={t("Tun Mode")}
- extra={
- <>
- <Tooltip title={t("Tun Mode Info")} placement="top">
- <IconButton color="inherit" size="small">
- <InfoRounded
- fontSize="inherit"
- style={{ cursor: "pointer", opacity: 0.75 }}
- />
- </IconButton>
- </Tooltip>
- <IconButton
- color="inherit"
- size="small"
- onClick={() => tunRef.current?.open()}
- >
- <Settings
- fontSize="inherit"
- style={{ cursor: "pointer", opacity: 0.75 }}
- />
- </IconButton>
- </>
- }
- >
- <GuardState
- value={enable_tun_mode ?? false}
- valueProps="checked"
- onCatch={onError}
- onFormat={onSwitchFormat}
- onChange={(e) => onChangeData({ enable_tun_mode: e })}
- onGuard={(e) => patchVerge({ enable_tun_mode: e })}
- >
- <Switch edge="end" />
- </GuardState>
- </SettingItem>
- <SettingItem
- label={t("Service Mode")}
- extra={
- <IconButton
- color="inherit"
- size="small"
- onClick={() => serviceRef.current?.open()}
- >
- <PrivacyTipRounded
- fontSize="inherit"
- style={{ cursor: "pointer", opacity: 0.75 }}
- />
- </IconButton>
- }
- >
- <GuardState
- value={enable_service_mode ?? false}
- valueProps="checked"
- onCatch={onError}
- onFormat={onSwitchFormat}
- onChange={(e) => onChangeData({ enable_service_mode: e })}
- onGuard={(e) => patchVerge({ enable_service_mode: e })}
- >
- <Switch
- edge="end"
- disabled={
- serviceStatus !== "active" && serviceStatus !== "installed"
- }
- />
- </GuardState>
- </SettingItem>
- <SettingItem
- label={t("System Proxy")}
- extra={
- <IconButton
- color="inherit"
- size="small"
- onClick={() => sysproxyRef.current?.open()}
- >
- <Settings
- fontSize="inherit"
- style={{ cursor: "pointer", opacity: 0.75 }}
- />
- </IconButton>
- }
- >
- <GuardState
- value={enable_system_proxy ?? false}
- valueProps="checked"
- onCatch={onError}
- onFormat={onSwitchFormat}
- onChange={(e) => onChangeData({ enable_system_proxy: e })}
- onGuard={(e) => patchVerge({ enable_system_proxy: e })}
- >
- <Switch edge="end" />
- </GuardState>
- </SettingItem>
- <SettingItem label={t("Auto Launch")}>
- <GuardState
- value={enable_auto_launch ?? false}
- valueProps="checked"
- onCatch={onError}
- onFormat={onSwitchFormat}
- onChange={(e) => onChangeData({ enable_auto_launch: e })}
- onGuard={(e) => patchVerge({ enable_auto_launch: e })}
- >
- <Switch edge="end" />
- </GuardState>
- </SettingItem>
- <SettingItem label={t("Silent Start")}>
- <GuardState
- value={enable_silent_start ?? false}
- valueProps="checked"
- onCatch={onError}
- onFormat={onSwitchFormat}
- onChange={(e) => onChangeData({ enable_silent_start: e })}
- onGuard={(e) => patchVerge({ enable_silent_start: e })}
- >
- <Switch edge="end" />
- </GuardState>
- </SettingItem>
- </SettingList>
- );
- };
- export default SettingSystem;
|