Skip to content

Miciaha/Rendezvous

Repository files navigation

Rendezvous

Scenario: You are working for a software company that has been contracted to develop a GUI-based scheduling desktop application. The contract is with a global consulting organization that conducts business in multiple languages and has main offices in Phoenix, Arizona; White Plains, New York; Montreal, Canada; and London, England. The consulting organization has provided a MySQL database that the application must pull data from. The database is used for other systems, so its structure cannot be modified.

The organization outlined specific business requirements that must be met as part of the application. From these requirements, a system analyst at your company created solution statements for you to implement in developing the application. These statements are listed in the requirements section.

Your company acquires Country and First-Level-Division data from a third party that is updated once per year. These tables are prepopulated with read-only data. Please use the attachment “Locale Codes for Region and Language” to review division data. Your company also supplies a list of contacts, which are prepopulated in the Contacts table; however, administrative functions such as adding users are beyond the scope of the application and done by your company’s IT support staff. Your application should be organized logically using one or more design patterns and generously commented using Javadoc so your code can be read and maintained by other programmers.

A. Create a GUI-based application using no external libraries (excluding JavaFX and MySQL JDBC)

1. Create a log-in form

Status Task
✔️ Accepts a user ID and password and provides an appropriate error message
✔️ Determines the user’s location and displays it in a label on the log-in form
✔️ Displays the log-in form in English or French based on the user’s computer language setting
✔️ Translates error control messages into English or French based on the user’s computer language setting

Login Screen

2. Customers

Status Task
✔️ Customer records can be added, updated, and deleted
✔️ Collect customer name, address, postal code, and phone number
✔️ Country and first-level division data is pre-populated in separate combo boxes
✔️ All of the original customer information is displayed on the update form
✔️ All of the fields can be updated except for Customer_ID
✔️ Customer data is displayed using a TableView
✔️ Message is displayed in the user interface when a customer is deleted

Create Customer Form Edit Customer Form Customer Table

3. Appointments

Status Task
✔️ Appointments can be added, updated, and deleted
✔️ Contact name is assigned to an appointment using a drop-down menu
✔️ Custom message is displayed in the user interface when canceled (deleted)
✔️ Appointment_ID is auto-generated and disabled throughout the application
✔️ Appointment information is displayed on the update form in local time zone
✔️ Show user upcoming appointment upon login
✔️ Allow user to view appointment schedules by month and week
✔️ Allow user to adjust appointment times

Create Appointment Form Edit Appointment Form Upcoming Appointment and Tables

4. Logical Error Checks

Status Logical Errors
✔️ Scheduling an appointment outside of business hours defined as 8:00 a.m. to 10:00 p.m. EST, including weekends
✔️ Scheduling overlapping appointments for customers
✔️ Entering an incorrect username and password

Incorrect username and password Scheduling conflict

5. Reports

Status Description
✔️ Total number of customer appointments by type and month
✔️ Schedule for each contact in your organization that includes appointment ID, title, type and description, start date and time, end date and time, and customer ID
✔️ Security report: application entry attempts

Reports Dashboard

6. Final Tasks

Status Description
✔️ Write at least two different lambda expressions
✔️ Record all user log-in attempts, dates, and time stamps and whether each attempt was successful in a file named login_activity.txt
✔️ Provide Javadoc comments for at least 70 percent of the classes and their members and create an index.html file

7. Included in the README.txt file

Status Description
✔️ Title and purpose of application
✔️ Author, contact, app version, date
✔️ IDE including version number
✔️ Full JDK of version used
✔️ JavaFX version compatible with JDK version
✔️ Directions for how to run program
✔️ Description of additional report
✔️ MySQL Connector driver version number, including the update number

About

GUI-based scheduling desktop application.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published