Skip to content

Commit

Permalink
feat: loding sub dirs (#81)
Browse files Browse the repository at this point in the history
> 更新 #80 实现,添加 loading 交互
> 例如  `/package/zoningjs/files?version=2.0.20` 加载事件比较久
* ⌛ FileIcon 添加 isLoading 逻辑

<!-- This is an auto-generated comment: release notes by coderabbit.ai
-->
## Summary by CodeRabbit

- **New Features**
- Added a loading indicator to the FileTree component to improve user
experience during data fetching.
- Modified the Icon function in icon.tsx to accept default parameters
for more flexible usage.
<!-- end of auto-generated comment: release notes by coderabbit.ai -->
  • Loading branch information
elrrrrrrr authored May 20, 2024
1 parent 1404458 commit 23f0299
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 6 deletions.
2 changes: 1 addition & 1 deletion src/components/FileTree/icon.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ function getIconHelper() {
cache.set('txt', <AiFillFileText color="white" />);
cache.set('closedDirectory', <FcFolder />);
cache.set('openDirectory', <FcOpenedFolder />);
return function Icon(extension: string, name: string): ReactNode {
return function Icon(extension = '', name = ''): ReactNode {
if (cache.has(extension)) return cache.get(extension);
else if (cache.has(name)) return cache.get(name);
else return <FcFile />;
Expand Down
13 changes: 8 additions & 5 deletions src/components/FileTree/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ import React, { useState } from 'react';
import { getIcon } from './icon';
import { useDirs, type Directory, type File } from '@/hooks/useFile';
import { createStyles } from 'antd-style';
import { LoadingOutlined } from '@ant-design/icons';

const useStyles = createStyles(({ token, css }) => {
return {
Expand Down Expand Up @@ -64,11 +65,13 @@ const FileDiv = ({
icon,
selectedFile,
onClick,
isLoading,
}: {
file: File | Directory; // 当前文件
icon?: string; // 图标名称
selectedFile: File | undefined; // 选中的文件
onClick: () => void; // 点击事件
isLoading?: boolean;
}) => {
const isSelected = (selectedFile && selectedFile.path === file.path) as boolean;
const pathArray = file.path.split('/');
Expand All @@ -87,7 +90,7 @@ const FileDiv = ({
}}
onClick={onClick}
>
<FileIcon name={icon} extension={file.path.split('.').pop() || ''} />
<FileIcon isLoading={!!isLoading} name={icon} extension={file.path.split('.').pop() || ''} />
<span style={{ marginLeft: 1 }}>{name}</span>
</div>
);
Expand All @@ -108,13 +111,14 @@ const DirDiv = ({
}) => {
let defaultOpen = selectedFile?.path.includes(directory.path);
const [open, setOpen] = useState(defaultOpen);
const { data: res } = useDirs({ fullname: pkgName, spec }, directory.path, !open);
const { data: res, isLoading } = useDirs({ fullname: pkgName, spec }, directory.path, !open);
return (
<>
<FileDiv
file={directory}
icon={open ? 'openDirectory' : 'closedDirectory'}
selectedFile={selectedFile}
isLoading={isLoading}
onClick={() => setOpen(!open)}
/>
{open ? (
Expand All @@ -130,8 +134,7 @@ const DirDiv = ({
);
};

const FileIcon = ({ extension, name }: { name?: string; extension?: string }) => {
let icon = getIcon(extension || '', name || '');
const FileIcon = ({ extension, name, isLoading }: { name?: string; extension?: string, isLoading: boolean }) => {
return (
<span
style={{
Expand All @@ -142,7 +145,7 @@ const FileIcon = ({ extension, name }: { name?: string; extension?: string }) =>
alignItems: 'center',
}}
>
{icon}
{isLoading ? <LoadingOutlined /> : getIcon(extension, name)}
</span>
);
};

0 comments on commit 23f0299

Please sign in to comment.