mirror of
https://github.com/supabase/supabase.git
synced 2026-05-22 17:00:43 +08:00
* Update API keys panel * Dnywh/chore/fe 2195 design pass (#41484) * first pass * fancy * fixes * text * lang * lang --------- Co-authored-by: Danny White <3104761+dnywh@users.noreply.github.com> * Clean up * Clean * Nit * Update enabled features --------- Co-authored-by: Danny White <3104761+dnywh@users.noreply.github.com>
49 lines
1.2 KiB
TypeScript
49 lines
1.2 KiB
TypeScript
import { useTheme } from 'next-themes'
|
|
import Image from 'next/image'
|
|
|
|
import { BASE_PATH } from 'lib/constants'
|
|
import { cn } from 'ui'
|
|
|
|
interface ConnectionIconProps {
|
|
icon: string
|
|
iconFolder?: string
|
|
supportsDarkMode?: boolean
|
|
size?: number
|
|
className?: string
|
|
}
|
|
|
|
export const ConnectionIcon = ({
|
|
icon,
|
|
iconFolder,
|
|
supportsDarkMode,
|
|
size = 14,
|
|
className,
|
|
}: ConnectionIconProps) => {
|
|
const { resolvedTheme } = useTheme()
|
|
|
|
const imageFolder =
|
|
iconFolder || (['ionic-angular'].includes(icon) ? 'icons/frameworks' : 'libraries')
|
|
|
|
const imageExtension = imageFolder === 'icons/frameworks' ? '' : '-icon'
|
|
|
|
const shouldUseDarkMode =
|
|
supportsDarkMode ||
|
|
['expo', 'nextjs', 'prisma', 'drizzle', 'astro', 'remix', 'refine'].includes(icon.toLowerCase())
|
|
|
|
const iconImgSrc = icon.startsWith('http')
|
|
? icon
|
|
: `${BASE_PATH}/img/${imageFolder}/${icon.toLowerCase()}${
|
|
shouldUseDarkMode && resolvedTheme?.includes('dark') ? '-dark' : ''
|
|
}${imageExtension}.svg`
|
|
|
|
return (
|
|
<Image
|
|
className={cn('transition-all group-hover:scale-110', className)}
|
|
src={iconImgSrc}
|
|
alt={`${icon} logo`}
|
|
width={size}
|
|
height={size}
|
|
/>
|
|
)
|
|
}
|