A rental management system that currently supports adding, modifying and removing customers and vehicles
This was an assignment from university, where we had to make a management interface for a hypothetical rental management company. I went a bit overboard and made a whole CUI (Console UI) library for it, which began as an immediate mode library, but evolved over time to be mostly retained from the application's point of view (although it was rendered as an immediate GUI internally). Unfortunately, as it is based on an immediate mode renderer, it has to update the entire screen for each change, which is very slow. (Work was done to change this, but never completed). You can find the graphics library in the MRRC.Guacamole directory.
We were not allowed to use any third party libraries, so I had to make a few more for the project:
It includes a search term parser, which can be used to highlight search terms, and includes functionality to search for words or a regular expression in some source (MRRC.SearchParser).
It also includes a tiny CSV parser which generates and reads CSVs from/into class instances, and can handle commas, quotes, and new lines in fields (MRRC.Cursive).
This project is set up so it can be built in Visual Studio or any other IDEs that support Visual Studio solution files. To build in VS, open the solution (MateRatesRentACar.sln
), right click the MatesRatesRentACar
project in the Solution Explorer panel and select Build (the required files will be put in the MatesRatesRentACar/bin/Debug
directory).
Note: You may have to build multiple times so that the dependant projects get included.
You may want to resize the console window that is opened by running the application, otherwise some menus may flow off the edge, and in rare cases the program could throw an exception.
With the solution open, press F5. This will open a console window with the program's GUI rendered.
Double click on the MatesRatesRentACar.exe
file after building, or run it from the command line.
The program should output something like the example below:
This program reads from and writes to files in the Data
directory, relative to the root folder of the solution. This directory will be created automatically if it does not exist, and the program will create the files on exit if they don't exist. The files used are:
fleet.csv
: Data about each vehicle owned by the companycustomers.csv
: Data about every customerrentals.csv
: Links the customers to the vehicles they are renting
The program is based around menus and forms, with menus being what you use to find what you want to do, and forms being how you input data. We will call these 'components'.
When a component is active, it will be drawn in a brighter colour than the rest of the app.
Note: Sometimes forms don't automatically focus the first input (shown by the input being a brighter colour than the other inputs) - in this case, pressing tab should focus it.
This menu lets you choose between the groups of functions the program supports. You can select one of these by pressing tab or vertical arrow keys to cycle through, then enter or the right arrow key to enter into the menu (this is true for all menus). To go up a level in the menus, you can press backspace or the left arrow key.
This menu is shown under the title Customers, and contains actions to add, modify and remove customers.
This item displays a form containing a search field, which allows you to find customers based on the following fields:
- Id
- Title
- Given names
- Surname
- Gender
To search for a field that contains special characters (anything that is not alphanumeric or an underscore), surround it in double quotes. Replace any double quotes in a quoted field with two of them ""
to prevent the field from closing.
You can use the AND
and OR
keywords between two expressions to combine them, either requiring both to match or only one to match, respectively. Place the NOT
keyword before an expression to match anything that does not match that expression.
You can surround an expression in parentheses (()
) to group them together, forcing the order of query checking (similar to in arithmetics).
Selecting Search will show a results selection field. The value here is not used for anything, instead the field is used to display your search results. If one of them is the one you wanted, you can copy its ID into wherever you need it. Otherwise, type a new search in and press Search again.
This item displays a form (that can be entered using enter or the right arrow) with the different fields relating to customers. Press tab, enter, or the vertical arrow keys to cycle through these. In the Gender field, press enter to show a list of options, then tab or vertical arrow keys to select an option, then enter to confirm it.
Once all the fields have been filled out, navigate to the 'Submit' button and press enter. If anything is wrong, it will give you feedback, otherwise it will tell you the new ID of the user.
You may press the left arrow key at any time to exit the form.
This item starts by displaying a form which asks for the ID of the customer to modify. Navigate to the 'Search' button and press enter to select that customer (if it can't find them, it will notify you).
It will now show a form similar to the Add Customer form, however the customer ID is included (although it is readonly). Once you have updated any information, select Submit to save it.
You may press the left arrow key to go back to the search at any time, and press it again to get back to the Customers menu.
This form starts off the same as the Modify Customer menu, requesting a customer ID. After searching, it will show information about the customer to help identify them, and ask for confirmation to delete them from the database. It will not allow them to be deleted if they are currently renting a vehicle (although at this time renting is not supported).
This shows a table of every customer and all the stored information about them. Note that it does not show rentals, for this look in the fleet management menu.
This menu is basically the same as the customer management menu, however the Add Vehicle form contains a new component - the checkbox. Press enter while it is focused to toggle it.
Note that the Add Vehicle form is quite tall, so you may need to resize your terminal window for it to fit. Some terminals may scroll to show the currently focused component, however this can be jarring.
This form is to rent a vehicle out to a customer. Enter the customer's ID and the vehicle's registration number (which can be found from the Find Customer and Find Vehicle forms respectively), and select Submit to begin renting. A message will be displayed if something went wrong.
Enter the registration number of the vehicle to return it.
To save and exit the application, press escape at any time, then choose 'Yes'.
Note that you can press Control+C to kill the application on most terminals, however be careful because this will not save your changes.