Files
supabase/apps/www/components/AuthWidget/AuthWidgetSection.tsx
2022-08-19 10:16:04 -05:00

291 lines
13 KiB
TypeScript

import { createClient } from '@supabase/supabase-js'
import { Button } from '@supabase/ui'
import { useState } from 'react'
// Import Swiper React components
import { useRouter } from 'next/router'
import { ColorSwatchIcon, MenuIcon } from '@heroicons/react/outline'
import { Auth, ThemeSupa } from '@supabase/auth-ui-react'
import { useTheme } from '../Providers'
const supabase = createClient(
'https://rsnibhkhsbfnncjmwnkj.supabase.co',
'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJyb2xlIjoiYW5vbiIsImlhdCI6MTYxNTIxNDE1MywiZXhwIjoxOTMwNzkwMTUzfQ.OQEbAaTfgDdLCCht251P2JRD3QDnui6nsU8N-tZA_Mc'
)
function AuthWidgetSection() {
const { isDarkMode } = useTheme()
const { basePath } = useRouter()
const [radius, setRadius] = useState('4px')
const [brandColor, setBrandColor] = useState({
brand: 'var(--colors-brand9)',
brandAccent: 'var(--colors-brand11)',
brandAccent2: 'var(--colors-brand3)',
})
const [layout, setLayout] = useState('horizontal')
// // store API swiper instance
const [imageSwiper, setImageSwiper] = useState(undefined)
const [imageSwiperActiveIndex, setImageSwiperActiveIndex] = useState(0)
function handleNavChange(e: number) {
console.log(e)
setImageSwiperActiveIndex(e)
// @ts-ignore
imageSwiper.slideTo(e)
}
const AuthContainer = (props: any) => {
const { user } = Auth.useUser()
if (user) {
return (
<>
<p>Signed in: {user.email}</p>
<Button block onClick={() => props.supabaseClient.auth.signOut()}>
Sign out
</Button>
</>
)
}
return props.children
}
// rounded-xl rounded-3xl rounded-full // for purging
return (
<div className="sbui-tabs--alt overflow-hidden">
<div className={`dark:bg-scale-200 bg-scale-100 relative border py-2 pb-16`}>
<div className="sm:py-18 gap container relative mx-auto grid grid-cols-12 px-6 py-16 md:gap-16 md:py-24 lg:gap-16 lg:px-16 lg:py-24 xl:px-20">
<div className="relative z-10 col-span-12 mb-16 md:col-span-7 md:mb-0 lg:col-span-6">
<div className="relative lg:mx-auto lg:max-w-md">
<div className="glow-area transition-all"></div>
<div className="border-scale-400 dark:bg-scale-300 pointer-events-none relative rounded-xl border bg-white px-8 py-12 drop-shadow-sm">
<div className="mb-6 flex flex-col gap-6">
<div className="flex items-center gap-3">
<div
className="w-10 rounded-full p-2"
style={{
background: brandColor.brandAccent2,
color: brandColor.brand,
}}
>
<ColorSwatchIcon strokeWidth={1.5} />
</div>
<h1 className="text-scale-1200 text-2xl">Acme Industries</h1>
</div>
<p className="text-scale-1100 text-auth-widget-test">
Sign in today for Supa stuff
</p>
</div>
<Auth.UserContextProvider supabaseClient={supabase}>
<AuthContainer supabaseClient={supabase}>
<Auth
// @ts-ignore
socialLayout={layout}
theme={isDarkMode ? 'dark' : 'default'}
providers={['google', 'facebook', 'twitter']}
supabaseClient={supabase}
localization={{
lang: 'en',
}}
appearance={{
theme: ThemeSupa,
variables: {
default: {
colors: {
brand: brandColor.brand,
brandAccent: brandColor.brandAccent,
},
radii: {
borderRadiusButton: radius,
buttonBorderRadius: radius,
inputBorderRadius: radius,
},
},
},
}}
/>
</AuthContainer>
</Auth.UserContextProvider>
</div>
</div>
</div>
<div className="col-span-12 md:col-span-5 lg:col-span-6">
<div className="prose !max-w-md">
<h3 className="text-2xl">Auth UI</h3>
<p className="!mb-0">Pre-built auth widgets to get started in minutes.</p>
<p className="text-scale-900 mt-0">
Customizable authentication UI component with custom themes and extensible styles to
match your brand and aesthetic
</p>
<div className="mb-4 flex items-center space-x-2">
<img className="m-0 w-8" src={`${basePath}/images/product/auth/react-icon.svg`} />
<small>React only. Other frameworks coming soon.</small>
</div>
</div>
<div className="grid gap-8 py-8 lg:grid-cols-2">
<div className="flex flex-col gap-2">
<label className="text-scale-1200 text-base">Brand color</label>
<div className="flex items-center gap-3">
<button
onClick={() =>
setBrandColor({
brand: 'var(--colors-brand9)',
brandAccent: 'var(--colors-brand11)',
brandAccent2: 'var(--colors-brand3)',
})
}
className={[
'bg-brand-300 border-brand-900 h-10 w-10 rounded-full border-2 transition hover:scale-105',
brandColor.brand === 'var(--colors-brand9)'
? ' !bg-brand-900 ring-scale-400 border-scale-800 ring-2 drop-shadow-lg dark:ring-white'
: '',
].join(' ')}
></button>
<button
onClick={() =>
setBrandColor({
brand: 'var(--colors-orange9)',
brandAccent: 'var(--colors-orange11)',
brandAccent2: 'var(--colors-orange3)',
})
}
className={[
'h-10 w-10 rounded-full border-2 border-orange-900 bg-orange-300 transition hover:scale-105 ',
brandColor.brand === 'var(--colors-orange9)'
? ' ring-scale-400 border-scale-800 !bg-orange-900 ring-2 drop-shadow-lg dark:ring-white'
: '',
].join(' ')}
></button>
<button
onClick={() =>
setBrandColor({
brand: 'var(--colors-crimson9)',
brandAccent: 'var(--colors-crimson11)',
brandAccent2: 'var(--colors-crimson3)',
})
}
className={[
'border-crimson-900 bg-crimson-300 h-10 w-10 rounded-full border-2 transition hover:scale-105 ',
brandColor.brand === 'var(--colors-crimson9)'
? ' ring-scale-400 border-scale-800 !bg-crimson-900 ring-2 drop-shadow-lg dark:ring-white'
: '',
].join(' ')}
></button>
<button
onClick={() =>
setBrandColor({
brand: 'var(--colors-indigo9)',
brandAccent: 'var(--colors-indigo11)',
brandAccent2: 'var(--colors-indigo3)',
})
}
className={[
'h-10 w-10 rounded-full border-2 border-indigo-900 bg-indigo-300 transition hover:scale-105 ',
brandColor.brand === 'var(--colors-indigo9)'
? ' ring-scale-400 border-scale-800 !bg-indigo-900 ring-2 drop-shadow-lg dark:ring-white'
: '',
].join(' ')}
></button>
</div>
</div>
<div className="flex flex-col gap-2">
<label className="text-scale-1200 text-base">Rounded corners</label>
<div className="flex items-center gap-3">
<button
onClick={() => setRadius('4px')}
className={[
'bg-scale-100 dark:bg-scale-400 border-scale-500 ring-scale-400 border-scale-800 flex h-10 w-10 items-center justify-center rounded-full border hover:scale-105',
radius === '4px'
? 'ring-scale-400 border-scale-800 border-2 ring-2 dark:ring-white'
: '',
].join(' ')}
>
<img
src="/images/auth-ui/small--light.svg"
className="hidden w-4 text-red-900 dark:block"
/>
<img
src="/images/auth-ui/small--dark.svg"
className="block w-4 text-red-900 dark:hidden"
/>
</button>
<button
onClick={() => setRadius('10px')}
className={[
'bg-scale-100 dark:bg-scale-400 border-scale-500 flex h-10 w-10 items-center justify-center rounded-full border transition hover:scale-105',
radius === '10px'
? 'ring-scale-400 border-scale-800 border-2 ring-2 dark:ring-white'
: '',
].join(' ')}
>
<img
src="/images/auth-ui/medium--light.svg"
className="hidden w-4 text-red-900 dark:block"
/>
<img
src="/images/auth-ui/medium--dark.svg"
className="block w-4 text-red-900 dark:hidden"
/>
</button>
<button
onClick={() => setRadius('32px')}
className={[
'bg-scale-100 dark:bg-scale-400 border-scale-500 flex h-10 w-10 items-center justify-center rounded-full border transition hover:scale-105',
radius === '32px'
? 'ring-scale-400 border-scale-800 border-2 ring-2 dark:ring-white'
: '',
].join(' ')}
>
<img
src="/images/auth-ui/large--dark.svg"
className="hidden w-4 text-red-900 dark:block"
/>
<img
src="/images/auth-ui/large--light.svg"
className="block w-4 text-red-900 dark:hidden"
/>
</button>
</div>
</div>
<div className="flex flex-col gap-2">
<label className="text-scale-1200 text-base">Social Auth Layout</label>
<div className="flex items-center gap-3">
<button
onClick={() => setLayout('horizontal')}
className={[
'dark:bg-scale-400 bg-scale-100 dark:border-scale-500 border-scale-500 flex h-10 w-10 items-center justify-center rounded-full border transition hover:scale-105 ',
layout === 'horizontal'
? 'ring-scale-400 border-scale-800 border-2 ring-2 dark:ring-white'
: '',
].join(' ')}
>
<MenuIcon className="text-scale-900 dark:text-scale-1100 w-6 rotate-90" />
</button>{' '}
<button
onClick={() => setLayout('vertical')}
className={[
'dark:bg-scale-400 bg-scale-100 dark:border-scale-500 border-scale-500 flex h-10 w-10 items-center justify-center rounded-full border transition hover:scale-105 ',
layout === 'vertical'
? 'ring-scale-400 border-scale-800 border-2 ring-2 dark:ring-white'
: '',
].join(' ')}
>
<MenuIcon className="text-scale-900 dark:text-scale-1100 w-6" />
</button>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
)
}
export default AuthWidgetSection