| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 | import React from 'react'import { useTranslation } from 'react-i18next'import { Message3Fill } from '@/app/components/base/icons/src/public/other'import Button from '@/app/components/base/button'import Divider from '@/app/components/base/divider'import InputsFormContent from '@/app/components/base/chat/chat-with-history/inputs-form/content'import { useChatWithHistoryContext } from '../context'import cn from '@/utils/classnames'type Props = {  collapsed: boolean  setCollapsed: (collapsed: boolean) => void}const InputsFormNode = ({  collapsed,  setCollapsed,}: Props) => {  const { t } = useTranslation()  const {    isMobile,    currentConversationId,    handleStartChat,    themeBuilder,  } = useChatWithHistoryContext()  return (    <div className={cn('flex flex-col items-center px-4 pt-6', isMobile && 'pt-4')}>      <div className={cn(        'w-full max-w-[672px] rounded-2xl border-[0.5px] border-components-panel-border bg-components-panel-bg shadow-md',        collapsed && 'border border-components-card-border bg-components-card-bg shadow-none',      )}>        <div className={cn(          'flex items-center gap-3 rounded-t-2xl px-6 py-4',          !collapsed && 'border-b border-divider-subtle',          isMobile && 'px-4 py-3',        )}>          <Message3Fill className='h-6 w-6 shrink-0' />          <div className='system-xl-semibold grow text-text-secondary'>{t('share.chat.chatSettingsTitle')}</div>          {collapsed && (            <Button className='uppercase text-text-tertiary' size='small' variant='ghost' onClick={() => setCollapsed(false)}>{currentConversationId ? t('common.operation.view') : t('common.operation.edit')}</Button>          )}          {!collapsed && currentConversationId && (            <Button className='uppercase text-text-tertiary' size='small' variant='ghost' onClick={() => setCollapsed(true)}>{t('common.operation.close')}</Button>          )}        </div>        {!collapsed && (          <div className={cn('p-6', isMobile && 'p-4')}>            <InputsFormContent showTip={!!currentConversationId} />          </div>        )}        {!collapsed && !currentConversationId && (          <div className={cn('p-6', isMobile && 'p-4')}>            <Button              variant='primary'              className='w-full'              onClick={() => handleStartChat(() => setCollapsed(true))}              style={                themeBuilder?.theme                  ? {                    backgroundColor: themeBuilder?.theme.primaryColor,                  }                  : {}              }            >{t('share.chat.startChat')}</Button>          </div>        )}      </div>      {collapsed && (        <div className='flex w-full max-w-[720px] items-center py-4'>          <Divider bgStyle='gradient' className='h-px basis-1/2 rotate-180' />          <Divider bgStyle='gradient' className='h-px basis-1/2' />        </div>      )}    </div>  )}export default InputsFormNode
 |