Files
supabase/apps/studio/components/ui/AIAssistantPanel/AIOptInModal.tsx
Ivan Vasilov 56de26fe22 chore: Migrate the monorepo to use Tailwind v4 (#45318)
This PR migrates the whole monorepo to use Tailwind v4:
- Removed `@tailwindcss/container-queries` plugin since it's included by
default in v4,
- Bump all instances of Tailwind to v4. Made minimal changes to the
shared config to remove non-supported features (`alpha` mentions),
- Migrate all apps to be compatible with v4 configs,
- Fix the `typography.css` import in 3 apps,
- Add missing rules which were included by default in v3,
- Run `pnpm dlx @tailwindcss/upgrade` on all apps, which renames a lot
of classes
- Rename all misnamed classes according to
https://tailwindcss.com/docs/upgrade-guide#renamed-utilities in all
apps.

---------

Co-authored-by: Jordi Enric <jordi.err@gmail.com>
2026-04-30 10:53:24 +00:00

92 lines
2.7 KiB
TypeScript

import { PermissionAction } from '@supabase/shared-types/out/constants'
import { useEffect } from 'react'
import {
Button,
cn,
Dialog,
DialogContent,
DialogFooter,
DialogHeader,
DialogSection,
DialogSectionSeparator,
DialogTitle,
Form,
} from 'ui'
import { AIOptInLevelSelector } from '@/components/interfaces/Organization/GeneralSettings/AIOptInLevelSelector'
import { useAIOptInForm } from '@/hooks/forms/useAIOptInForm'
import { useAsyncCheckPermissions } from '@/hooks/misc/useCheckPermissions'
interface AIOptInModalProps {
visible: boolean
onCancel: () => void
}
export const AIOptInModal = ({ visible, onCancel }: AIOptInModalProps) => {
const { form, onSubmit, isUpdating, currentOptInLevel } = useAIOptInForm(onCancel)
const { can: canUpdateOrganization } = useAsyncCheckPermissions(
PermissionAction.UPDATE,
'organizations'
)
const onOpenChange = (open: boolean) => {
if (!open) {
onCancel()
}
}
useEffect(() => {
if (visible) {
form.reset({ aiOptInLevel: currentOptInLevel })
}
}, [visible, currentOptInLevel, form])
return (
<Dialog open={visible} onOpenChange={onOpenChange}>
<DialogContent size="large" aria-describedby={undefined}>
<Form {...form}>
<form id="ai-opt-in-form" onSubmit={form.handleSubmit(onSubmit)}>
<DialogHeader padding="small">
<DialogTitle>Update Supabase Assistant Opt-in Level</DialogTitle>
</DialogHeader>
<DialogSectionSeparator />
<DialogSection className="space-y-4 pb-0" padding="small">
<AIOptInLevelSelector
control={form.control}
disabled={!canUpdateOrganization || isUpdating}
/>
</DialogSection>
<DialogFooter
padding="small"
className={cn(!canUpdateOrganization && 'justify-between!')}
>
{!canUpdateOrganization && (
<p className="text-sm text-foreground-lighter">
You need additional permissions to update the opt-in level
</p>
)}
<div className="flex items-center gap-x-2">
<Button type="default" disabled={isUpdating} onClick={onCancel}>
Cancel
</Button>
<Button
type="primary"
htmlType="submit"
form="ai-opt-in-form"
loading={isUpdating}
disabled={isUpdating || !canUpdateOrganization || !form.formState.isDirty}
>
Confirm
</Button>
</div>
</DialogFooter>
</form>
</Form>
</DialogContent>
</Dialog>
)
}