We have created a money management mobile application for 8 to 12 years olds that would teach them financial literacy. The app includes the following features:
-
Authenticated Login: Parents must log in with their credentials to access the app's features, ensuring their data is secure.
-
Record and Categorise Transactions: Users can record their financial transactions, categorising them into different income expense categories for better budgeting and understanding of their spending habits.
-
Complete Interactive Challenges: The app offers interactive financial challenges to users, encouraging them to make informed financial decisions and develop responsible money management skills.
-
Earn Rewards / Level Up: By completing challenges, users can earn rewards and level up, fostering a sense of achievement and progress in their financial journey.
-
Create a Monetary Goal & Record Progress: Users can set monetary goals, such as saving for a specific item or target amount, and track their progress towards achieving these goals.
-
Select a Profile Picture: Users have the option to personalise their profiles by selecting a profile picture based on their favourite animal, making the app experience more engaging and enjoyable.
As an extension to the core features, the app provides a visual breakdown of users' spending and income. This feature enables users to gain insights into their financial patterns through easy-to-understand charts and graphs, helping them make more informed decisions about their money.
With these features, our Smart Savers app aims to empower young users with essential financial skills and knowledge, setting them on a path of financial responsibility and independence.
Please watch a demonstration of our app by clicking here
- React Native (Expo Go)
- TypeScript
- Lottie (for animations)
- Victory Pie Charts (for interactive pie charts)
- Java (Spring Framework)
- PostgreSQL
Before running the app locally, ensure you have the following installed:
- Clone the repository to your local machine:
git clone https://github.com/BBilgili15/smart_savers
- Change directory to the project folder:
cd your-repo
- Install dependencies:
npm install
- Start the Expo development server:
npm start
-
Use the Expo Go app on your Android or iOS device to scan the QR code from the Expo development server. Alternatively, you can use an Android emulator or iOS simulator to run the app.
-
To connect to your backend (Java Spring), update the appropriate API URLs in the codebase to match your backend's endpoints.
-
Go to the Firebase Console and sign in with your Google account.
-
Click on "Add Project" and follow the on-screen instructions to create a new Firebase project. Choose a unique project name and select your preferred region.
-
Once the project is created, click on "Web" under "Build" to add a web app to your Firebase project.
-
Provide a name for your app and click "Register App."
-
Firebase will generate your web app's configuration. Copy the configuration details (apiKey, authDomain, projectId, storageBucket, messagingSenderId, appId) as you'll need them later.
In your React Native Expo project, navigate to the FirebaseConfig.ts
file (or create one if it doesn't exist) and paste the Firebase configuration details:
// FirebaseConfig.ts
import { initializeApp } from "firebase/app";
const firebaseConfig = {
apiKey: "YOUR_API_KEY",
authDomain: "YOUR_AUTH_DOMAIN",
projectId: "YOUR_PROJECT_ID",
storageBucket: "YOUR_STORAGE_BUCKET",
messagingSenderId: "YOUR_MESSAGING_SENDER_ID",
appId: "YOUR_APP_ID",
};
const app = initializeApp(firebaseConfig);
export { app as FirebaseAuth };
Replace the placeholders (YOUR_API_KEY, YOUR_AUTH_DOMAIN, etc.) with the corresponding values from your Firebase project's configuration.
In your Java Spring backend project, you'll need to configure Firebase Admin SDK. Follow the official Firebase Admin SDK setup guide for Java to set up Firebase in your backend:
Firebase Admin SDK Setup Guide for Java
Once you have set up the Firebase Admin SDK in your Java backend, you can use the Firebase Admin SDK APIs to interact with your Firebase project. For example, you can use it to authenticate users, access the Firebase Realtime Database, Cloud Firestore, and other Firebase services from your Java Spring application.
The following libraries were used in this project:
Lottie is used for adding beautiful animations to the app. It allows us to use After Effects animations in our React Native app seamlessly. More About Lottie
Victory Pie Charts is used for displaying visually appealing and interactive pie charts in the app. It provides various customization options. More About Victory