mirror of
https://github.com/supabase/supabase.git
synced 2026-05-08 09:50:33 -04:00
0facd341a6
## Problem We used to have a `_Shadcn_` suffix for all the shadcn form components because we also had `formik` form components. This is not needed anymore. ## Solution - Remove the suffix - Update all usages
71 lines
2.2 KiB
TypeScript
71 lines
2.2 KiB
TypeScript
import type { UseFormReturn } from 'react-hook-form'
|
|
import { CardContent, CardFooter, Form, FormControl, FormField, FormItem, Switch } from 'ui'
|
|
import { FormItemLayout } from 'ui-patterns/form/FormItemLayout/FormItemLayout'
|
|
|
|
import { DataApiDisabledAlert } from './DataApiDisabledAlert'
|
|
import type { DataApiFormValues } from './DataApiEnableSwitch.types'
|
|
import { FormActions } from '@/components/ui/Forms/FormActions'
|
|
|
|
export const DataApiEnableSwitchForm = ({
|
|
form,
|
|
formId,
|
|
disabled,
|
|
isBusy,
|
|
permissionsHelper,
|
|
onSubmit,
|
|
handleReset,
|
|
}: {
|
|
form: UseFormReturn<DataApiFormValues>
|
|
formId: string
|
|
disabled: boolean
|
|
isBusy: boolean
|
|
permissionsHelper: string | undefined
|
|
onSubmit: (values: DataApiFormValues) => void
|
|
handleReset: () => void
|
|
}) => {
|
|
const watchedEnabled = form.watch('enableDataApi')
|
|
|
|
return (
|
|
<Form {...form}>
|
|
<form id={formId} onSubmit={form.handleSubmit(onSubmit)}>
|
|
<CardContent>
|
|
<FormField
|
|
control={form.control}
|
|
name="enableDataApi"
|
|
render={({ field }) => (
|
|
<FormItem className="space-y-4">
|
|
<FormItemLayout
|
|
layout="flex-row-reverse"
|
|
label="Enable Data API"
|
|
description="When enabled you will be able to use any Supabase client library and PostgREST endpoints with any schema configured in the Settings tab."
|
|
>
|
|
<FormControl>
|
|
<Switch
|
|
size="large"
|
|
disabled={disabled}
|
|
checked={field.value}
|
|
onCheckedChange={field.onChange}
|
|
/>
|
|
</FormControl>
|
|
</FormItemLayout>
|
|
|
|
{!watchedEnabled && <DataApiDisabledAlert />}
|
|
</FormItem>
|
|
)}
|
|
/>
|
|
</CardContent>
|
|
<CardFooter>
|
|
<FormActions
|
|
form={formId}
|
|
isSubmitting={isBusy}
|
|
hasChanges={form.formState.isDirty}
|
|
handleReset={handleReset}
|
|
disabled={disabled}
|
|
helper={permissionsHelper}
|
|
/>
|
|
</CardFooter>
|
|
</form>
|
|
</Form>
|
|
)
|
|
}
|