* docs(react-native): create the basic expo project * docs(react-native): cross-platform Apple social sign-in * docs(react-native): cross-platform Google social sign-in * docs(react-native): fix typos * docs(react-native): remove wrong entry in the `Connection` component * Correct typos * Prettier * Draft * Draft * docs(react-native): use kebab-case file naming convention in Expo guide - use kebab-case file naming convention in Expo guide - add trailing semicolon to align with the standard Expo template conventions * docs(react-native): use kebab-case file naming convention in Expo social auth example * docs(react-native): update the packages of the Expo social auth example * Fix * Draft * Changes * Correct log message --------- Co-authored-by: Chris Chinchilla <chris.ward@supabase.io> Co-authored-by: Chris Chinchilla <chris@chrischinchilla.com>
30 lines
786 B
TypeScript
30 lines
786 B
TypeScript
import AsyncStorage from '@react-native-async-storage/async-storage';
|
|
import { createClient } from '@supabase/supabase-js';
|
|
import 'react-native-url-polyfill/auto';
|
|
|
|
const ExpoWebSecureStoreAdapter = {
|
|
getItem: (key: string) => {
|
|
console.debug("getItem", { key })
|
|
return AsyncStorage.getItem(key)
|
|
},
|
|
setItem: (key: string, value: string) => {
|
|
return AsyncStorage.setItem(key, value)
|
|
},
|
|
removeItem: (key: string) => {
|
|
return AsyncStorage.removeItem(key)
|
|
},
|
|
}
|
|
|
|
export const supabase = createClient(
|
|
process.env.EXPO_PUBLIC_SUPABASE_URL ?? '',
|
|
process.env.EXPO_PUBLIC_SUPABASE_ANON_KEY ?? '',
|
|
{
|
|
auth: {
|
|
storage: ExpoWebSecureStoreAdapter,
|
|
autoRefreshToken: true,
|
|
persistSession: true,
|
|
detectSessionInUrl: false,
|
|
},
|
|
},
|
|
);
|