ConceptPortal-public/rsconcept/frontend/src/context/UserProfileContext.tsx

86 lines
2.5 KiB
TypeScript
Raw Normal View History

'use client';
2023-07-31 23:47:18 +03:00
import { createContext, useCallback, useContext, useEffect, useState } from 'react';
2024-05-02 17:04:18 +03:00
import { DataCallback, getProfile, patchProfile } from '@/app/backendAPI';
2024-03-20 15:27:32 +03:00
import { ErrorData } from '@/components/info/InfoError';
import { IUserProfile, IUserUpdateData } from '@/models/user';
2023-08-27 15:39:49 +03:00
import { useUsers } from './UsersContext';
2023-07-31 23:47:18 +03:00
2023-08-10 13:53:19 +03:00
interface IUserProfileContext {
2023-12-28 14:04:44 +03:00
user: IUserProfile | undefined;
loading: boolean;
processing: boolean;
error: ErrorData;
errorProcessing: ErrorData;
2023-12-28 14:04:44 +03:00
setError: (error: ErrorData) => void;
updateUser: (data: IUserUpdateData, callback?: DataCallback<IUserProfile>) => void;
2023-07-31 23:47:18 +03:00
}
2023-08-10 13:53:19 +03:00
const ProfileContext = createContext<IUserProfileContext | null>(null);
2023-07-31 23:47:18 +03:00
export const useUserProfile = () => {
const context = useContext(ProfileContext);
if (!context) {
2023-12-28 14:04:44 +03:00
throw new Error('useUserProfile has to be used within <UserProfileState.Provider>');
2023-07-31 23:47:18 +03:00
}
return context;
2023-12-28 14:04:44 +03:00
};
2023-07-31 23:47:18 +03:00
interface UserProfileStateProps {
2023-12-28 14:04:44 +03:00
children: React.ReactNode;
2023-07-31 23:47:18 +03:00
}
export const UserProfileState = ({ children }: UserProfileStateProps) => {
2023-08-27 15:39:49 +03:00
const { users } = useUsers();
2023-07-31 23:47:18 +03:00
const [user, setUser] = useState<IUserProfile | undefined>(undefined);
const [loading, setLoading] = useState(false);
const [processing, setProcessing] = useState(false);
const [error, setError] = useState<ErrorData>(undefined);
const [errorProcessing, setErrorProcessing] = useState<ErrorData>(undefined);
2023-07-31 23:47:18 +03:00
2023-12-28 14:04:44 +03:00
const reload = useCallback(() => {
2023-08-27 15:39:49 +03:00
setError(undefined);
setUser(undefined);
getProfile({
showError: true,
setLoading: setLoading,
2024-01-04 22:10:57 +03:00
onError: setError,
2023-08-27 15:39:49 +03:00
onSuccess: newData => setUser(newData)
});
}, [setUser]);
2023-12-28 14:04:44 +03:00
2023-07-31 23:47:18 +03:00
const updateUser = useCallback(
2023-12-28 14:04:44 +03:00
(data: IUserUpdateData, callback?: DataCallback<IUserProfile>) => {
setErrorProcessing(undefined);
2023-12-28 14:04:44 +03:00
patchProfile({
data: data,
showError: true,
setLoading: setProcessing,
onError: setErrorProcessing,
2023-12-28 14:04:44 +03:00
onSuccess: newData => {
setUser(newData);
const libraryUser = users.find(item => item.id === user?.id);
if (libraryUser) {
libraryUser.first_name = newData.first_name;
libraryUser.last_name = newData.last_name;
}
if (callback) callback(newData);
2023-07-31 23:47:18 +03:00
}
2023-12-28 14:04:44 +03:00
});
},
[setUser, users, user?.id]
);
2023-07-31 23:47:18 +03:00
useEffect(() => {
reload();
}, [reload]);
return (
<ProfileContext.Provider value={{ user, updateUser, error, loading, setError, processing, errorProcessing }}>
2023-07-31 23:47:18 +03:00
{children}
</ProfileContext.Provider>
);
2023-12-28 14:04:44 +03:00
};