74 lines
1.6 KiB
TypeScript
Raw Normal View History

import { createStore, useStore } from "zustand";
import { persist, createJSONStorage } from "zustand/middleware";
import AsyncStorage from "@react-native-async-storage/async-storage";
2024-11-12 04:43:59 +07:00
export type AppServer = {
name?: string;
url: string;
};
type AppStore = {
2024-11-16 02:34:07 +07:00
localServer?: string | null;
servers: AppServer[];
2024-11-16 02:34:07 +07:00
curServer?: string | null;
};
const appStore = createStore(
persist<AppStore>(
() => ({
2024-11-16 02:34:07 +07:00
localServer: null,
servers: [],
2024-11-16 02:34:07 +07:00
curServer: null,
}),
{
name: "vaulterm:app",
storage: createJSONStorage(() => AsyncStorage),
}
)
);
export function addServer(srv: AppServer, setActive?: boolean) {
const curServers = appStore.getState().servers;
const isExist = curServers.findIndex((s) => s.url === srv.url);
if (isExist >= 0) {
2024-11-16 02:34:07 +07:00
setCurrentServer(srv.url);
return;
}
appStore.setState((state) => ({
servers: [...state.servers, srv],
2024-11-16 02:34:07 +07:00
curServer: setActive ? srv.url : state.curServer,
}));
}
export function removeServer(idx: number) {
appStore.setState((state) => ({
servers: state.servers.filter((_, i) => i !== idx),
}));
}
2024-11-16 02:34:07 +07:00
export function setCurrentServer(url: string) {
appStore.setState({ curServer: url });
}
2024-11-12 04:43:59 +07:00
export function getCurrentServer() {
2024-11-16 02:34:07 +07:00
return appStore.getState().curServer;
}
export function setLocalServer(url: string) {
appStore.setState((state) => ({
localServer: url,
curServer:
!state.curServer || state.curServer === state.localServer
? url
: state.curServer,
}));
2024-11-12 04:43:59 +07:00
}
2024-11-12 04:43:59 +07:00
export const useServer = () => {
2024-11-16 02:34:07 +07:00
return useStore(appStore, (i) => i.curServer);
};
export default appStore;