| /* | |
| Copyright (C) 2025 QuantumNous | |
| This program is free software: you can redistribute it and/or modify | |
| it under the terms of the GNU Affero General Public License as | |
| published by the Free Software Foundation, either version 3 of the | |
| License, or (at your option) any later version. | |
| This program is distributed in the hope that it will be useful, | |
| but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| GNU Affero General Public License for more details. | |
| You should have received a copy of the GNU Affero General Public License | |
| along with this program. If not, see <https://www.gnu.org/licenses/>. | |
| For commercial licensing, please contact support@quantumnous.com | |
| */ | |
| import React from 'react'; | |
| const CustomInputRender = (props) => { | |
| const { detailProps } = props; | |
| const { clearContextNode, uploadNode, inputNode, sendNode, onClick } = | |
| detailProps; | |
| // 清空按钮 | |
| const styledClearNode = clearContextNode | |
| ? React.cloneElement(clearContextNode, { | |
| className: `!rounded-full !bg-gray-100 hover:!bg-red-500 hover:!text-white flex-shrink-0 transition-all ${clearContextNode.props.className || ''}`, | |
| style: { | |
| ...clearContextNode.props.style, | |
| width: '32px', | |
| height: '32px', | |
| minWidth: '32px', | |
| padding: 0, | |
| display: 'flex', | |
| alignItems: 'center', | |
| justifyContent: 'center', | |
| }, | |
| }) | |
| : null; | |
| // 发送按钮 | |
| const styledSendNode = React.cloneElement(sendNode, { | |
| className: `!rounded-full !bg-purple-500 hover:!bg-purple-600 flex-shrink-0 transition-all ${sendNode.props.className || ''}`, | |
| style: { | |
| ...sendNode.props.style, | |
| width: '32px', | |
| height: '32px', | |
| minWidth: '32px', | |
| padding: 0, | |
| display: 'flex', | |
| alignItems: 'center', | |
| justifyContent: 'center', | |
| }, | |
| }); | |
| return ( | |
| <div className='p-2 sm:p-4'> | |
| <div | |
| className='flex items-center gap-2 sm:gap-3 p-2 bg-gray-50 rounded-xl sm:rounded-2xl shadow-sm hover:shadow-md transition-shadow' | |
| style={{ border: '1px solid var(--semi-color-border)' }} | |
| onClick={onClick} | |
| > | |
| {/* 清空对话按钮 - 左边 */} | |
| {styledClearNode} | |
| <div className='flex-1'>{inputNode}</div> | |
| {/* 发送按钮 - 右边 */} | |
| {styledSendNode} | |
| </div> | |
| </div> | |
| ); | |
| }; | |
| export default CustomInputRender; | |