From 9ccc66ca1ec75a3b5f12d5f4df28c0c0d3255414 Mon Sep 17 00:00:00 2001 From: GyDi Date: Fri, 25 Feb 2022 01:22:33 +0800 Subject: [PATCH] feat: use enhanced guard-state --- src/components/setting/setting-clash.tsx | 50 +++++++++-------------- src/components/setting/setting-system.tsx | 1 + 2 files changed, 21 insertions(+), 30 deletions(-) diff --git a/src/components/setting/setting-clash.tsx b/src/components/setting/setting-clash.tsx index e0fa9f7b18..7ae9dd1933 100644 --- a/src/components/setting/setting-clash.tsx +++ b/src/components/setting/setting-clash.tsx @@ -1,7 +1,5 @@ -import { useEffect, useState } from "react"; -import { useDebounceFn } from "ahooks"; -import { useSetRecoilState } from "recoil"; import useSWR, { useSWRConfig } from "swr"; +import { useSetRecoilState } from "recoil"; import { ListItemText, TextField, @@ -31,13 +29,10 @@ const SettingClash = ({ onError }: Props) => { ipv6 = false, "allow-lan": allowLan = false, "log-level": logLevel = "silent", - "mixed-port": thePort = 0, + "mixed-port": mixedPort = 0, } = clashConfig ?? {}; - const setPort = useSetRecoilState(atomClashPort); - const [mixedPort, setMixedPort] = useState(thePort); - - useEffect(() => setMixedPort(thePort), [thePort]); + const setGlobalClashPort = useSetRecoilState(atomClashPort); const onSwitchFormat = (_e: any, value: boolean) => value; const onChangeData = (patch: Partial) => { @@ -48,27 +43,20 @@ const SettingClash = ({ onError }: Props) => { await patchClashConfig(patch); }; - // restart clash when port is changed - const { run: onUpdatePort } = useDebounceFn( - async (port: number) => { - try { - if (port < 1000) { - throw new Error("The port should not < 1000"); - } - if (port > 65536) { - throw new Error("The port should not > 65536"); - } - await patchClashConfig({ "mixed-port": port }); - onChangeData({ "mixed-port": port }); - setPort(port); - Notice.success("Change Clash port successfully!"); - } catch (err: any) { - setMixedPort(thePort); // back to old port value - Notice.error(err.message ?? err.toString()); - } - }, - { wait: 1000 } - ); + const onUpdatePort = async (port: number) => { + if (port < 1000) { + throw new Error("The port should not < 1000"); + } + if (port > 65536) { + throw new Error("The port should not > 65536"); + } + await patchClashConfig({ "mixed-port": port }); + setGlobalClashPort(port); + Notice.success("Change Clash port successfully!"); + + // update the config + mutate("getClashConfig"); + }; // get clash core version const clashVer = versionData?.premium @@ -128,9 +116,11 @@ const SettingClash = ({ onError }: Props) => { +e.target.value?.replace(/\D+/, "")} - onChange={setMixedPort} + onChange={(e) => onChangeData({ "mixed-port": e })} onGuard={onUpdatePort} + waitTime={800} > diff --git a/src/components/setting/setting-system.tsx b/src/components/setting/setting-system.tsx index c38055c84c..d7db114822 100644 --- a/src/components/setting/setting-system.tsx +++ b/src/components/setting/setting-system.tsx @@ -91,6 +91,7 @@ const SettingSystem = ({ onError }: Props) => { onFormat={(e: any) => e.target.value} onChange={(e) => onChangeData({ system_proxy_bypass: e })} onGuard={(e) => patchVergeConfig({ system_proxy_bypass: e })} + waitTime={1000} >