1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768 |
- import type { FC } from 'react'
- import React from 'react'
- import { useTranslation } from 'react-i18next'
- import {
- RiAddLine,
- } from '@remixicon/react'
- import VarList from './components/var-list'
- import useConfig from './use-config'
- import type { AssignerNodeType } from './types'
- import { useHandleAddOperationItem } from './hooks'
- import ActionButton from '@/app/components/base/action-button'
- import { type NodePanelProps } from '@/app/components/workflow/types'
- const i18nPrefix = 'workflow.nodes.assigner'
- const Panel: FC<NodePanelProps<AssignerNodeType>> = ({
- id,
- data,
- }) => {
- const { t } = useTranslation()
- const handleAddOperationItem = useHandleAddOperationItem()
- const {
- readOnly,
- inputs,
- handleOperationListChanges,
- getAssignedVarType,
- getToAssignedVarType,
- writeModeTypesNum,
- writeModeTypesArr,
- writeModeTypes,
- filterAssignedVar,
- filterToAssignedVar,
- } = useConfig(id, data)
- const handleAddOperation = () => {
- const newList = handleAddOperationItem(inputs.items || [])
- handleOperationListChanges(newList)
- }
- return (
- <div className='flex py-2 flex-col items-start self-stretch'>
- <div className='flex flex-col justify-center items-start gap-1 px-4 py-2 w-full self-stretch'>
- <div className='flex items-start gap-2 self-stretch'>
- <div className='flex flex-col justify-center items-start flex-grow text-text-secondary system-sm-semibold-uppercase'>{t(`${i18nPrefix}.variables`)}</div>
- <ActionButton onClick={handleAddOperation}>
- <RiAddLine className='w-4 h-4 shrink-0 text-text-tertiary' />
- </ActionButton>
- </div>
- <VarList
- readonly={readOnly}
- nodeId={id}
- list={inputs.items || []}
- onChange={(newList) => {
- handleOperationListChanges(newList)
- }}
- filterVar={filterAssignedVar}
- filterToAssignedVar={filterToAssignedVar}
- getAssignedVarType={getAssignedVarType}
- writeModeTypes={writeModeTypes}
- writeModeTypesArr={writeModeTypesArr}
- writeModeTypesNum={writeModeTypesNum}
- getToAssignedVarType={getToAssignedVarType}
- />
- </div>
- </div>
- )
- }
- export default React.memo(Panel)
|