BillTracker/client/hooks/useAuth.jsx

55 lines
1.4 KiB
React
Raw Normal View History

2026-05-03 19:51:57 -05:00
import { createContext, useContext, useEffect, useState } from 'react';
import { api } from '@/api';
const AuthContext = createContext(null);
export function AuthProvider({ children }) {
2026-05-14 21:00:07 -05:00
const [user, setUser] = useState(undefined); // undefined = loading
const [singleUserMode, setSUM] = useState(false);
const [hasNewVersion, setHasNewVersion] = useState(false);
function applyMeResponse(d) {
setUser(d.user);
setSUM(d.single_user_mode || false);
setHasNewVersion(!!d.has_new_version);
}
2026-05-03 19:51:57 -05:00
useEffect(() => {
api.authMode().then(d => {
if (d.auth_mode === 'single') setSUM(true);
}).catch(() => {});
2026-05-14 21:00:07 -05:00
api.me().then(applyMeResponse).catch(() => setUser(null));
}, []); // eslint-disable-line
2026-05-03 19:51:57 -05:00
const logout = async () => {
await api.logout();
setUser(null);
setSUM(false);
2026-05-14 21:00:07 -05:00
setHasNewVersion(false);
2026-05-03 19:51:57 -05:00
};
const refresh = () => {
2026-05-14 21:00:07 -05:00
api.me().then(applyMeResponse).catch(() => {
setUser(null);
setSUM(false);
});
2026-05-03 19:51:57 -05:00
};
return (
2026-05-14 21:00:07 -05:00
<AuthContext.Provider value={{
user, singleUserMode, setUser, logout, refresh,
hasNewVersion, setHasNewVersion,
}}>
2026-05-03 19:51:57 -05:00
{children}
</AuthContext.Provider>
);
}
export function useAuth() {
2026-05-14 21:00:07 -05:00
return useContext(AuthContext) || {
user: null, setUser: () => {}, logout: () => {}, refresh: () => {},
singleUserMode: false, hasNewVersion: false, setHasNewVersion: () => {},
};
2026-05-03 19:51:57 -05:00
}