Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

refactor(ui): update styling, error handling, and page linking for improved ux #7

Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
7 changes: 5 additions & 2 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,8 @@ npm-debug.*
*.mobileprovision
*.orig.*
web-build/
.env
!.env.example
.env.*

# macOS
.DS_Store
Expand All @@ -18,4 +19,6 @@ web-build/
# The following patterns were generated by expo-cli

expo-env.d.ts
# @end expo-cli
# @end expo-cli
ios
android
8 changes: 8 additions & 0 deletions .prettierrc
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"tabWidth": 2,
"semi": false,
"singleQuote": true,
"printWidth": 120,
"useTabs": false,
"bracketSpacing": true
}
148 changes: 126 additions & 22 deletions app/(auth)/sign-in.tsx
100644 → 100755
Original file line number Diff line number Diff line change
@@ -1,60 +1,164 @@
import { useSignIn } from "@clerk/clerk-expo";
import { Link, useRouter } from "expo-router";
import { Text, TextInput, Button, View } from "react-native";
import React from "react";
import { useSignIn } from '@clerk/clerk-expo'
import { Stack, useRouter } from 'expo-router'
import { Text, TextInput, Button, View } from 'react-native'
import React from 'react'
import * as WebBrowser from 'expo-web-browser'

export const useWarmUpBrowser = () => {
React.useEffect(() => {
// Warm up the android browser to improve UX
// https://docs.expo.dev/guides/authentication/#improving-user-experience
void WebBrowser.warmUpAsync()
return () => {
void WebBrowser.coolDownAsync()
}
}, [])
}

WebBrowser.maybeCompleteAuthSession()

export default function Page() {
const { signIn, setActive, isLoaded } = useSignIn();
const router = useRouter();
const { signIn, setActive, isLoaded } = useSignIn()
const router = useRouter()

const [emailAddress, setEmailAddress] = React.useState("");
const [password, setPassword] = React.useState("");
const [emailAddress, setEmailAddress] = React.useState('')
const [password, setPassword] = React.useState('')
const [emailError, setEmailError] = React.useState('')
const [passwordError, setPasswordError] = React.useState('')

const onSignInPress = React.useCallback(async () => {
if (!isLoaded) {
return;
return
}

if (!emailAddress) {
setEmailError('Email is required')
}
if (!password) {
setPasswordError('Password is required')
}

if (!emailAddress || !password) {
return
}

try {
const signInAttempt = await signIn.create({
identifier: emailAddress,
password,
});
})

if (signInAttempt.status === "complete") {
await setActive({ session: signInAttempt.createdSessionId });
router.replace("/");
if (signInAttempt.status === 'complete') {
await setActive({ session: signInAttempt.createdSessionId })
} else {
// See https://clerk.com/docs/custom-flows/error-handling
// for more info on error handling
console.error(JSON.stringify(signInAttempt, null, 2));
console.error(JSON.stringify(signInAttempt, null, 2))
}
} catch (err: any) {
console.error(JSON.stringify(err, null, 2));
console.error(JSON.stringify(err, null, 2))
}
}, [isLoaded, emailAddress, password]);
}, [isLoaded, emailAddress, password])

return (
<View>
<Stack.Screen
options={{
title: '',
headerLeft: () => <Button title="Back" onPress={() => router.replace('/')} />,
}}
/>

<Text
style={{
fontSize: 24,
fontWeight: 'bold',
textAlign: 'center',
marginVertical: 10,
}}
>
Sign In
</Text>
<View>
{emailError ? (
<Text
style={{
color: 'red',
marginBottom: 10,
fontWeight: 'bold',
fontSize: 16,
textAlign: 'center',
}}
>
{emailError}
</Text>
) : null}
{passwordError ? (
<Text
style={{
color: 'red',
marginBottom: 10,
fontWeight: 'bold',
fontSize: 16,
textAlign: 'center',
}}
>
{passwordError}
</Text>
) : null}
</View>
<TextInput
autoCapitalize="none"
placeholderTextColor={'#000'}
value={emailAddress}
placeholder="Email..."
autoComplete="email"
inputMode="email"
style={{
marginBottom: 10,
marginHorizontal: 10,
borderColor: 'black',
borderWidth: 1,
padding: 10,
}}
onChangeText={(emailAddress) => setEmailAddress(emailAddress)}
/>
<TextInput
value={password}
placeholder="Password..."
placeholderTextColor={'#000'}
autoComplete="password"
style={{
marginBottom: 10,
marginHorizontal: 10,
borderColor: 'black',
borderWidth: 1,
padding: 10,
}}
secureTextEntry={true}
onChangeText={(password) => setPassword(password)}
/>
<Button title="Sign In" onPress={onSignInPress} />
<View>
<Text>Don't have an account?</Text>
<Link href="/sign-up">
<Text>Sign up</Text>
</Link>

<View
style={{
display: 'flex',
flexDirection: 'column',
alignItems: 'center',
paddingTop: 10,
}}
>
<Text
style={{
marginTop: 10,
marginBottom: 10,
fontSize: 20,
}}
>
Don't have an account?
</Text>
<Button onPress={() => router.replace('/sign-up')} title="Sign Up" />
</View>
</View>
);
)
}
Loading