PolicyReview() — supabase Function Reference
Architecture documentation for the PolicyReview() function in PolicyReview.tsx from the supabase codebase.
Entity Profile
Relationship Graph
Source Code
apps/studio/components/interfaces/Auth/Policies/PolicyReview.tsx lines 13–65
const PolicyReview = ({
policy = {},
onSelectBack = noop,
onSelectSave = noop,
}: PolicyReviewProps) => {
const [isSaving, setIsSaving] = useState(false)
const onSavePolicy = () => {
setIsSaving(true)
onSelectSave()
}
let formattedSQLStatement = policy.statement || ''
return (
<>
<Modal.Content>
<div className="space-y-6">
<div className="flex items-center justify-between space-y-8">
<div className="flex flex-col">
<p className="text-sm text-foreground-light">
This is the SQL statement that will be used to create your policy.
</p>
</div>
</div>
<div className="space-y-4 overflow-y-auto" style={{ maxHeight: '25rem' }}>
{isEmpty(policy) ? (
<div className="my-10 flex items-center justify-center space-x-2 opacity-50">
<p className="text-base text-foreground-light">
There are no changes made to this policy
</p>
</div>
) : (
<div className="space-y-2">
<span>{policy.description}</span>
<div className="h-40">
<SqlEditor readOnly defaultValue={formattedSQLStatement} />
</div>
</div>
)}
</div>
</div>
</Modal.Content>
<div className="flex w-full items-center justify-end gap-2 border-t px-6 py-4 border-default">
<Button type="default" onClick={onSelectBack}>
Back to edit
</Button>
<Button type="primary" disabled={isEmpty(policy)} onClick={onSavePolicy} loading={isSaving}>
Save policy
</Button>
</div>
</>
)
}
Domain
Subdomains
Source
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free