Files
infio-copilot/src/components/chat-view/MarkdownListFilesBlock.tsx
2025-04-01 18:56:11 +08:00

51 lines
1.1 KiB
TypeScript

import { FolderOpen } from 'lucide-react'
import React from 'react'
import { useApp } from '../../contexts/AppContext'
import { ApplyStatus, ListFilesToolArgs } from '../../types/apply'
import { openMarkdownFile } from '../../utils/obsidian'
export default function MarkdownListFilesBlock({
applyStatus,
onApply,
path,
recursive,
finish
}: {
applyStatus: ApplyStatus
onApply: (args: ListFilesToolArgs) => void
path: string,
recursive: boolean,
finish: boolean
}) {
const app = useApp()
const handleClick = () => {
openMarkdownFile(app, path)
}
React.useEffect(() => {
if (finish && applyStatus === ApplyStatus.Idle) {
onApply({
type: 'list_files',
filepath: path,
recursive
})
}
}, [finish])
return (
<div
className={`infio-chat-code-block ${path ? 'has-filename' : ''}`}
onClick={handleClick}
>
<div className={'infio-chat-code-block-header'}>
<div className={'infio-chat-code-block-header-filename'}>
<FolderOpen size={14} className="infio-chat-code-block-header-icon" />
List files: {path}
</div>
</div>
</div>
)
}