Firestaurant is a website that helps users book tables online quickly, conveniently and without wasting much time and helps managers automate all processes for recording requests to book tables/change tables from clients.
This is a Frontend source code to help develop a restaurant reservation website - an academic project of the subject "Object-oriented programming techniques" - taught by lecturer Huynh Trung Tru.
Made by:
- Le Mau Anh Duc - N19DCCN038
- Tran Thu Dat - N19DCCN036
- FE: https://dynamite-tnt-1.github.io/
- BE: https://restaurantbe-production.up.railway.app/
- DATABASE MYSQL: Deploy to clever service
- Language: Dart
- Framework: Flutter
- State Management: BLoC
- For manager roles:
- Add several information of dish, drink, service..., includes: name, description, image, price, type...
- Manage client reservation history: view, change status(ex: reject for some reasons) or add notes to it.
- For client roles:
- View all information about restaurant: basic information and restaurant's products: dish, drink, service... clearly.
- Make a reservation.
- Change schedule of reservation or cancel it.
- Automatically reservation: Based on the number of guests, event time, menu, drinks, and services provided by client, the system
automatically arranges tables(without manager intervention) and notifies prepaid fees(if any)
. In case there is a prepaid fee, the person booking the table is required to pay before the specified time. Otherwise, the system will no longer hold the reservation. - Messenger-lite: Our website
allows clients to message the manager and vice versa
. This helps the restaurant easily connect and better understand clients' requests as well as make clients express their opinions more clearly to the restaurant. - Multi-language: Our website currently supports 2 languages: ENGLISH and VIETNAMESE. Because backend technology is still limited, the data in the database cannot support multiple languages, so some data is only displayed in Vietnamese.
Visit Firestaurant
- In case the current languages don't work for you, you can change them in Setting Tab.
- Click on "Change Language".
- Change language what you want and "Apply" it.
This tab helps you prepare a table reservation request by entering information such as the number of guests, date and time of the event, seating location, and a list of dishes, drinks, services, and notes you want to send to the restaurant.
- Click on "Booking" Button on the right top corner.
- Click on add/subtract button to increase/descrease quantity. Or change order of item by drag and drop button shaped like an equal sign.
-
Click on "Ghi chú" Tab to add your note.
-
Click on "Reservation Confirmation" to make a reservation(need Sign In).
- Simalar to Setting Tab, you click on Dish, Drink, Service tab to view list of each.
- For example, in the dish tab, a list of dishes appears with the following interface for each dish
- You can filter by Type, order Price by the top bar
- Pagination on the bottom.
- To add what you want to Reservation Tab, just click on a specific item.
This function need to Sign In.
- Click History Tab to see all your reservation history. Have filter bar and pagination on this screen.
- Click on "three dot" button to view detail of specific reservation.
Firstly, need an IDE/Editor where build and compile code. Highly recommend to using VSCode. Because it's very popular, easy to use and have many extension that make coding more funny and easier.
See this original document to more information.
Run flutter doctor -v
to check version of Flutter and if any missing related to Flutter.
If you have VSCode and all of above things, now run this.
Step 1: Run flutter pub get
to get all package/dependency is used in source code.
Step 2: Check the bottom right corner, you can see available devices (maybe IDE needs a few seconds to load it). Click on it and select any browser you have.
Step 3: Check the bar on top, you can see a button called "Run". Click on it. After that, click on "Run without debugging", or "Start debugging" if you want debug code.
Step 4: Check the result.
Step 5: Make a coffee and fix bug. ☕ 🛠️ 🐞