wwf
3 天以前 a430284aa21e3ae1f0d5654e55b2ad2852519cc2
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
import React, { useCallback } from 'react'
import Button from '@/app/components/base/button'
import { RiAddCircleFill } from '@remixicon/react'
import { useTranslation } from 'react-i18next'
import { useVisualEditorStore } from './store'
import { useMittContext } from './context'
 
const AddField = () => {
  const { t } = useTranslation()
  const setIsAddingNewField = useVisualEditorStore(state => state.setIsAddingNewField)
  const { emit } = useMittContext()
 
  const handleAddField = useCallback(() => {
    setIsAddingNewField(true)
    emit('addField', { path: [] })
  }, [setIsAddingNewField, emit])
 
  return (
    <div className='py-2 pl-5'>
      <Button
        size='small'
        variant='secondary-accent'
        className='flex items-center gap-x-[1px]'
        onClick={handleAddField}
      >
        <RiAddCircleFill className='h-3.5 w-3.5'/>
        <span className='px-[3px]'>{t('workflow.nodes.llm.jsonSchema.addField')}</span>
      </Button>
    </div>
  )
}
 
export default React.memo(AddField)