37 lines
905 B
TypeScript
37 lines
905 B
TypeScript
import { create } from 'zustand';
|
|
import { persist } from 'zustand/middleware';
|
|
|
|
interface AuthState {
|
|
token: string | null;
|
|
isAuthenticated: boolean;
|
|
user: {
|
|
email: string;
|
|
firstName?: string;
|
|
lastName?: string;
|
|
} | null;
|
|
login: (token: string, user: {email: string, firstName?: string, lastName?: string}) => void;
|
|
logout: () => void;
|
|
setToken: (token: string | null) => void;
|
|
}
|
|
|
|
export const useAuthStore = create<AuthState>()(
|
|
persist(
|
|
(set) => ({
|
|
token: null,
|
|
isAuthenticated: false,
|
|
user: null,
|
|
login: (token, user) => set({ token, isAuthenticated: true, user }),
|
|
logout: () => set({ token: null, isAuthenticated: false, user: null }),
|
|
setToken: (token) =>
|
|
set((state) => ({
|
|
token,
|
|
isAuthenticated: !!token,
|
|
user: state.user,
|
|
})),
|
|
}),
|
|
{
|
|
name: 'keygen-auth',
|
|
}
|
|
)
|
|
);
|