mirror of
https://github.com/supabase/supabase.git
synced 2026-05-09 10:19:50 -04:00
56de26fe22
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>
116 lines
3.5 KiB
TypeScript
116 lines
3.5 KiB
TypeScript
import { useState } from 'react'
|
|
import {
|
|
Button,
|
|
Dialog,
|
|
DialogContent,
|
|
DialogFooter,
|
|
DialogHeader,
|
|
DialogSection,
|
|
DialogSectionSeparator,
|
|
DialogTitle,
|
|
DialogTrigger,
|
|
} from 'ui'
|
|
import { Admonition } from 'ui-patterns'
|
|
|
|
import { INTERNAL_SCHEMAS, useIsProtectedSchema } from '@/hooks/useProtectedSchemas'
|
|
|
|
export const ProtectedSchemaDialog = ({ onClose }: { onClose: () => void }) => {
|
|
return (
|
|
<>
|
|
<DialogHeader>
|
|
<DialogTitle>Schemas managed by Supabase</DialogTitle>
|
|
</DialogHeader>
|
|
<DialogSectionSeparator />
|
|
<DialogSection className="space-y-2 prose">
|
|
<p className="text-sm">
|
|
The following schemas are managed by Supabase and are currently protected from write
|
|
access through the dashboard.
|
|
</p>
|
|
<div className="flex flex-wrap gap-1">
|
|
{INTERNAL_SCHEMAS.map((schema) => (
|
|
<code key={schema} className="text-xs">
|
|
{schema}
|
|
</code>
|
|
))}
|
|
</div>
|
|
<p className="text-sm mt-4!">
|
|
These schemas are critical to the functionality of your Supabase project and hence we
|
|
highly recommend not altering them.
|
|
</p>
|
|
<p className="text-sm">
|
|
You can, however, still interact with those schemas through the SQL Editor although we
|
|
advise you only do so if you know what you are doing.
|
|
</p>
|
|
</DialogSection>
|
|
<DialogFooter>
|
|
<div className="flex items-center justify-end space-x-2">
|
|
<Button type="default" onClick={onClose}>
|
|
Understood
|
|
</Button>
|
|
</div>
|
|
</DialogFooter>
|
|
</>
|
|
)
|
|
}
|
|
|
|
export const ProtectedSchemaWarning = ({
|
|
size = 'md',
|
|
schema,
|
|
entity,
|
|
}: {
|
|
size?: 'sm' | 'md'
|
|
schema: string
|
|
entity: string
|
|
}) => {
|
|
const [showModal, setShowModal] = useState(false)
|
|
const { isSchemaLocked, reason, fdwType } = useIsProtectedSchema({ schema })
|
|
|
|
if (!isSchemaLocked) return null
|
|
|
|
const showLearnMoreDialog =
|
|
reason !== 'fdw' || (fdwType !== 'iceberg' && fdwType !== 's3_vectors')
|
|
|
|
return (
|
|
<Admonition
|
|
showIcon={size === 'sm' ? false : true}
|
|
layout={size === 'sm' ? 'vertical' : 'horizontal'}
|
|
type="note"
|
|
title={
|
|
size === 'sm' ? `Viewing protected schema` : `Viewing ${entity} from a protected schema`
|
|
}
|
|
description={
|
|
reason === 'fdw' && fdwType === 'iceberg' ? (
|
|
<p>
|
|
The <code className="text-code-inline">{schema}</code> schema is used by Supabase to
|
|
connect to analytics buckets and is read-only through the dashboard.
|
|
</p>
|
|
) : reason === 'fdw' && fdwType === 's3_vectors' ? (
|
|
<p>
|
|
The <code className="text-code-inline">{schema}</code> schema is used by Supabase to
|
|
connect to vector buckets and is read-only through the dashboard.
|
|
</p>
|
|
) : (
|
|
<p>
|
|
The <code className="text-code-inline">{schema}</code> schema is managed by Supabase and
|
|
is read-only through the dashboard.
|
|
</p>
|
|
)
|
|
}
|
|
actions={
|
|
showLearnMoreDialog && (
|
|
<Dialog open={showModal} onOpenChange={setShowModal}>
|
|
<DialogTrigger asChild>
|
|
<Button type="default" size="tiny" onClick={() => setShowModal(true)}>
|
|
Learn more
|
|
</Button>
|
|
</DialogTrigger>
|
|
<DialogContent>
|
|
<ProtectedSchemaDialog onClose={() => setShowModal(false)} />
|
|
</DialogContent>
|
|
</Dialog>
|
|
)
|
|
}
|
|
/>
|
|
)
|
|
}
|