Skip to content

Latest commit

 

History

History
69 lines (40 loc) · 4.75 KB

README.md

File metadata and controls

69 lines (40 loc) · 4.75 KB

Pedalo Web App

LOB web application for a Pedalo rental. Uses Razor Pages.

The app includes overview pages:

  • for the pedalo fleet of the company.
  • for the customers that have rent a pedalo, or are currently renting one.
  • for the past and current rentals (bookings) to replicate which customer has rented which pedalo at what moment of time.

As soon as you start the app in Visual Studio, the database will be created automatically. Check the SampleData.cs to see how this works. If you make changes to the database, the old database will not automatically be changed. You need to delete the old one first and then restart the app.

Before you start

Before you start, make sure you are familiar with LINQ Method Syntax.

Tasks

1. Create CRUD Pages for Pedaloes, Customers and Bookings

Start with the "update" pages. The "Edit customer" page is already included. The "Edit pedalo" page should be nearly the same. For the "Edit booking" page you need store the relationship between the two previous task.

After that continue to add the "create" and "delete" pages.

2. Replace start page with a Dashboard

A dashboard is most likely the starting point for a user and should give the user interesting insights and provide helpful actions for his application and data. Add a "Quick Create Booking" feature so the user does not have to navigate to the Bookings menu first, but is able to create a booking right from the dashboard. Also create a display for the business' highest-grossing customers and the most popular Pedaloes with some calculated numbers.

3. Reasonable and uniform display format for dates & times when rendering on web page

At the moment dates & times have different formats, they should have the same format for the whole app. Also, some date & time information do not make sense everywhere. E.g. no one cares about the time of birth of a customer, so it should not be displayed.

4. Extend functionality and database to allow for passenger registration

Government regulators want to not only know who our customer is, but also what people have accompanied him on his pedalo ride. E.g. when the pedalo goes missing on the water. The water police needs to know how many people to look for. You need to adjust the database design for this change. Here is some advice on how the change can look like.

  • Booking still needs always exactly 1 Customer, but now it can have 0 to multiple passengers
  • Passengers must only registered with first and last name.
  • Max. capacity of passengers for a Booking is given by Pedalo capacity, minus 1 (the Customer)

5. Enhance the styling

  • Make the tables nicer and switch background colors for each row (alternate between light gray and white for example).
  • Align numbers on the right. Read more about CSS and fiddle online style changing.
  • Choose some nicer and consistent colors for buttons

6. Make the website work on mobile devices using responsiveness

If you open the website in the browser and make the window smaller, you can see how it would look on a mobile device. All major browser have a mobile device simulation option that could be useful, like Chromes Device Mode.

The tables and forms are not well suited to mobile devices. The application is using Bootstrap as the main UI framework. Bootstrap already has a lot of support and utilities to make it responsive (mobile friendly). Please prepare by first reading about bootstrap's grid system and how you can use this to create mobile friendly layouts. Bootstrap Grid system

  • Find a good solution for the Dashboard to show elements mobile friendly
  • All pages using tables should only scroll the table sideways, not the navigation
    • You can refer to responsive tables section in the bootstrap documentation
  • Adjust font sizes to match the screen size
  • Make sure the text is readably and breaks in the right places when Pedalo or Customer names are very long

7. Create PDF as receipt

Once you have completed the boooking, create a PDF with the booking details using QuestPDF. The library is alread integrated into the project and you find an example in the Pedaloes list.

8. Send an email receipt

Once you have completed the booking, send a confirmation email.

9. Selenium Tests

In the PedaloWebApp.FunctionalTests we have included a selenium test. Build a test that books a pedalo.