Skip to content

Commit

Permalink
refactor(materials): optimize folder data loading and improve type co…
Browse files Browse the repository at this point in the history
…nsistency
  • Loading branch information
phungmanhcuong committed Oct 30, 2024
1 parent 06c8e88 commit d1b5abf
Show file tree
Hide file tree
Showing 3 changed files with 25 additions and 20 deletions.
2 changes: 1 addition & 1 deletion client/app/api/course/Materials.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import { FileListData } from 'types/course/material/files';

import { APIResponse } from 'api/types';

import {FolderMiniEntity} from '../../types/course/material/folders';
import { FolderMiniEntity } from '../../types/course/material/folders';

import BaseCourseAPI from './Base';

Expand Down
29 changes: 15 additions & 14 deletions client/app/bundles/course/material/folders/operations.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import { Operation } from 'store';
import {
FolderData,
FolderFormData,
MaterialFormData,
MaterialUploadFormData,
Expand Down Expand Up @@ -62,20 +63,20 @@ const formatMaterialAttributes = (data: MaterialFormData): FormData => {
return payload;
};

export function loadFolder(folderId: number): Operation<SaveFolderAction> {
return async (dispatch) =>
CourseAPI.folders.fetch(folderId).then((response) => {
const data = response.data;
return dispatch(
actions.saveFolder(
data.currFolderInfo,
data.subfolders,
data.materials,
data.advanceStartAt,
data.permissions,
),
);
});
export function dispatchFolderData(
data: FolderData,
): Operation<SaveFolderAction> {
return async (dispatch) => {
return dispatch(
actions.saveFolder(
data.currFolderInfo,
data.subfolders,
data.materials,
data.advanceStartAt,
data.permissions,
),
);
};
}

export function createFolder(
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { FC, ReactElement, useEffect, useState } from 'react';
import { defineMessages } from 'react-intl';
import { useParams } from 'react-router-dom';
import { useLoaderData, useParams } from 'react-router-dom';

import EditButton from 'lib/components/core/buttons/EditButton';
import Page from 'lib/components/core/layouts/Page';
Expand All @@ -10,12 +10,13 @@ import { getCourseId } from 'lib/helpers/url-helpers';
import { useAppDispatch, useAppSelector } from 'lib/hooks/store';
import useTranslation from 'lib/hooks/useTranslation';

import { FolderData } from '../../../../../../types/course/material/folders';
import DownloadFolderButton from '../../components/buttons/DownloadFolderButton';
import NewSubfolderButton from '../../components/buttons/NewSubfolderButton';
import UploadFilesButton from '../../components/buttons/UploadFilesButton';
import MaterialUpload from '../../components/misc/MaterialUpload';
import WorkbinTable from '../../components/tables/WorkbinTable';
import { loadFolder } from '../../operations';
import { dispatchFolderData } from '../../operations';
import {
getCurrFolderInfo,
getFolderMaterials,
Expand Down Expand Up @@ -48,13 +49,16 @@ const FolderShow: FC = () => {
const materials = useAppSelector(getFolderMaterials);
const currFolderInfo = useAppSelector(getCurrFolderInfo);
const permissions = useAppSelector(getFolderPermissions);
const loaderData = useLoaderData() as FolderData;

const [isLoading, setIsLoading] = useState(true);
useEffect(() => {
if (folderId) {
dispatch(loadFolder(+folderId)).finally(() => setIsLoading(false));
if (loaderData) {
dispatch(dispatchFolderData(loaderData)).finally(() =>
setIsLoading(false),
);
}
}, [dispatch, folderId]);
}, [dispatch, loaderData]);

if (isLoading) {
return <LoadingIndicator />;
Expand Down

0 comments on commit d1b5abf

Please sign in to comment.