This food ordering project is a comprehensive solution that facilitates a seamless ordering process for users while providing efficient management tools for outlet owners. The project consists of two distinct apps developed using Flutter: a user app and an owner app.
The user app allows customers to conveniently browse and select food items from local food outlets. Once the order is placed, users are seamlessly redirected to a secure payment gateway to complete the transaction. This ensures a smooth and secure payment process. After successful payment, the order details are automatically forwarded to the respective outlet for confirmation.
Upon confirmation by the outlet, an order number is assigned, and users are notified through the app. This eliminates the need for users to physically visit the outlet or repeatedly inquire about the status of their order. Users can simply wait for the notification and then proceed to the food outlet for order collection.
On the other hand, the owner app provides outlet owners with powerful tools to efficiently manage their operations. Owners can view and process incoming orders, keeping track of order details, delivery preferences, and customer information. The app also facilitates seamless communication with users, enabling owners to provide updates or address any concerns regarding the order.
To further enhance outlet management, a dedicated website using React.js has been developed specifically for owners. This website serves as a comprehensive outlet management system, allowing owners to perform CRUD operations on their menu and outlet(s), and monitor the incoming orders. It also provides the owner with various analytics about their outlet like revenue generated, various outlets comparison and products ordering frequency. The website also provides a user-friendly interface and can be easily accessed from larger screens, making it ideal for use in the outlet's kitchen.
The backend of the project is built using Node.js, Express, MongoDB, Redis, and Firebase. These technologies ensure efficient data management, real-time notifications, and seamless integration between the user app, owner app, and the website.
Overall, this project revolutionizes the food ordering experience by providing a convenient and streamlined solution for users while empowering outlet owners with efficient management tools. It enhances customer satisfaction, reduces waiting times, and increases operational efficiency for food outlets.
- User-Friendly Ordering
- Real time management of orders by the outlet
- Secure Payment Gateway
- Cross platform functionality
- Various Analytics tools available
- User app, Owner app, and Website work together in sync
Website: ReactJS, Context API, and Bootstrap.
User and Owner App: Flutter, Firebase, and Bloc.
Server: NodeJS, Express, MongoDB, Redis and Firebase.
This section describes in detail the working of the User app, the owner app, and the Website (All three of these are still in development phase, so there might be some bugs).
The user app can be used by the users to place orders on the food outlet of their choice. The App is developed using Flutter and Bloc Technology.
- Repo https://github.com/sanyam12/FlavR
- APK Link
- User Registration and Authentication: Seamless registration process and secure user authentication to create and access personal accounts.
- Browse Menus: Users can easily browse and explore the menus of local food outlets, displaying various food items and their details.
- Place Orders: Conveniently place food orders from selected outlets, customizing quantities and preferences.
- Secure Payments: Integrated payment gateway for safe and hassle-free transactions while placing orders.
- Order Tracking: Real-time updates on order status, including confirmation, preparation, and delivery progress.
- Order History: Access to previous order details, making it easy for users to reorder their favorite items.
- Notifications: Automatic notifications to keep users informed about order updates.
- Selecting the outlet
- Placing an order
- Real-time order updates
- Order History
The website developed as part of the food ordering project serves as a comprehensive outlet management system for owners. Built using React.js, the website offers a user-friendly interface and a range of features that facilitate efficient management of the outlet's operations.
- Repo https://github.com/mridul549/ownerweb
- Website live at https://flavr.onrender.com/
-
Outlet Menu Management: The website enables owners to perform CRUD operations on the menu. They can easily add, update, and delete food items, ensuring that the menu is always up to date and reflects the available options.
-
Outlet Information: Owners can update important information about their outlet, such as contact details, address, working hours
-
Order Tracking: The website provides a centralized platform for owners to track and manage incoming orders. Owners can view details of each order, including the items ordered, delivery preferences, and customer information.
-
Real-Time Notifications: The website offers real-time notifications to owners, keeping them informed about new orders.
-
Analytics and Reporting: The website includes analytics features that provide owners with valuable insights into their business. They can access data on popular menu items, sales performance, and different outlets comparison (the ones they own).
-
Menu
-
Add a product
-
Update a product
-
Delete a product
-
-
CRUD operations for the outlet
-
Handling of incoming orders
- Contains three sections
- Pending Confirmation: Once a new order arrives, it will come in this section, the owner would first have to accept an order or reject it selecting the proper reason.
- Active Orders: Once an order is accepted, it is brought to this section along with the assignment of the order number.
- Ready Orders: This section contains orders that are marked as prepared and ready for pickup.
- The entire order handling process works in real time with notifications being sent to the user at each stage automatically.
Flavr.bg-1.mp4
- Contains three sections
-
Analytics Dashboard
- The analytics section provides an owner with three important pieces of information.
-
Revenue Generated: This lets the owner know how much revenue was generated by an outlet on a given date, month, or year.
-
Outlets comparison: This lets the owner compare multiple outlets based on revenue generated on a given day, month, or year.
-
Products comparison: This lets the owner compare the performance of the various products of the outlet based on the quantity ordered on a given day, month, or year.
-
- The analytics section provides an owner with three important pieces of information.
To run Locally, go to the respective repos of the apps or the website, and follow the steps mentioned there.
- Website: https://github.com/mridul549/ownerweb
- User App: https://github.com/sanyam12/FlavR
- Owner App: https://github.com/sanyam12/FlavR
For the server, follow the below mentioned steps:
- Clone the project
git clone https://github.com/mridul549/FlavR
- Go to the project directory
cd FlavR
- Install dependencies
npm install
- Create a new file named .env in the root directory, and add the following secrets there.
MONGOOSE_CONNECTION_STRING = <Enter the value>
CLOUDINARY_CLOUD_NAME = <Enter the value>
CLOUDINARY_API_KEY = <Enter the value>
CLOUDINARY_API_SECRET = <Enter the value>
TOKEN_SECRET = <Enter the value>
REDIS_HOST = <Enter the value>
REDIS_PORT = <Enter the value>
REDIS_PASSWORD = <Enter the value>
REDIS_USERNAME = <Enter the value>
REDIS_URI = <Enter the value>
CF_APP_ID = <Enter the value>
CF_API_KEY = <Enter the value>
GOOGLE_CLIENT_ID = <Enter the value>
GOOGLE_CLIENT_SECRET = <Enter the value>
GOOGLE_REDIRECT_URI = <Enter the value>
GOOGLE_REFRESH_TOKEN = <Enter the value>
FB_API_KEY = <Enter the value>
FB_AUTH_DOMAIN = <Enter the value>
FB_PROJECT_ID = <Enter the value>
FB_STORAGE_BUCKET = <Enter the value>
FB_MESSAGING_SENDER_ID = <Enter the value>
FB_APP_ID = <Enter the value>
FB_MEASUREMENT_ID = <Enter the value>
To setup the environment variables, see contributing.md
.
- Start the server
npm start
- The server should be up and running on PORT 3001.
The Documentation of the REST-API can be found here. This Documentation was created with the help of Postman.
Contributions are always welcome!
See contributing.md
for ways to get started.
Please adhere to this project's code of conduct
.
Developed | Contributors |
---|---|
The User and the Owner app using Flutter | @sanyam12 and @Akshi-ta |
The Website using ReactJS | @mridul549 and @chahat30 |
The Server using Nodejs | @mridul549 |
Q- In the user app, when multiple people place orders simultaneously, how does the system allocate unique order numbers to ensure accurate tracking and management of each order?
A- To handle concurrent order placements, we have implemented a queue-based system that assigns order numbers to incoming orders in a sequential manner. By using queues, we ensure that each order is processed one by one, eliminating any potential race conditions that may arise when multiple people place orders simultaneously. This was done with the help of Bull package and Redis.
A- For hosting the REST API, we have opted for Amazon Web Services (AWS) EC2 instances, leveraging their reliable infrastructure to ensure seamless deployment and scalability of the application.
A- We are the JSON Web Tokens (JWT) to log in a user into the application or the Website. The token is stored securely in the browser or the app and expires after 30 days.
A- To verify user emails during Sign Up, the project utilizes the Gmail API or Google OAuth2 for sending email verification messages. When a user registers using their email address, the system integrates with the Gmail API or leverages Google OAuth2 to send a verification email to the provided address.
A- We are using the different databases for the following use cases:
-
MongoDB- MongoDB serves as the central data repository for the food ordering project, storing information about outlets, products, orders, users, and owners. It enables efficient data retrieval, storage, and management, ensuring smooth operations.
-
Redis- Redis is currently being used for two main tasks:
- Order queue: The entire order queue is stored in Redis.
- Mail queue: The version of Gmail API we are using to send OTP mails to users has a rate limiter of sending not more than 100 mails/second. To ensure this condition never arises, we are using a mail queue with concurrency set to 80, which means at a time only 80 verification emails can be sent.
- In the future we are planning to implement caching using Redis to reduce API response times even further.
-
Firebase- We are using Firebase to enable real-time communication between the server, Apps, and the website. Real-time communication is mainly required for Order handling. At the various stages of the order handling process, real-time notifications are sent to the apps and the website to update their UI accordingly.
A- We are currently using the sandbox version of the Cashfree Payment gateway. The refunds are handled in the following ways:
-
If an order is rejected by the outlet, the user is given the option to claim a coupon for the same order amount which can be used immediately at the same outlet again (coupon be used only at the outlet from where the order was rejected) only once.
-
Or ask for a refund which is credited back to the original payment method of the user in T+7 days.
A- We are using MongoDB's Aggregation Pipeline queries to calculate the revenues and the product comparison statistics.
Our app is scheduled to be launched at Lovely Professional University (LPU), where it will be utilized by the Nescafe Food outlet. This real-world deployment will enable us to thoroughly test the app and gather valuable feedback, facilitating further enhancements and scalability for future expansion to additional outlets.