import { Sparkles } from 'lucide-react'
import React from 'react'
import { useApp } from "../../../contexts/AppContext"
import { ApplyStatus, ToolArgs } from "../../../types/apply"
import { openMarkdownFile } from "../../../utils/obsidian"
export type TransformationToolType = 'call_transformations'
interface MarkdownTransformationToolBlockProps {
applyStatus: ApplyStatus
onApply: (args: ToolArgs) => void
toolType: TransformationToolType
path: string
transformation?: string
finish: boolean
}
const getTransformationConfig = (transformation: string) => {
switch (transformation) {
case 'analyze_paper':
return {
icon: ,
title: 'Analyze Paper',
description: 'Deep analysis of academic papers'
}
case 'key_insights':
return {
icon: ,
title: 'Key Insights',
description: 'Extract key insights'
}
case 'dense_summary':
return {
icon: ,
title: 'Dense Summary',
description: 'Create information-dense summary'
}
case 'reflections':
return {
icon: ,
title: 'Deep Reflections',
description: 'Generate deep reflections'
}
case 'table_of_contents':
return {
icon: ,
title: 'Table of Contents',
description: 'Generate table of contents structure'
}
case 'simple_summary':
return {
icon: ,
title: 'Simple Summary',
description: 'Create readable summary'
}
default:
return {
icon: ,
title: 'Document Processing',
description: 'Process document'
}
}
}
export default function MarkdownTransformationToolBlock({
applyStatus,
onApply,
path,
transformation,
finish
}: MarkdownTransformationToolBlockProps) {
const app = useApp()
const config = getTransformationConfig(transformation || '')
const handleClick = () => {
if (path) {
openMarkdownFile(app, path)
}
}
React.useEffect(() => {
if (finish && applyStatus === ApplyStatus.Idle) {
onApply({
type: 'call_transformations',
path: path || '',
transformation: transformation || ''
})
}
}, [finish])
const getDisplayText = () => {
return `${config.title}: ${path || '未指定路径'}`
}
return (
{config.icon}
{getDisplayText()}
)
}