'use client' import type { FC } from 'react' import React, { useEffect, useMemo, useRef } from 'react' import cn from '@/utils/classnames' import { RiArrowDownSLine, RiArrowRightSLine } from '@remixicon/react' import { useGetLanguage } from '@/context/i18n' import { CollectionType } from '../../../tools/types' import type { TriggerWithProvider } from '../types' import { BlockEnum } from '../../types' import type { ToolDefaultValue } from '../types' import TriggerPluginActionItem from './action-item' import BlockIcon from '../../block-icon' import { useTranslation } from 'react-i18next' type Props = { className?: string payload: TriggerWithProvider hasSearchText: boolean onSelect: (type: BlockEnum, tool?: ToolDefaultValue) => void } const TriggerPluginItem: FC = ({ className, payload, hasSearchText, onSelect, }) => { const { t } = useTranslation() const language = useGetLanguage() const notShowProvider = payload.type === CollectionType.workflow const actions = payload.tools const hasAction = !notShowProvider const [isFold, setFold] = React.useState(true) const ref = useRef(null) useEffect(() => { if (hasSearchText && isFold) { setFold(false) return } if (!hasSearchText && !isFold) setFold(true) }, [hasSearchText]) const FoldIcon = isFold ? RiArrowRightSLine : RiArrowDownSLine const groupName = useMemo(() => { if (payload.type === CollectionType.builtIn) return payload.author if (payload.type === CollectionType.custom) return t('workflow.tabs.customTool') if (payload.type === CollectionType.workflow) return t('workflow.tabs.workflowTool') return payload.author || '' }, [payload.author, payload.type, t]) return (
{ if (hasAction) { setFold(!isFold) return } const tool = actions[0] const params: Record = {} if (tool.parameters) { tool.parameters.forEach((item) => { params[item.name] = '' }) } onSelect(BlockEnum.TriggerPlugin, { provider_id: payload.id, provider_type: payload.type, provider_name: payload.name, tool_name: tool.name, tool_label: tool.label[language], tool_description: tool.description[language], title: tool.label[language], is_team_authorization: payload.is_team_authorization, output_schema: tool.output_schema || {}, paramSchemas: tool.parameters, params, }) }} >
{notShowProvider ? actions[0]?.label[language] : payload.label[language]} {groupName}
{hasAction && ( )}
{!notShowProvider && hasAction && !isFold && ( actions.map(action => ( )) )}
) } export default React.memo(TriggerPluginItem)