EZBus is a transportation service that is committed to enabling cities, individuals, and businesses to move anywhere. EzBus is tech-driven, fancy, and convenient.
EZBus consists of
- Two Flutter apps for customers and drivers
- Admin panel with a Laravel API system as a back-end and a Vue.js front-end system as a web interface
Demo
- Backend, go to the demo
and log in using
- Admin credentials
- Username: admin@ezbus.com
- Password: admin123
- Customer Mobile App, click
- Use customer@ezbus.com for email with password 12345678, or sign up with a new email
- Driver Mobile App, click
- Use driver@ezbus.com for email with password 12345678, or sign up with a new email
- Driver Mobile App, click
How to test the system?
- Open the driver app and register for a new driver.
- Go to the admin panel and do the following:
- Approve the driver’s documents.
- Add a new bus.
- Assign the bus to the driver.
- Create a new route.
- Create a trip on that route.
- Assign the trip to the new driver.
- Go to the driver app and start the trip.
- Go to the customer app and try to search for trips in the same geographical area where the start and end stops of the created route are located. Make sure that your wallet balance is sufficient. If not, please charge it. All payments are in the sandbox, so there are no real payments in the demo.
- Select the trip in the customer app and pay for it.
- Track the trip from the customer app.
- Navigate the route as the driver. When your location is close to the customer, an alert will appear in the driver app to slow down. When the driver reaches the customer’s location, a pop-up will appear to allow the driver to scan the customer’s ticket to check him in.
- When the driver reaches the customer’s drop-off point, a pop-up will appear to allow the driver to check him out.
- The driver will see his wallet value increase and the history of this.
Requirements
Please make sure that you have accounts for- VPS server with root credentials
-
with the following APIs enabled
- Geocoding API
- Maps JavaScript API
- Places API
- Directions API
- Maps SDK for Android
- Maps SDK for iOS
- Braintree SDK. You can test with a account OR integrate a account.
Technologies Used
- Flutter – customer and driver apps
- Laravel - backend
- VueJS - admin panel front end
- Socket.io – real-time bus location update for mobile apps and admin panel
- Google Maps SDK – display maps in mobile apps and admin panels