This is a React Native template that includes basic authentication functionality (sign-in and sign-out) using Redux for state management. The template provides a starting point for building mobile apps with authentication workflows, such as login, logout, and handling user tokens.
data:image/s3,"s3://crabby-images/0db2d/0db2d4affaa23f2958cdb8262fda1feba8566aed" alt="rn-auth-template-ui"
- Authentication: Sign-in and sign-out functionality using redux and redux-thunk.
- React Navigation: Stack and Tab navigation with screens for login, home, and settings. Styled Components: Modular and customizable component styling using styled-components.
- Redux Store: Centralized state management for handling authentication and other state.
- React Native: Mobile framework for building cross-platform apps.
- Redux: State management for handling authentication and other app state.
- Redux Thunk: Middleware for handling async actions in Redux.
- React Navigation: For handling navigation between different screens (stack and tab navigation).
- Styled Components: CSS-in-JS for styling components.
- Login Screen: Users can enter their username and password to sign in.
- Home Screen: Main screen of the app accessible after sign-in.
- Settings Screen: Includes a sign-out button that logs the user out.
/screens
login.tsx // Screen for user login
home.tsx // Main screen after login
settings.tsx // Settings screen with sign out button
/styles
// Contains separated styled components for various screens
/store
auth-slice.ts // Redux slice for authentication (login and logout logic)
index.ts // Store setup for the application
/navigation
index.tsx // Main navigation setup (Tab and Stack Navigators)
git clone https://github.com/AlanFnz/rn-auth-template.git
cd rn-auth-template
npm install
or with Yarn:
yarn install
Install CocoaPods dependencies (iOS only)
cd ios
pod install
cd ..
For iOS:
npx react-native run-ios
For Android:
npx react-native run-android
Run tests:
npm test
When a user opens the app, they are prompted with the Login Screen. After entering valid credentials, the user is authenticated, and the app navigates to the Home Screen.
The user can navigate to the Settings Screen and sign out, returning them to the Login Screen.
- Styling: All components are styled using styled-components. You can find and modify the styles in the /styles folder.
- State Management: The authentication logic (sign-in, sign-out) is handled using Redux. The store is set up in /store/auth-slice.ts.
- Navigation: Stack and tab navigation are configured in the /navigation/navigation.tsx file. You can easily add more screens or customize navigation behavior