DeleteOrganizationButton() — supabase Function Reference
Architecture documentation for the DeleteOrganizationButton() function in DeleteOrganizationButton.tsx from the supabase codebase.
Entity Profile
Relationship Graph
Source Code
apps/studio/components/interfaces/Organization/GeneralSettings/DeleteOrganizationButton.tsx lines 14–141
export const DeleteOrganizationButton = () => {
const router = useRouter()
const { data: selectedOrganization } = useSelectedOrganizationQuery()
const { slug: orgSlug, name: orgName } = selectedOrganization ?? {}
const [isOpen, setIsOpen] = useState(false)
const [value, setValue] = useState('')
const [_, setLastVisitedOrganization] = useLocalStorageQuery(
LOCAL_STORAGE_KEYS.LAST_VISITED_ORGANIZATION,
''
)
const { can: canDeleteOrganization } = useAsyncCheckPermissions(
PermissionAction.UPDATE,
'organizations'
)
const { mutate: deleteOrganization, isPending: isDeleting } = useOrganizationDeleteMutation({
onSuccess: () => {
toast.success(`Successfully deleted ${orgName}`)
setLastVisitedOrganization('')
router.push('/organizations')
},
})
const onValidate = (values: any) => {
const errors: any = {}
if (!values.orgName) {
errors.orgName = 'Enter the name of the organization.'
}
if (values.orgName.trim() !== orgSlug?.trim()) {
errors.orgName = 'Value entered does not match the value above.'
}
return errors
}
const onConfirmDelete = async (values: any) => {
if (!canDeleteOrganization) {
return toast.error('You do not have the required permissions to delete this organization')
}
if (!orgSlug) return console.error('Org slug is required')
deleteOrganization({ slug: orgSlug })
}
return (
<>
<div className="mt-2">
<ButtonTooltip
type="danger"
disabled={!canDeleteOrganization}
loading={!orgSlug}
onClick={() => setIsOpen(true)}
tooltip={{
content: {
side: 'bottom',
text: !canDeleteOrganization
? 'You need additional permissions to delete this organization'
: undefined,
},
}}
>
Delete organization
</ButtonTooltip>
</div>
<Modal
hideFooter
size="small"
visible={isOpen}
onCancel={() => setIsOpen(false)}
header={
<div className="flex items-baseline gap-2">
<span>Delete organization</span>
<span className="text-xs text-foreground-lighter">Are you sure?</span>
</div>
}
>
<Form
validateOnBlur
initialValues={{ orgName: '' }}
onSubmit={onConfirmDelete}
validate={onValidate}
>
{() => (
<>
<Modal.Content>
<p className="text-sm text-foreground-lighter">
This action <span className="text-foreground">cannot</span> be undone. This will
permanently delete the <span className="text-foreground">{orgName}</span>{' '}
organization and remove all of its projects.
</p>
</Modal.Content>
<Modal.Separator />
<Modal.Content>
<Input
id="orgName"
label={
<span>
Please type <span className="font-bold">{orgSlug}</span> to confirm
</span>
}
onChange={(e) => setValue(e.target.value)}
value={value}
placeholder="Enter the string above"
className="w-full"
/>
</Modal.Content>
<Modal.Separator />
<Modal.Content>
<Button
block
size="small"
type="danger"
htmlType="submit"
loading={isDeleting}
disabled={isDeleting}
>
I understand, delete this organization
</Button>
</Modal.Content>
</>
)}
</Form>
</Modal>
</>
)
}
Domain
Subdomains
Source
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free