12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788 |
- 'use client'
- import type { FC } from 'react'
- import React, { useEffect, useState } from 'react'
- import { useTranslation } from 'react-i18next'
- import cn from 'classnames'
- import { toolCredentialToFormSchemas } from '../../utils/to-form-schema'
- import type { Collection } from '../../types'
- import Drawer from '@/app/components/base/drawer-plus'
- import Button from '@/app/components/base/button'
- import { fetchBuiltInToolCredentialSchema } from '@/service/tools'
- import Loading from '@/app/components/base/loading'
- import Form from '@/app/components/header/account-setting/model-provider-page/model-modal/Form'
- type Props = {
- collection: Collection
- onCancel: () => void
- onSaved: (value: Record<string, any>) => void
- onRemove: () => void
- }
- const ConfigCredential: FC<Props> = ({
- collection,
- onCancel,
- onSaved,
- onRemove,
- }) => {
- const { t } = useTranslation()
- const [credentialSchema, setCredentialSchema] = useState<any>(null)
- const { team_credentials: credentialValue, name: collectionName } = collection
- useEffect(() => {
- fetchBuiltInToolCredentialSchema(collectionName).then((res) => {
- setCredentialSchema(toolCredentialToFormSchemas(res))
- })
- }, [])
- const [tempCredential, setTempCredential] = React.useState<any>(credentialValue)
- return (
- <Drawer
- isShow
- onHide={onCancel}
- title={t('tools.auth.setupModalTitle') as string}
- titleDescription={t('tools.auth.setupModalTitleDescription') as string}
- panelClassName='mt-2 !w-[480px]'
- maxWidthClassName='!max-w-[480px]'
- height='calc(100vh - 16px)'
- contentClassName='!bg-gray-100'
- headerClassName='!border-b-black/5'
- body={
- <div className='px-6 py-3 h-full'>
- {!credentialSchema
- ? <Loading type='app' />
- : (
- <>
- <Form
- value={tempCredential}
- onChange={(v) => {
- setTempCredential(v)
- }}
- formSchemas={credentialSchema}
- isEditMode={true}
- showOnVariableMap={{}}
- validating={false}
- inputClassName='!bg-gray-50'
- />
- <div className={cn(collection.is_team_authorization ? 'justify-between' : 'justify-end', 'mt-2 flex ')} >
- {
- collection.is_team_authorization && (
- <Button className='flex items-center h-8 !px-3 !text-[13px] font-medium !text-gray-700' onClick={onRemove}>{t('common.operation.remove')}</Button>
- )
- }
- < div className='flex space-x-2'>
- <Button className='flex items-center h-8 !px-3 !text-[13px] font-medium !text-gray-700' onClick={onCancel}>{t('common.operation.cancel')}</Button>
- <Button className='flex items-center h-8 !px-3 !text-[13px] font-medium' type='primary' onClick={() => onSaved(tempCredential)}>{t('common.operation.save')}</Button>
- </div>
- </div>
- </>
- )
- }
- </div >
- }
- isShowMask={true}
- clickOutsideNotOpen={false}
- />
- )
- }
- export default React.memo(ConfigCredential)
|