Web:Client:Add useMemo.
This commit is contained in:
parent
1d0c9640d3
commit
509a1b9d9e
@ -1,4 +1,10 @@
|
||||
import React, { useEffect, useRef, useCallback, useState } from "react";
|
||||
import React, {
|
||||
useEffect,
|
||||
useRef,
|
||||
useCallback,
|
||||
useState,
|
||||
useMemo,
|
||||
} from "react";
|
||||
import { inject, observer } from "mobx-react";
|
||||
import elementResizeDetectorMaker from "element-resize-detector";
|
||||
import TileContainer from "./sub-components/TileContainer";
|
||||
@ -87,6 +93,38 @@ const FilesTileContainer = ({ filesList, t, sectionWidth, withPaging }) => {
|
||||
}
|
||||
}, []);
|
||||
|
||||
const filesListNode = useMemo(() => {
|
||||
return filesList.map((item, index) => {
|
||||
return index % 11 == 0 ? (
|
||||
<FileTile
|
||||
id={`${item?.isFolder ? "folder" : "file"}_${item.id}`}
|
||||
key={
|
||||
item?.version ? `${item.id}_${item.version}` : `${item.id}_${index}`
|
||||
}
|
||||
item={item}
|
||||
itemIndex={index}
|
||||
sectionWidth={sectionWidth}
|
||||
selectableRef={onSetTileRef}
|
||||
thumbSize={thumbSize}
|
||||
columnCount={columnCount}
|
||||
withRef={true}
|
||||
/>
|
||||
) : (
|
||||
<FileTile
|
||||
id={`${item?.isFolder ? "folder" : "file"}_${item.id}`}
|
||||
key={
|
||||
item?.version ? `${item.id}_${item.version}` : `${item.id}_${index}`
|
||||
}
|
||||
item={item}
|
||||
itemIndex={index}
|
||||
sectionWidth={sectionWidth}
|
||||
thumbSize={thumbSize}
|
||||
columnCount={columnCount}
|
||||
/>
|
||||
);
|
||||
});
|
||||
}, [filesList, sectionWidth, onSetTileRef, thumbSize, columnCount]);
|
||||
|
||||
return (
|
||||
<TileContainer
|
||||
className="tile-container"
|
||||
@ -95,39 +133,7 @@ const FilesTileContainer = ({ filesList, t, sectionWidth, withPaging }) => {
|
||||
headingFolders={t("Translations:Folders")}
|
||||
headingFiles={t("Translations:Files")}
|
||||
>
|
||||
{filesList.map((item, index) => {
|
||||
return index % 11 == 0 ? (
|
||||
<FileTile
|
||||
id={`${item?.isFolder ? "folder" : "file"}_${item.id}`}
|
||||
key={
|
||||
item?.version
|
||||
? `${item.id}_${item.version}`
|
||||
: `${item.id}_${index}`
|
||||
}
|
||||
item={item}
|
||||
itemIndex={index}
|
||||
sectionWidth={sectionWidth}
|
||||
selectableRef={onSetTileRef}
|
||||
thumbSize={thumbSize}
|
||||
columnCount={columnCount}
|
||||
withRef={true}
|
||||
/>
|
||||
) : (
|
||||
<FileTile
|
||||
id={`${item?.isFolder ? "folder" : "file"}_${item.id}`}
|
||||
key={
|
||||
item?.version
|
||||
? `${item.id}_${item.version}`
|
||||
: `${item.id}_${index}`
|
||||
}
|
||||
item={item}
|
||||
itemIndex={index}
|
||||
sectionWidth={sectionWidth}
|
||||
thumbSize={thumbSize}
|
||||
columnCount={columnCount}
|
||||
/>
|
||||
);
|
||||
})}
|
||||
{filesListNode}
|
||||
</TileContainer>
|
||||
);
|
||||
};
|
||||
|
Loading…
Reference in New Issue
Block a user