소스 검색

fix: clash field state error

GyDi 3 년 전
부모
커밋
2f8146b11f
1개의 변경된 파일14개의 추가작업 그리고 12개의 파일을 삭제
  1. 14 12
      src/components/setting/mods/clash-field-viewer.tsx

+ 14 - 12
src/components/setting/mods/clash-field-viewer.tsx

@@ -46,8 +46,11 @@ const handleFields = [...HANDLE_FIELDS, ...DEFAULT_FIELDS].sort(fieldSorter);
 const ClashFieldViewer = ({ handler }: Props) => {
 const ClashFieldViewer = ({ handler }: Props) => {
   const { t } = useTranslation();
   const { t } = useTranslation();
 
 
-  const { data, mutate } = useSWR("getProfiles", getProfiles);
-  const { data: existsKeys = [] } = useSWR(
+  const { data: profiles = {}, mutate: mutateProfile } = useSWR(
+    "getProfiles",
+    getProfiles
+  );
+  const { data: existsKeys = [], mutate: mutateExists } = useSWR(
     "getRuntimeExists",
     "getRuntimeExists",
     getRuntimeExists
     getRuntimeExists
   );
   );
@@ -63,12 +66,12 @@ const ClashFieldViewer = ({ handler }: Props) => {
   }
   }
 
 
   useEffect(() => {
   useEffect(() => {
-    if (open) mutate();
-  }, [open]);
-
-  useEffect(() => {
-    setSelected(data?.valid || []);
-  }, [data?.valid]);
+    if (open) {
+      mutateProfile();
+      mutateExists();
+      setSelected(profiles.valid || []);
+    }
+  }, [open, profiles.valid]);
 
 
   const handleChange = (item: string) => {
   const handleChange = (item: string) => {
     if (!item) return;
     if (!item) return;
@@ -81,7 +84,7 @@ const ClashFieldViewer = ({ handler }: Props) => {
   const handleSave = async () => {
   const handleSave = async () => {
     setOpen(false);
     setOpen(false);
 
 
-    const oldSet = new Set(data?.valid || []);
+    const oldSet = new Set(profiles.valid || []);
     const curSet = new Set(selected);
     const curSet = new Set(selected);
     const joinSet = new Set(selected.concat([...oldSet]));
     const joinSet = new Set(selected.concat([...oldSet]));
 
 
@@ -89,7 +92,7 @@ const ClashFieldViewer = ({ handler }: Props) => {
 
 
     try {
     try {
       await changeProfileValid([...curSet]);
       await changeProfileValid([...curSet]);
-      mutate();
+      mutateProfile();
       Notice.success("Refresh clash config", 1000);
       Notice.success("Refresh clash config", 1000);
     } catch (err: any) {
     } catch (err: any) {
       Notice.error(err?.message || err.toString());
       Notice.error(err?.message || err.toString());
@@ -112,7 +115,6 @@ const ClashFieldViewer = ({ handler }: Props) => {
         {otherFields.map((item) => {
         {otherFields.map((item) => {
           const inSelect = selected.includes(item);
           const inSelect = selected.includes(item);
           const inConfig = existsKeys.includes(item);
           const inConfig = existsKeys.includes(item);
-          const inValid = data?.valid?.includes(item);
 
 
           return (
           return (
             <Stack key={item} mb={0.5} direction="row" alignItems="center">
             <Stack key={item} mb={0.5} direction="row" alignItems="center">
@@ -124,7 +126,7 @@ const ClashFieldViewer = ({ handler }: Props) => {
               />
               />
               <Typography width="100%">{item}</Typography>
               <Typography width="100%">{item}</Typography>
 
 
-              {!inSelect && inConfig && !inValid && <WarnIcon />}
+              {!inSelect && inConfig && <WarnIcon />}
             </Stack>
             </Stack>
           );
           );
         })}
         })}