Spaces:
Paused
Paused
| import { useTranslation } from 'react-i18next' | |
| import Indicator from '../../indicator' | |
| import type { Status } from './declarations' | |
| type OperateProps = { | |
| isOpen: boolean | |
| status: Status | |
| disabled?: boolean | |
| onCancel: () => void | |
| onSave: () => void | |
| onAdd: () => void | |
| onEdit: () => void | |
| } | |
| const Operate = ({ | |
| isOpen, | |
| status, | |
| disabled, | |
| onCancel, | |
| onSave, | |
| onAdd, | |
| onEdit, | |
| }: OperateProps) => { | |
| const { t } = useTranslation() | |
| if (isOpen) { | |
| return ( | |
| <div className='flex items-center'> | |
| <div className=' | |
| flex items-center | |
| mr-[5px] px-3 h-7 rounded-md cursor-pointer | |
| text-xs font-medium text-gray-700 | |
| ' onClick={onCancel} > | |
| {t('common.operation.cancel')} | |
| </div> | |
| <div className=' | |
| flex items-center | |
| px-3 h-7 rounded-md cursor-pointer bg-primary-700 | |
| text-xs font-medium text-white | |
| ' onClick={onSave}> | |
| {t('common.operation.save')} | |
| </div> | |
| </div> | |
| ) | |
| } | |
| if (status === 'add') { | |
| return ( | |
| <div className={ | |
| `px-3 h-[28px] bg-white border border-gray-200 rounded-md cursor-pointer | |
| text-xs font-medium text-gray-700 flex items-center ${disabled && 'opacity-50 cursor-default'}}` | |
| } onClick={() => !disabled && onAdd()}> | |
| {t('common.provider.addKey')} | |
| </div> | |
| ) | |
| } | |
| if (status === 'fail' || status === 'success') { | |
| return ( | |
| <div className='flex items-center'> | |
| { | |
| status === 'fail' && ( | |
| <div className='flex items-center mr-4'> | |
| <div className='text-xs text-[#D92D20]'>{t('common.provider.invalidApiKey')}</div> | |
| <Indicator color='red' className='ml-2' /> | |
| </div> | |
| ) | |
| } | |
| { | |
| status === 'success' && ( | |
| <Indicator color='green' className='mr-4' /> | |
| ) | |
| } | |
| <div className={ | |
| `px-3 h-[28px] bg-white border border-gray-200 rounded-md cursor-pointer | |
| text-xs font-medium text-gray-700 flex items-center ${disabled && 'opacity-50 cursor-default'}}` | |
| } onClick={() => !disabled && onEdit()}> | |
| {t('common.provider.editKey')} | |
| </div> | |
| </div> | |
| ) | |
| } | |
| return null | |
| } | |
| export default Operate | |