setting-system.tsx 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. import useSWR from "swr";
  2. import { useState } from "react";
  3. import { useTranslation } from "react-i18next";
  4. import { IconButton, Switch } from "@mui/material";
  5. import { ArrowForward, PrivacyTipRounded, Settings } from "@mui/icons-material";
  6. import {
  7. checkService,
  8. getVergeConfig,
  9. patchVergeConfig,
  10. } from "@/services/cmds";
  11. import { SettingList, SettingItem } from "./setting";
  12. import useModalHandler from "@/hooks/use-modal-handler";
  13. import getSystem from "@/utils/get-system";
  14. import GuardState from "./mods/guard-state";
  15. import ServiceMode from "./mods/service-mode";
  16. import SysproxyViewer from "./mods/sysproxy-viewer";
  17. interface Props {
  18. onError?: (err: Error) => void;
  19. }
  20. const isWIN = getSystem() === "windows";
  21. const SettingSystem = ({ onError }: Props) => {
  22. const { t } = useTranslation();
  23. const { data: vergeConfig, mutate: mutateVerge } = useSWR(
  24. "getVergeConfig",
  25. getVergeConfig
  26. );
  27. // service mode
  28. const [serviceOpen, setServiceOpen] = useState(false);
  29. const { data: serviceStatus } = useSWR(
  30. isWIN ? "checkService" : null,
  31. checkService,
  32. { revalidateIfStale: true, shouldRetryOnError: false }
  33. );
  34. const {
  35. enable_tun_mode,
  36. enable_auto_launch,
  37. enable_service_mode,
  38. enable_silent_start,
  39. enable_system_proxy,
  40. } = vergeConfig ?? {};
  41. const onSwitchFormat = (_e: any, value: boolean) => value;
  42. const onChangeData = (patch: Partial<CmdType.VergeConfig>) => {
  43. mutateVerge({ ...vergeConfig, ...patch }, false);
  44. };
  45. const sysproxyHandler = useModalHandler();
  46. return (
  47. <SettingList title={t("System Setting")}>
  48. <SysproxyViewer handler={sysproxyHandler} />
  49. <SettingItem label={t("Tun Mode")}>
  50. <GuardState
  51. value={enable_tun_mode ?? false}
  52. valueProps="checked"
  53. onCatch={onError}
  54. onFormat={onSwitchFormat}
  55. onChange={(e) => onChangeData({ enable_tun_mode: e })}
  56. onGuard={(e) => patchVergeConfig({ enable_tun_mode: e })}
  57. >
  58. <Switch edge="end" />
  59. </GuardState>
  60. </SettingItem>
  61. {isWIN && (
  62. <SettingItem
  63. label={t("Service Mode")}
  64. extra={
  65. (serviceStatus === "active" || serviceStatus === "installed") && (
  66. <PrivacyTipRounded
  67. fontSize="small"
  68. style={{ cursor: "pointer", opacity: 0.75 }}
  69. onClick={() => setServiceOpen(true)}
  70. />
  71. )
  72. }
  73. >
  74. {serviceStatus === "active" || serviceStatus === "installed" ? (
  75. <GuardState
  76. value={enable_service_mode ?? false}
  77. valueProps="checked"
  78. onCatch={onError}
  79. onFormat={onSwitchFormat}
  80. onChange={(e) => onChangeData({ enable_service_mode: e })}
  81. onGuard={(e) => patchVergeConfig({ enable_service_mode: e })}
  82. >
  83. <Switch edge="end" />
  84. </GuardState>
  85. ) : (
  86. <IconButton
  87. color="inherit"
  88. size="small"
  89. sx={{ my: "2px" }}
  90. onClick={() => setServiceOpen(true)}
  91. >
  92. <ArrowForward />
  93. </IconButton>
  94. )}
  95. </SettingItem>
  96. )}
  97. {isWIN && (
  98. <ServiceMode
  99. open={serviceOpen}
  100. enable={!!enable_service_mode}
  101. onError={onError}
  102. onClose={() => setServiceOpen(false)}
  103. />
  104. )}
  105. <SettingItem
  106. label={t("System Proxy")}
  107. extra={
  108. <Settings
  109. fontSize="small"
  110. style={{ cursor: "pointer", opacity: 0.75 }}
  111. onClick={() => sysproxyHandler.current.open()}
  112. />
  113. }
  114. >
  115. <GuardState
  116. value={enable_system_proxy ?? false}
  117. valueProps="checked"
  118. onCatch={onError}
  119. onFormat={onSwitchFormat}
  120. onChange={(e) => onChangeData({ enable_system_proxy: e })}
  121. onGuard={async (e) => {
  122. await patchVergeConfig({ enable_system_proxy: e });
  123. mutateVerge(); // update bypass value
  124. }}
  125. >
  126. <Switch edge="end" />
  127. </GuardState>
  128. </SettingItem>
  129. <SettingItem label={t("Auto Launch")}>
  130. <GuardState
  131. value={enable_auto_launch ?? false}
  132. valueProps="checked"
  133. onCatch={onError}
  134. onFormat={onSwitchFormat}
  135. onChange={(e) => onChangeData({ enable_auto_launch: e })}
  136. onGuard={(e) => patchVergeConfig({ enable_auto_launch: e })}
  137. >
  138. <Switch edge="end" />
  139. </GuardState>
  140. </SettingItem>
  141. <SettingItem label={t("Silent Start")}>
  142. <GuardState
  143. value={enable_silent_start ?? false}
  144. valueProps="checked"
  145. onCatch={onError}
  146. onFormat={onSwitchFormat}
  147. onChange={(e) => onChangeData({ enable_silent_start: e })}
  148. onGuard={(e) => patchVergeConfig({ enable_silent_start: e })}
  149. >
  150. <Switch edge="end" />
  151. </GuardState>
  152. </SettingItem>
  153. </SettingList>
  154. );
  155. };
  156. export default SettingSystem;