This project aims to build JavaScript classes for a banking application to practice Object-Oriented Programming (OOP) concepts.
Properties:
- name (string)
- branches (Branch[])
Constructor:
- Parameters: name (string)
Methods:
-
addBranch(branch: Branch): boolean Description: Adds the branch to the branches array. Each branch should only be added once.
-
addCustomer(branch: Branch, customer: Customer): boolean Description: Adds the customer to the branch of the bank. Each customer can only be added once to a branch.
-
addCustomerTransaction(branch: Branch, customerId: string, amount: number): boolean Description: Adds a transaction of the amount for the customer with the specified customerId in the given branch.
-
findBranchByName(branchName: string): Branch[] | null Description: Returns a list of matched branches with the specified branchName or null if no matches were found.
-
checkBranch(branch: Branch): boolean Description: Returns true if the branch belongs to the bank or false otherwise.
-
listCustomers(branch: Branch, includeTransactions: boolean): void Description: Prints out a list of customers with their transaction details if includeTransactions is true.
Properties:
- name (string)
- customers (array of Customer[])
Constructor:
- Parameters: name (string)
Methods:
-
getName(): string
-
getCustomers(): Customer[]
-
addCustomer(customer: Customer): boolean Description: Adds the customer to the customers array. Each customer should only be added once.
-
addCustomerTransaction(customerId: string, amount: number): boolean Description: Adds a transaction of the amount for the customer with the specified customerId.
Properties:
- name (string)
- id (string)
- transactions (array of Transaction[])
Constructor:
- Parameters: name, id
Methods:
-
getName(): string
-
getId(): string
-
getTransactions(): Transaction[]
-
getBalance(): number Note: The balance cannot be negative.
-
addTransaction(amount: number): boolean Description: Adds a successful transaction of the amount to the transactions array.
Properties:
- amount (number)
- date (Date)
Constructor:
- Parameters: amount, date
In addition to the basic requirements, enhance the application with the following features:
- Add validation checks to ensure that the data meets certain criteria before performing create or update operations. For example, validate required fields and data format.
Please run the following JavaScript code in bank.js and share your results and findings in the Slack channel
const arizonaBank = new Bank("Arizona")
const westBranch = new Branch("West Branch")
const sunBranch = new Branch("Sun Branch")
const customer1 = new Customer("John", 1)
const customer2 = new Customer("Anna", 2)
const customer3 = new Customer("John", 3)
arizonaBank.addBranch(westBranch)
arizonaBank.addBranch(sunBranch)
arizonaBank.addBranch(westBranch)
arizonaBank.findBranchByName("bank")
arizonaBank.findBranchByName("sun")
arizonaBank.addCustomer(westBranch, customer1)
arizonaBank.addCustomer(westBranch, customer3)
arizonaBank.addCustomer(sunBranch, customer1)
arizonaBank.addCustomer(sunBranch, customer2)
arizonaBank.addCustomerTransaction(westBranch, customer1.getId, 3000)
arizonaBank.addCustomerTransaction(westBranch, customer1.getId, 2000)
arizonaBank.addCustomerTransaction(westBranch, customer2.getId, 3000)
customer1.addTransactions(-1000)
console.log(customer1.getBalance())
console.log(arizonaBank.listCustomers(westBranch, true))
console.log(arizonaBank.listCustomers(sunBranch,true))
You can add more codes to check the functionality and secrity of your banking system
- Add search functionality to allow users to search for specific customers based on keywords or specific fields, such as by name or Id
- Peer review:
- Review the code and implementation of 2 assignments from other participants.
- Provide constructive feedback and suggestions for improvement.
Please note that the bonus requirements and reviews are optional and can be completed if you have additional time and advanced skills.
This is the Typescript assignment for the Typescript lecture. Your task is to convert the existing project to TypeScript and add appropriate type annotations to enhance type safety and maintainability.
To complete this assignment, follow the guidelines below:
-
Set up TypeScript:
- Install TypeScript globally on your system if you haven't done so already.
- Create a new TypeScript configuration file (tsconfig.json) in the root folder of your project.
-
Convert JavaScript files to TypeScript:
- Rename .js files to .ts extension. Please rename and update one by one.
- Define the type or interface for variables and declare the return types of the methods.
- Ensure that the converted TypeScript code compiles successfully without any type errors.
-
Running the TypeScript Code: Please run the code in bank.ts and share your results and findings in the Slack channel.
- Ensure to apply proper type annotations for variables, function parameters, and return types to enhance type safety.
- Leverage interfaces and custom types wherever appropriate to improve code maintainability and reusability.
Happy coding!