The Court Project // 2024




Overview
The Court Project is a React Native mobile application designed to streamline tennis court reservations at The Falls of Autry Millβs tennis facility. The app provides a seamless user experience for booking, modifying, and managing reservations with an intuitive interface and real-time updates.
Role
Full Stack Developer, UI/UX Designer, Product Manager
Tools/Skills
Agile Development, React Native, JIRA, Figma, TypeScript
π± Key Features
β
Interactive Scheduling β Users can search for available courts based on time, date, and duration.
β
Seamless Booking System β Confirm reservations with just a few clicks.
β
Real-time Availability & Waitlist System β If a user doesn't check in, the next person on the waitlist gets the spot.
β
User-Friendly Interface β A modern UI that prioritizes simplicity and ease of navigation.
β
Secure Authentication β Google Firebase handles user authentication and role-based access control.
β
Cross-Platform Compatibility β Developed in React Native, making it available on both iOS and Android.
π οΈ Tech Stack
Frontend: React Native, TypeScript
Backend: Firestore (NoSQL Database), Firebase Authentication
Authentication: Googleβs Firebase for secure login
Data Exchange: JSON over HTTPS
UI Frameworks: NativeBase, React Navigation
π System Design
The app follows a modular architecture to ensure scalability and maintainability:
π Static Architecture β A layered structure with clear separation of UI, logic, and data access.
π Dynamic Architecture β A well-defined flow where users interact with the app, trigger logic, and update the Firestore database in real-time.
π Security & Performance Considerations:
- Encryption: Data is encrypted at rest and in transit.
- Access Control: Role-based authentication restricts user permissions.
- Optimized Queries: Firestore real-time synchronization ensures fast performance.
π₯οΈ Key Screens
π Court Scheduling Screen β Users enter preferred time slots and see available courts.
πΎ Available Courts Screen β Displays open courts and lets users select one.
β Confirm Booking Screen β Summarizes details before finalizing.
π Reservations Screen β Shows all active bookings with options to modify, cancel, or check in.
βοΈ User Settings Screen β Allows account management and statistics viewing.




