-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathroute-provider-create.tsx
54 lines (49 loc) · 1.58 KB
/
route-provider-create.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
import {
AddProviderEndpointRequest,
ProviderAuthType,
ProviderType,
} from '@/api/generated'
import { ProviderDialog } from '@/features/providers/components/provider-dialog'
import { ProviderDialogFooter } from '@/features/providers/components/provider-dialog-footer'
import { ProviderForm } from '@/features/providers/components/provider-form'
import { useMutationCreateProvider } from '@/features/providers/hooks/use-mutation-create-provider'
import { getProviderEndpointByAuthType } from '@/features/providers/lib/utils'
import { DialogContent, Form } from '@stacklok/ui-kit'
import { useState } from 'react'
const DEFAULT_PROVIDER_STATE = {
name: '',
description: '',
auth_type: ProviderAuthType.API_KEY,
provider_type: ProviderType.OPENAI,
endpoint: '',
api_key: '',
}
export function RouteProviderCreate() {
const [provider, setProvider] = useState<AddProviderEndpointRequest>({
...DEFAULT_PROVIDER_STATE,
endpoint: getProviderEndpointByAuthType(
DEFAULT_PROVIDER_STATE.provider_type
),
})
const { mutateAsync } = useMutationCreateProvider()
const handleSubmit = (event: React.FormEvent) => {
event.preventDefault()
mutateAsync({
body: provider,
})
}
return (
<ProviderDialog title="Add provider">
<Form
onSubmit={handleSubmit}
validationBehavior="aria"
className="overflow-auto"
>
<DialogContent className="p-8">
<ProviderForm provider={provider} setProvider={setProvider} />
</DialogContent>
<ProviderDialogFooter />
</Form>
</ProviderDialog>
)
}