diff --git a/src/pages/lesson-list/components/item.tsx b/src/pages/lesson-list/components/item.tsx index 01ff631..cb94266 100644 --- a/src/pages/lesson-list/components/item.tsx +++ b/src/pages/lesson-list/components/item.tsx @@ -30,6 +30,7 @@ type ItemProps = { isTeacher: boolean courseId: string setlessonToDelete(): void + setEditLesson?: () => void students: unknown[] } @@ -40,6 +41,7 @@ export const Item: React.FC = ({ isTeacher, courseId, setlessonToDelete, + setEditLesson, students, }) => { const [edit, setEdit] = useState(false) @@ -128,7 +130,11 @@ export const Item: React.FC = ({ { - setEdit(true) + if (setEditLesson) { + setEditLesson(); + } else { + setEdit(true); + } }} > {t('journal.pl.edit')} diff --git a/src/pages/lesson-list/components/lesson-items.tsx b/src/pages/lesson-list/components/lesson-items.tsx index b78decc..e0075bc 100644 --- a/src/pages/lesson-list/components/lesson-items.tsx +++ b/src/pages/lesson-list/components/lesson-items.tsx @@ -15,6 +15,7 @@ type LessonItemProps = { isTeacher: boolean courseId: string setlessonToDelete(lesson: Lesson): void + setEditLesson?(lesson: Lesson): void } export const LessonItems: React.FC = ({ @@ -23,6 +24,7 @@ export const LessonItems: React.FC = ({ isTeacher, courseId, setlessonToDelete, + setEditLesson, }) => ( <> {date && ( @@ -37,6 +39,7 @@ export const LessonItems: React.FC = ({ key={lesson.id} {...lesson} setlessonToDelete={() => setlessonToDelete(lesson)} + setEditLesson={setEditLesson ? () => setEditLesson(lesson) : undefined} courseId={courseId} isTeacher={isTeacher} /> diff --git a/src/pages/lesson-list/lesson-list.tsx b/src/pages/lesson-list/lesson-list.tsx index 2f9bb7d..2c4c205 100644 --- a/src/pages/lesson-list/lesson-list.tsx +++ b/src/pages/lesson-list/lesson-list.tsx @@ -102,12 +102,6 @@ const LessonList = () => { return lessonsData.sort((a, b) => (a.date < b.date ? 1 : -1)) }, [groupByDate, isSuccess, sorted]) - useEffect(() => { - if (isTeacher(user) && !isSuccessGenerateLessons) { - generateLessonsMutation(courseId) - } - }, [isSuccessGenerateLessons, user, courseId, generateLessonsMutation]) - useEffect(() => { if (isSuccessGenerateLessons) { console.log(generateLessons) @@ -205,6 +199,31 @@ const LessonList = () => { setShowForm(false) setEditLesson(null) setSuggestedLessonToCreate(null) + + // Сбрасываем флаги генерации, чтобы при повторном открытии формы + // генерация запускалась снова + if (generateLessons) { + // Сбрасываем данные генерации (если в API есть такая возможность) + // или при повторном открытии формы будем перезапрашивать данные + } + } + + // Обработчик открытия формы создания новой лекции + const handleOpenForm = () => { + setShowForm(true) + + // Запускаем генерацию лекций только при открытии формы создания новой лекции + // и если генерация ещё не была запущена + if (isTeacher(user) && !editLesson && !generateLessons && !isLoadingGenerateLessons) { + generateLessonsMutation(courseId) + } + } + + // Обработчик редактирования существующей лекции + const handleEditLesson = (lesson) => { + setEditLesson(lesson) + setShowForm(true) + // Не запускаем генерацию при редактировании } if (isLoading) { @@ -284,7 +303,7 @@ const LessonList = () => { @@ -326,6 +345,7 @@ const LessonList = () => { isTeacher={isTeacher(user)} lessons={lessons} setlessonToDelete={setlessonToDelete} + setEditLesson={handleEditLesson} key={date} /> ))}