Files
supabase/apps/studio/components/layouts/TableEditorLayout/TableMenuEmptyState.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

48 lines
2.0 KiB
TypeScript

import { Pointer } from 'lucide-react'
import { cn, TreeViewItemVariant } from 'ui'
import { InnerSideBarEmptyPanel } from 'ui-patterns/InnerSideMenu'
import { EntityTypeIcon } from '@/components/ui/EntityTypeIcon'
export const TableMenuEmptyState = () => {
return (
<InnerSideBarEmptyPanel
title="No tables or views"
description="Any tables or views you create will be listed here."
className="mx-4"
>
<div className="top-0 left-6 flex flex-col opacity-50 cursor-not-allowed bg-dash-sidebar h-content -mb-7 pointer-events-none scale-75">
<div className="relative h-content">
<div className="absolute inset-0 pointer-events-none z-10">
<div className="absolute inset-0 bg-linear-to-t from-transparent from-80% to-100% to-background-surface-100 dark:to-background-surface-75" />
<div className="absolute inset-0 bg-linear-to-r from-transparent from-50% to-100% to-background-surface-100 dark:to-background-surface-75" />
</div>
<div className="absolute left-[150px] bottom-[21px] text-foreground-muted z-10 pointer-events-none">
<Pointer size={16} className="text-foreground-light" strokeWidth={1.5} />
</div>
{[...Array(4)].map((_, i) => (
<div className="border-l pointer-events-none" key={`some-${i}`}>
<div
className={cn(
'group',
TreeViewItemVariant({
isSelected: i === 2 ? true : false,
isOpened: i === 2 ? true : false,
isPreview: false,
}),
'px-4 min-w-40'
)}
aria-selected={i === 2}
>
{i === 2 && <div className="absolute left-0 h-full w-0.5 bg-foreground" />}
<EntityTypeIcon type={'r'} />
{`postgres_table_${i}`}
</div>
</div>
))}
</div>
</div>
</InnerSideBarEmptyPanel>
)
}