mirror of
https://github.com/rzmk/learnhouse.git
synced 2025-12-19 04:19:25 +00:00
feat: add refetch capability to contributor status hook and update course actions to utilize it
This commit is contained in:
parent
b6059f8d5c
commit
837e5842c5
2 changed files with 33 additions and 32 deletions
|
|
@ -1,4 +1,4 @@
|
|||
import { useState, useEffect } from 'react';
|
||||
import { useState, useEffect, useCallback } from 'react';
|
||||
import { getCourseContributors } from '@services/courses/courses';
|
||||
import { useLHSession } from '@components/Contexts/LHSessionContext';
|
||||
import toast from 'react-hot-toast';
|
||||
|
|
@ -10,42 +10,42 @@ export function useContributorStatus(courseUuid: string) {
|
|||
const [contributorStatus, setContributorStatus] = useState<ContributorStatus>('NONE');
|
||||
const [isLoading, setIsLoading] = useState(true);
|
||||
|
||||
useEffect(() => {
|
||||
const checkContributorStatus = async () => {
|
||||
if (!session.data?.user) {
|
||||
setIsLoading(false);
|
||||
return;
|
||||
}
|
||||
const checkContributorStatus = useCallback(async () => {
|
||||
if (!session.data?.user) {
|
||||
setIsLoading(false);
|
||||
return;
|
||||
}
|
||||
|
||||
try {
|
||||
const response = await getCourseContributors(
|
||||
'course_' + courseUuid,
|
||||
session.data?.tokens?.access_token
|
||||
try {
|
||||
const response = await getCourseContributors(
|
||||
'course_' + courseUuid,
|
||||
session.data?.tokens?.access_token
|
||||
);
|
||||
|
||||
if (response && response.data) {
|
||||
const currentUser = response.data.find(
|
||||
(contributor: any) => contributor.user_id === session.data.user.id
|
||||
);
|
||||
|
||||
if (response && response.data) {
|
||||
const currentUser = response.data.find(
|
||||
(contributor: any) => contributor.user_id === session.data.user.id
|
||||
);
|
||||
|
||||
if (currentUser) {
|
||||
setContributorStatus(currentUser.authorship_status as ContributorStatus);
|
||||
} else {
|
||||
setContributorStatus('NONE');
|
||||
}
|
||||
if (currentUser) {
|
||||
setContributorStatus(currentUser.authorship_status as ContributorStatus);
|
||||
} else {
|
||||
setContributorStatus('NONE');
|
||||
}
|
||||
} catch (error) {
|
||||
console.error('Failed to check contributor status:', error);
|
||||
toast.error('Failed to check contributor status');
|
||||
} finally {
|
||||
setIsLoading(false);
|
||||
}
|
||||
};
|
||||
|
||||
if (session.data?.user) {
|
||||
checkContributorStatus();
|
||||
} catch (error) {
|
||||
console.error('Failed to check contributor status:', error);
|
||||
toast.error('Failed to check contributor status');
|
||||
} finally {
|
||||
setIsLoading(false);
|
||||
}
|
||||
}, [courseUuid, session.data?.tokens?.access_token, session.data?.user]);
|
||||
|
||||
return { contributorStatus, isLoading };
|
||||
useEffect(() => {
|
||||
if (session.data?.user) {
|
||||
checkContributorStatus();
|
||||
}
|
||||
}, [checkContributorStatus, session.data?.user]);
|
||||
|
||||
return { contributorStatus, isLoading, refetch: checkContributorStatus };
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue