'use client' import { useGetLanguage } from '@/context/i18n' import cn from '@/utils/classnames' import { RiArrowDownSLine, RiArrowRightSLine } from '@remixicon/react' import type { FC } from 'react' import React, { useEffect, useMemo, useRef } from 'react' import { useTranslation } from 'react-i18next' import { CollectionType } from '../../../tools/types' import BlockIcon from '../../block-icon' import { BlockEnum } from '../../types' import type { TriggerDefaultValue, TriggerWithProvider } from '../types' import TriggerPluginActionItem from './action-item' type Props = { className?: string payload: TriggerWithProvider hasSearchText: boolean onSelect: (type: BlockEnum, trigger?: TriggerDefaultValue) => void } const TriggerPluginItem: FC = ({ className, payload, hasSearchText, onSelect, }) => { const { t } = useTranslation() const language = useGetLanguage() const notShowProvider = payload.type === CollectionType.workflow const actions = payload.triggers 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 trigger = actions[0] const params: Record = {} if (trigger.parameters) { trigger.parameters.forEach((item) => { params[item.name] = '' }) } onSelect(BlockEnum.TriggerPlugin, { provider_id: payload.id, provider_type: payload.type, provider_name: payload.name, trigger_name: trigger.name, trigger_label: trigger.label[language], trigger_description: trigger.description[language], title: trigger.label[language], is_team_authorization: payload.is_team_authorization, output_schema: trigger.output_schema || {}, paramSchemas: trigger.parameters, params, }) }} >
{notShowProvider ? actions[0]?.label[language] : payload.label[language]} {groupName}
{hasAction && ( )}
{!notShowProvider && hasAction && !isFold && ( actions.map(action => ( )) )}
) } export default React.memo(TriggerPluginItem)