Files
supabase/apps/studio/components/ui/Forms/FormSection.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

95 lines
2.0 KiB
TypeScript

import { Children } from 'react'
import { cn } from 'ui'
export const FormSection = ({
children,
id,
header,
disabled,
className,
}: {
children: React.ReactNode
id?: string
header?: React.ReactNode
disabled?: boolean
visible?: boolean
className?: string
}) => {
const classes = [
'grid grid-cols-12 gap-6 px-card py-4 md:py-8',
`${disabled ? ' opacity-30' : ' opacity-100'}`,
`${className}`,
]
return (
<div id={id} className={classes.join(' ')}>
{header}
{children}
</div>
)
}
export const FormSectionLabel = ({
children,
className = '',
description,
}: {
children: React.ReactNode | string
className?: string
description?: React.ReactNode
}) => {
if (description !== undefined) {
return (
<div className={cn('flex flex-col space-y-2 col-span-12 lg:col-span-5', className)}>
<label className="text-foreground text-sm">{children}</label>
{description}
</div>
)
} else {
return (
<label className={`text-foreground col-span-12 text-sm lg:col-span-5 ${className}`}>
{children}
</label>
)
}
}
const Shimmer = () => (
<div className="flex w-full flex-col gap-2">
<div className="shimmering-loader h-2 w-1/3 rounded-sm"></div>
<div className="flex flex-col justify-between space-y-2">
<div className="shimmering-loader h-[34px] w-2/3 rounded-sm" />
</div>
</div>
)
export const FormSectionContent = ({
children,
loading = true,
loaders,
fullWidth,
className,
}: {
children: React.ReactNode | string
loading?: boolean
loaders?: number
fullWidth?: boolean
className?: string
}) => {
return (
<div
className={`
relative col-span-12 flex flex-col gap-6 @lg:col-span-7
${fullWidth && 'col-span-12!'}
${className}
`}
>
{loading
? !!loaders
? new Array(loaders).fill(0).map((_, idx) => <Shimmer key={idx} />)
: Children.map(children, (_, idx) => <Shimmer key={idx} />)
: children}
</div>
)
}