mirror of
https://github.com/supabase/supabase.git
synced 2026-06-13 10:09:12 +08:00
## What kind of change does this PR introduce? UI polish. ## What is the current behavior? - A few product sidebar areas render menu rows outside the shared ProductMenu/Menu.Item styling path, so their hover and selected states differ from the rest of Studio. - Database product menu shortcut tooltips are also scoped to the text label instead of the full hoverable row. ## What is the new behavior? - Integrations Explore/Installed, Observability, and Reports sidebar rows now use the shared ProductMenu or Menu.Item pill styling. - Observability spacing is tightened after the ProductMenu conversion. - Product menu shortcut tooltips now wrap the full row trigger, so the entire Database sidebar row opens the tooltip. <!-- This is an auto-generated comment: release notes by coderabbit.ai --> ## Summary by CodeRabbit * **Refactor** * Enhanced navigation menu components with improved loading and error state handling across the dashboard. * Streamlined menu structure and styling consistency for integrations, reports, and observability sections. * Added enhanced tooltip support for navigation items. <!-- end of auto-generated comment: release notes by coderabbit.ai -->
94 lines
3.1 KiB
TypeScript
94 lines
3.1 KiB
TypeScript
import { useParams } from 'common'
|
|
import { useRouter } from 'next/router'
|
|
import { Menu, Separator } from 'ui'
|
|
import { GenericSkeletonLoader } from 'ui-patterns'
|
|
|
|
import { getCategoryParamFromAsPath, getIntegrationsPageFromPathname } from './Integrations.utils'
|
|
import { generateIntegrationsMenu } from './IntegrationsMenu.utils'
|
|
import { useInstalledIntegrations } from '@/components/interfaces/Integrations/Landing/useInstalledIntegrations'
|
|
import AlertError from '@/components/ui/AlertError'
|
|
import { ProductMenu } from '@/components/ui/ProductMenu'
|
|
import { useIsFeatureEnabled } from '@/hooks/misc/useIsFeatureEnabled'
|
|
import { useSelectedProjectQuery } from '@/hooks/misc/useSelectedProject'
|
|
import { getPathnameWithoutQuery } from '@/lib/pathname.utils'
|
|
|
|
export function IntegrationsProductMenu() {
|
|
const router = useRouter()
|
|
const { ref: projectRef } = useParams()
|
|
const { data: project } = useSelectedProjectQuery()
|
|
const { integrationsWrappers: showWrappers } = useIsFeatureEnabled(['integrations:wrappers'])
|
|
const resolvedProjectRef = projectRef ?? project?.ref
|
|
|
|
const pathname = getPathnameWithoutQuery(router.asPath, router.pathname)
|
|
const page = getIntegrationsPageFromPathname(pathname)
|
|
const categoryParam = getCategoryParamFromAsPath(router.asPath)
|
|
|
|
const {
|
|
installedIntegrations: integrations,
|
|
error,
|
|
isLoading,
|
|
isSuccess,
|
|
isError,
|
|
} = useInstalledIntegrations()
|
|
|
|
const resolvedPage =
|
|
page === 'integrations'
|
|
? categoryParam
|
|
? `integrations-${categoryParam}`
|
|
: 'integrations'
|
|
: page
|
|
|
|
return (
|
|
<>
|
|
<ProductMenu
|
|
page={resolvedPage}
|
|
menu={generateIntegrationsMenu({ projectRef, flags: { showWrappers } })}
|
|
/>
|
|
<Separator />
|
|
{isSuccess && resolvedProjectRef ? (
|
|
<ProductMenu
|
|
page={page}
|
|
menu={[
|
|
{
|
|
key: 'installed',
|
|
title: 'Installed',
|
|
items: integrations.map((integration) => ({
|
|
name: integration.name,
|
|
label: integration.status,
|
|
key: `integrations/${integration.id}`,
|
|
url: `/project/${resolvedProjectRef}/integrations/${integration.id}/overview`,
|
|
icon: (
|
|
<div className="relative w-6 h-6 bg-white border rounded-sm flex items-center justify-center">
|
|
{integration.icon({ className: 'p-1' })}
|
|
</div>
|
|
),
|
|
items: [],
|
|
})),
|
|
},
|
|
]}
|
|
/>
|
|
) : (
|
|
<div className="px-4 py-6 md:px-6">
|
|
<Menu type="pills">
|
|
<Menu.Group
|
|
title={
|
|
<div className="flex flex-col space-y-2 uppercase font-mono">
|
|
<span>Installed</span>
|
|
</div>
|
|
}
|
|
/>
|
|
</Menu>
|
|
{isLoading && <GenericSkeletonLoader />}
|
|
{isError && (
|
|
<AlertError
|
|
showIcon={false}
|
|
error={error}
|
|
subject="Failed to retrieve installed integrations"
|
|
/>
|
|
)}
|
|
</div>
|
|
)}
|
|
</>
|
|
)
|
|
}
|