You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

index.tsx 795B

12345678910111213141516171819202122232425262728293031
  1. import { getExtension } from '@/utils/document-util';
  2. import SvgIcon from '../svg-icon';
  3. import { useFetchDocumentThumbnailsByIds } from '@/hooks/document-hooks';
  4. import { useEffect } from 'react';
  5. import styles from './index.less';
  6. interface IProps {
  7. name: string;
  8. id: string;
  9. }
  10. const FileIcon = ({ name, id }: IProps) => {
  11. const fileExtension = getExtension(name);
  12. const { data: fileThumbnails, setDocumentIds } =
  13. useFetchDocumentThumbnailsByIds();
  14. const fileThumbnail = fileThumbnails[id];
  15. useEffect(() => {
  16. setDocumentIds([id]);
  17. }, [id, setDocumentIds]);
  18. return fileThumbnail ? (
  19. <img src={fileThumbnail} className={styles.thumbnailImg}></img>
  20. ) : (
  21. <SvgIcon name={`file-icon/${fileExtension}`} width={24}></SvgIcon>
  22. );
  23. };
  24. export default FileIcon;