1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 |
- import { useTranslation } from 'react-i18next'
- import Image from 'next/image'
- import SerpapiLogo from '../../assets/serpapi.png'
- import KeyValidator from '../key-validator'
- import type { Form, ValidateValue } from '../key-validator/declarations'
- import { updatePluginKey, validatePluginKey } from './utils'
- import { useToastContext } from '@/app/components/base/toast'
- import type { PluginProvider } from '@/models/common'
- import { useAppContext } from '@/context/app-context'
- type SerpapiPluginProps = {
- plugin: PluginProvider
- onUpdate: () => void
- }
- const SerpapiPlugin = ({
- plugin,
- onUpdate,
- }: SerpapiPluginProps) => {
- const { t } = useTranslation()
- const { isCurrentWorkspaceManager } = useAppContext()
- const { notify } = useToastContext()
- const forms: Form[] = [{
- key: 'api_key',
- title: t('common.plugin.serpapi.apiKey'),
- placeholder: t('common.plugin.serpapi.apiKeyPlaceholder'),
- value: plugin.credentials?.api_key,
- validate: {
- before: (v) => {
- if (v?.api_key)
- return true
- },
- run: async (v) => {
- return validatePluginKey('serpapi', {
- credentials: {
- api_key: v?.api_key,
- },
- })
- },
- },
- handleFocus: (v, dispatch) => {
- if (v.api_key === plugin.credentials?.api_key)
- dispatch({ ...v, api_key: '' })
- },
- }]
- const handleSave = async (v: ValidateValue) => {
- if (!v?.api_key || v?.api_key === plugin.credentials?.api_key)
- return
- const res = await updatePluginKey('serpapi', {
- credentials: {
- api_key: v?.api_key,
- },
- })
- if (res.status === 'success') {
- notify({ type: 'success', message: t('common.actionMsg.modifiedSuccessfully') })
- onUpdate()
- return true
- }
- }
- return (
- <KeyValidator
- type='serpapi'
- title={<Image alt='serpapi logo' src={SerpapiLogo} width={64} />}
- status={plugin.credentials?.api_key ? 'success' : 'add'}
- forms={forms}
- keyFrom={{
- text: t('common.plugin.serpapi.keyFrom'),
- link: 'https://serpapi.com/manage-api-key',
- }}
- onSave={handleSave}
- disabled={!isCurrentWorkspaceManager}
- />
- )
- }
- export default SerpapiPlugin
|