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

52 lines
1.2 KiB
TypeScript

import { FileSearch } from 'lucide-react'
import React from 'react'
import { useApp } from '../../contexts/AppContext'
import { ApplyStatus, RegexSearchFilesToolArgs } from '../../types/apply'
import { openMarkdownFile } from '../../utils/obsidian'
export default function MarkdownRegexSearchFilesBlock({
applyStatus,
onApply,
path,
regex,
finish
}: {
applyStatus: ApplyStatus
onApply: (args: RegexSearchFilesToolArgs) => void
path: string,
regex: string,
finish: boolean
}) {
const app = useApp()
const handleClick = () => {
openMarkdownFile(app, path)
}
React.useEffect(() => {
if (finish && applyStatus === ApplyStatus.Idle) {
onApply({
type: 'regex_search_files',
filepath: path,
regex: regex,
file_pattern: ".md",
})
}
}, [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'}>
<FileSearch size={14} className="infio-chat-code-block-header-icon" />
<span>regex search files &quot;{regex}&quot; in {path}</span>
</div>
</div>
</div>
)
}