Files
supabase/apps/docs/components/Frameworks.tsx
Jonathan Summers-Muir db7870d21f fix images
2022-12-08 14:27:28 +08:00

107 lines
2.5 KiB
TypeScript

import ButtonCard from './ButtonCard'
import { useTheme } from 'common/Providers'
const Frameworks = () => {
const { isDarkMode } = useTheme()
const frameworks = [
{
name: 'Angular',
logo: {
light: '/docs/img/icons/angular-icon.svg',
dark: '/docs/img/icons/angular-icon.svg',
},
href: '/guides/with-angular',
},
{
name: 'Expo',
logo: {
light: '/docs/img/icons/expo-icon.svg',
dark: '/docs/img/icons/expo-icon-dark.svg',
},
href: '/guides/with-expo',
},
{
name: 'Flutter',
logo: {
light: '/docs/img/icons/flutter-icon.svg',
dark: '/docs/img/icons/flutter-icon.svg',
},
href: '/guides/with-flutter',
},
{
name: 'JavaScript',
logo: {
light: '/docs/img/icons/javascript-icon.svg',
dark: '/docs/img/icons/javascript-icon.svg',
},
href: '/reference/javascript/installing#javascript',
},
{
name: 'Next.js',
logo: {
light: '/docs/img/icons/nextjs-light-icon.svg',
dark: '/docs/img/icons/nextjs-dark-icon.svg',
},
href: '/guides/with-nextjs',
},
{
name: 'React',
logo: {
light: '/docs/img/icons/react-icon.svg',
dark: '/docs/img/icons/react-icon.svg',
},
href: '/guides/with-react',
},
{
name: 'RedwoodJS',
logo: {
light: '/docs/img/icons/redwoodjs-icon.svg',
dark: '/docs/img/icons/redwoodjs-icon.svg',
},
href: '/guides/with-redwoodjs',
},
{
name: 'SolidJS',
logo: {
light: '/docs/img/icons/solidjs-icon.svg',
dark: '/docs/img/icons/solidjs-icon.svg',
},
href: '/guides/with-solidjs',
},
{
name: 'Svelte',
logo: {
light: '/docs/img/icons/svelte-icon.svg',
dark: '/docs/img/icons/svelte-icon.svg',
},
href: '/guides/with-svelte',
},
{
name: 'Vue',
logo: {
light: '/docs/img/icons/vuejs-icon.svg',
dark: '/docs/img/icons/vuejs-icon.svg',
},
href: '/guides/with-vue-3',
},
]
return (
<div className="grid md:grid-cols-12 gap-4 not-prose">
{frameworks.map((x) => (
<div key={x.name} className="col-span-3">
<ButtonCard
layout="horizontal"
to={x.href}
title={x.name}
// [Joshen] Nice to have: theming
icon={isDarkMode ? x.logo.dark : x.logo.light}
/>
</div>
))}
</div>
)
}
export default Frameworks