Skip to content
Snippets Groups Projects
Commit f72536bc authored by GyDi's avatar GyDi
Browse files

feat: auto update profiles

parent 81aef736
No related branches found
No related tags found
No related merge requests found
......@@ -10,6 +10,7 @@ import {
} from "../services/command";
import ProfileItemComp from "../components/profile-item";
import useNotice from "../utils/use-notice";
import noop from "../utils/noop";
const RulesPage = () => {
const [url, setUrl] = useState("");
......@@ -19,14 +20,21 @@ const RulesPage = () => {
const { mutate } = useSWRConfig();
const { data: profiles = {} } = useSWR("getProfiles", getProfiles);
const onClick = () => {
const onImport = async () => {
if (!url) return;
setUrl("");
setDisabled(true);
importProfile(url)
.then(() => notice.success("Successfully import profile."))
.catch(() => notice.error("Failed to import profile."))
.finally(() => setDisabled(false));
try {
await importProfile(url);
mutate("getProfiles", getProfiles());
if (!profiles.items?.length) putProfiles(0).catch(noop);
notice.success("Successfully import profile.");
} catch {
notice.error("Failed to import profile.");
} finally {
setDisabled(false);
}
};
const lockRef = useRef(false);
......@@ -76,7 +84,7 @@ const RulesPage = () => {
<Button
disabled={!url || disabled}
variant="contained"
onClick={onClick}
onClick={onImport}
>
Import
</Button>
......
......@@ -48,7 +48,7 @@ export interface ProfilesConfig {
}
export async function getProfiles() {
return invoke<ProfilesConfig | null>("get_profiles");
return (await invoke<ProfilesConfig>("get_profiles")) ?? {};
}
export async function setProfiles(current: number, profile: ProfileItem) {
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment