2023-12-13 14:32:57 +03:00
|
|
|
'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';
|
2024-05-26 14:54:02 +03:00
|
|
|
import { IUserProfile, IUserUpdateData } from '@/models/user';
|
2024-06-06 23:11:53 +03:00
|
|
|
import { contextOutsideScope } from '@/utils/labels';
|
2023-12-13 14:32:57 +03:00
|
|
|
|
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;
|
2024-05-28 15:09:43 +03:00
|
|
|
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) {
|
2024-06-06 23:11:53 +03:00
|
|
|
throw new Error(contextOutsideScope('useUserProfile', 'UserProfileState'));
|
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);
|
2023-12-13 14:32:57 +03:00
|
|
|
const [error, setError] = useState<ErrorData>(undefined);
|
2024-05-28 15:09:43 +03:00
|
|
|
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>) => {
|
2024-05-28 15:09:43 +03:00
|
|
|
setErrorProcessing(undefined);
|
2023-12-28 14:04:44 +03:00
|
|
|
patchProfile({
|
|
|
|
data: data,
|
|
|
|
showError: true,
|
|
|
|
setLoading: setProcessing,
|
2024-05-28 15:09:43 +03:00
|
|
|
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 (
|
2024-05-28 15:09:43 +03:00
|
|
|
<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
|
|
|
};
|