C# WinForms Application: Watts' A Loan |
|
Saving Values to a Stream
Watts' A Loan is a relatively financial company that provides loans to individuals and small business. The types of loans include personal cash loan, car purchase, boat financing, etc. In this exercise, we will create a graphical application that can assist Watt' A Loan to issue and manage loans.
For this exercise, we will create a WinForms application. For each type of object, we will create a class. To save the records for the business, we will use XML serialization.
Practical Learning: Creating the Application
Employees
Obviously, a company has employees, who are the people who process the necessary translations. To prepare employees, we will create a class and the necessary forms.
Practical Learning: Introducing Employees
namespace WattsALoan1
{
public class Employee
{
public string EmployeeNumber { get; set; }
public string FirstName { get; set; }
public string LastName { get; set; }
public string EmployeeTitle { get; set; }
}
}
Control | (Name) | Text | Modifiers | Other Properties |
Label | Employee #: | |||
TextBox | txtEmployeeNumber | Public | ||
Label | First Name | |||
TextBox | txtFirstName | Public | ||
Label | Last Name | |||
TextBox | txtLastName | Public | ||
Label | Employee Title: | |||
TextBox | txtEmployeeTitle | Public | ||
Button | btnOK | OK | DialogResult: OK | |
Button | btnCancel | Cancel | DialogResult: Cancel |
Form Properties/p>
FormBorderStyle: | FixedDialog |
Text | Watts' A Loan - Employee Editor |
StartPosition | CenterScreen |
AcceptButton | btnOK |
CancelButton | btnCancel |
MaximizeBox | False |
MinimizeBox | False |
Control | (Name) | Text | Other Properties |
ListView | lvwEmployees |
FullRowSelect: True GridLines: True View: Details Anchor: Top, Bottom, Left, Right |
|
Button | btnClose | Close | Anchor: Bottom, Right |
List View Columns
(Name) | Text | TextAlign | Width |
colCounter | # | 20 | |
colEmployeeNumber | Employee # | Center | 90 |
colFirstName | First Name | 80 | |
colLastName | Last Name | 80 | |
colEmployeeTitle | Employee Title | 175 |
Form Properties/p>
FormBorderStyle: | FixedDialog |
Text | Watts' A Loan - Employees |
StartPosition | CenterScreen |
MaximizeBox | False |
StreamWriter
Loans Contracts
Serialization is the ability to save an object or a whole collection of objects to a stream. Another concept of serialization is the ability to send an object or a whole collection of objects from one device to another. In both cases, the object or the collection is save or sent as a whole instead of its individual values.
Control | (Name) | Text | Modifiers | Other Properties |
Label | Employee #: | |||
TextBox | txtEmployeeNumber | Public | ||
Label | First Name | |||
TextBox | txtFirstName | Public | ||
Label | Last Name | |||
TextBox | txtLastName | Public | ||
Label | Employee Title: | |||
TextBox | txtEmployeeTitle | Public | ||
Button | btnOK | OK | DialogResult: OK | |
Button | btnCancel | Cancel | DialogResult: Cancel |
Form Properties/p>
FormBorderStyle: | FixedDialog |
Text | Watts' A Loan - Employee Editor |
StartPosition | CenterScreen |
AcceptButton | btnOK |
CancelButton | btnCancel |
using System; using System.IO; using System.Windows.Forms; namespace WattsALoan1 { public partial class WattsALoan : Form { public WattsALoan() { InitializeComponent(); } private void WattsALoan_Load(object sender, EventArgs e) { /* The files for this project will reside in a directory we will create. * By default, we will create a directory in a C: drive. If you are planning * to use a different directory, change the value of the following variable. * In the same way, if you are working on an operating system other than * Microsoft Windows, make the necessary changes. */ string strDrive = @"C:\"; /* This is the main directory where the files of the project will reside. * If necessary, make the appropriate changes. */ string strPrimaryFolder = strDrive + "Watts A Loan"; // Prepare the directory DirectoryInfo diWattsALoan = new DirectoryInfo(strPrimaryFolder); // Create the primary directory for this project diWattsALoan.Create(); // A Directory for the employees files DirectoryInfo diEmployees = diWattsALoan.CreateSubdirectory("Employees"); // A Directory for the loans contracts files diWattsALoan.CreateSubdirectory("Loans Contracts"); // A Directory for the loans payments files diWattsALoan.CreateSubdirectory("Loans Payments"); } } }
XML serialization is the ability to save (to a medium or send through communication) an object or a collection of objects in XML format. Although the XML name is used, you really don't need to know anything about XML to use this technique or its class, but we first studied XML in previous lessons so you would know what an XML document (or its content) looks like.
Serializing and Deserializing an Object
The .NET Framework supports XML serialization through a class named XmlSerializer
public class XmlSerializer
This class is created in a namespace named assembly. Therefore, you must make sure that your project contains a reference to the line. Other than that, in the next sections, we will see that (once you have been introduced to file processing and know XML) XML serialization is extremely easy to use. You write just a couple of lines of code and the compiler will take care of the rest.
In our introductions to file processing, we saw that, as a preparation, you can create an object with which you will write values to a stream. This can be done by declaring a variable and initializing it. You can also declare a variable of the abstract class. The class is equipped with various constructors. One of the constructors uses the following syntax:
public StreamWriter (string path);
This constructor takes as argument the name of a file or its complete path. You can first declare and initialize a string variable and then pass that variable to a object. Here is an example:
Of course, you can pass the name or path of the file directly to a variable.
To serialize an object, you must first create it, which is easily done by declaring a variable of a class (or structure) type. If one of the built-in classes of the .NET Framework suits your needs, you can use it. Otherwise, you can create a class and fill it with properties of your choice. Then, declare a variable of type the default constructor (it doesn't take any argument). The second constructor uses this syntax:
public XmlSerializer (Type type);
This constructor asks you . This method is overloaded with nine versions. One of the versions of this method uses the following syntax:
public void Serialize(TextWriter textWriter, object o);
This method takes a -based object as argument. The method secondly needs the object that must be written to the stream. Once you call this method, that's it, your job is done. As a small detaiul, remember that the TextWriter class implements the IDisposable interface. This means that you must close the writer after using it, and you have many options. You can:
Practical Learning: Serializing Objects
using System; using System.IO; using System.Windows.Forms; using System.Xml.Serialization; namespace WattsALoan1 { public partial class WattsALoan : Form { public WattsALoan() { InitializeComponent(); } private void WattsALoan_Load(object sender, EventArgs e) { /* The files for this project will reside in a directory we will create. * By default, we will create a directory in a C: drive. If you are planning * to use a different directory, change the value of the following variable. * In the same way, if you are working on an operating system other than * Microsoft Windows, make the necessary changes. */ string strDrive = @"C:\"; /* This is the main directory where the files of the project will reside. * If necessary, make the appropriate changes. */ string strPrimaryFolder = strDrive + "Watts A Loan"; // Prepare the directory DirectoryInfo diWattsALoan = new DirectoryInfo(strPrimaryFolder); // Create the primary directory for this project diWattsALoan.Create(); // A Directory for the employees files DirectoryInfo diEmployees = diWattsALoan.CreateSubdirectory("Employees"); // A Directory for the loans contracts files diWattsALoan.CreateSubdirectory("Loans Contracts"); // A Directory for the loans payments files diWattsALoan.CreateSubdirectory("Loans Payments"); // Serializing an object Employee worker = new Employee() { EmployeeNumber = "293-747", FirstName = "Catherine", LastName = "Watts", Title = "Owner - General Manager" }; string strEmployee = diEmployees.FullName + @"\" + worker.EmployeeNumber + ".xml"; XmlSerializer xsEmployee = new XmlSerializer(typeof(Employee)); TextWriter twEmployee = new StreamWriter(strEmployee); xsEmployee.Serialize(twEmployee, worker); twEmployee.Close(); // Serializing an object worker = new Employee() { EmployeeNumber = "836-486", FirstName = "Thomas", LastName = "Felton", Title = "Accounts Representative" }; strEmployee = diEmployees.FullName + @"\" + worker.EmployeeNumber + ".xml"; try { twEmployee = new StreamWriter(strEmployee); xsEmployee.Serialize(twEmployee, worker); } finally { twEmployee.Close(); } // Serializing an object worker = new Employee() { EmployeeNumber = "492-947", FirstName = "Caroline", LastName = "Wernick", Title = "Assistant Manager" }; strEmployee = diEmployees.FullName + @"\" + worker.EmployeeNumber + ".xml"; using (twEmployee = new StreamWriter(strEmployee)) { xsEmployee.Serialize(twEmployee, worker); twEmployee.Close(); } // Serializing an object worker = new Employee() { EmployeeNumber = "240-750", FirstName = "Catherine", LastName = "Donato", Title = "Accounts Representative" }; strEmployee = diEmployees.FullName + @"\" + worker.EmployeeNumber + ".xml"; xsEmployee = new XmlSerializer(typeof(Employee)); Stream fsEmployee = new FileStream(strEmployee, FileMode.Create, FileAccess.Write, FileShare.Write); try { xsEmployee.Serialize(fsEmployee, worker); } finally { fsEmployee.Close(); } // Serializing an object worker = new Employee() { EmployeeNumber = "804-685", FirstName = "Melissa", LastName = "Browns", Title = "Customer Accounts Representative" }; strEmployee = diEmployees.FullName + @"\" + worker.EmployeeNumber + ".xml"; xsEmployee = new XmlSerializer(typeof(Employee)); using (fsEmployee = new FileStream(strEmployee, FileMode.Create, FileAccess.Write, FileShare.Write)) { xsEmployee.Serialize(fsEmployee, worker); } // Serializing an object worker = new Employee() { EmployeeNumber = "429-374", FirstName = "Denise", LastName = "Leighton", Title = "Accounts Manager" }; strEmployee = diEmployees.FullName + @"\" + worker.EmployeeNumber + ".xml"; xsEmployee = new XmlSerializer(typeof(Employee)); FileInfo fiEmployee = new FileInfo(strEmployee); StreamWriter swEmployee = new StreamWriter(fiEmployee.FullName); xsEmployee.Serialize(swEmployee, worker); swEmployee.Close(); } } }
Control | (Name) | Text | Other Properties |
ListView | lvwEmployees |
FullRowSelect: True GridLines: True View: Details Anchor: Top, Bottom, Left, Right |
|
Button | btnClose | Close | Anchor: Bottom, Right |
List View Columns
(Name) | Text | TextAlign | Width |
colCounter | # | 20 | |
colEmployeeNumber | Employee # | 90 | |
colFirstName | First Name | 80 | |
colLastName | Last Name | 80 | |
colTitle | Title | 175 |
Deserializing an Object
Deserialization is the opposite to serialization. It consists of getting an object of collection that is stored in a medium or was sent as a stream. To start, you can create a stream or a text reader and initialize it:
using System.IO; public class Exercise { void OpenAppliance() { string fileName = "dischwasher.apl"; StreamReader srAppliance = new StreamReader(fileName); } }
You must also indicate the type of object you want to deserialize. You can do this by declaring a value of that class. Here is an example:
using System.IO; public class Dishwasher { } public class Exercise { void OpenAppliance() { Dishwasher dw = new Dishwasher(); string fileName = "dischwasher.apl"; StreamReader srAppliance = new StreamReader(fileName); } }
To deserialize, declare a variable of type XmlSerializer. Remember that this class has many constructors and some of the constructors require that you indicate the type of object you want to work on. Here is an example of declaring and initializing the variable:
using System.IO; using System.Xml.Serialization; public class Dishwasher { } public class Program { void OpenAppliance() { Dishwasher dw = new Dishwasher(); string fileName = "dischwasher.apl"; StreamReader srAppliance = new StreamReader(fileName); XmlSerializer xs = new XmlSerializer(typeof(Dishwasher)); } }
To support deserialization, the XmlSerializer class is equipped with a method named the . This method is overloaded with various (seven) versions. One of the versions uses the following syntax:
public object Deserialize(TextReader textReader);
This method takes as argument an object from a class derived from TextReader. This method return a general object object. Therefore, you must cast the returned value to a type of your class. This can be done as follows:
using System.IO; using System.Xml.Serialization; public class Dishwasher { } public class Execise { void OpenAppliance() { Dishwasher dw = new Dishwasher(); string fileName = "dischwasher.apl"; StreamReader srAppliance = new StreamReader(fileName); XmlSerializer xs = new XmlSerializer(typeof(Dishwasher)); dw = (Dishwasher)xs.Deserialize(srAppliance); } }
Once you have done this, you have the object and you can use it as you see fit.
Practical Learning: Deserializing Objects
using System; using System.IO; using System.Windows.Forms; using System.Xml.Serialization; namespace WattsALoan1 { public partial class Employees : Form { public Employees() { InitializeComponent(); } private void Employees_Load(object sender, EventArgs e) { string strEmployees = @"C:\Watts A Loan\Employees"; DirectoryInfo diEmployees = new DirectoryInfo(strEmployees); FileInfo[] fiEmployees = diEmployees.GetFiles(); int i = 1; foreach(FileInfo file in fiEmployees) { XmlSerializer xs = new XmlSerializer(typeof(Employee)); FileStream fsEmployees = new FileStream(file.FullName, FileMode.Open, FileAccess.Read, FileShare.Read); Employee empl = (Employee)xs.Deserialize(fsEmployees); ListViewItem lviEmployee = new ListViewItem(i.ToString()); lviEmployee.SubItems.Add(empl.EmployeeNumber); lviEmployee.SubItems.Add(empl.FirstName); lviEmployee.SubItems.Add(empl.LastName); lviEmployee.SubItems.Add(empl.Title); lvwEmployees.Items.Add(lviEmployee); i++; fsEmployees.Close(); } } private void btnClose_Click(object sender, EventArgs e) { Close(); } } }
namespace WattsALoan1 { public class Loan { public double LoanAmount { get; set; } public double InterestRate { get; set; } public int Periods { get; set; } public double InterestAmount { get; set; } public double FutureValue { get; set; } } }
Serializing and Deserializing a Collection
Seriualizing a collection is as easy as serializing an object. Instead of simply creating an object, create a collection using any of the techniques we have learned or better, use one of the .NET collection classes we we will study in the next few lessons. When creating a XmlSerializer object, pass the type of collection to the constructor. Then call the XmlSerializer.Serialize() method exactly as we learned. The deserialization follows the same steps we reviewed for an object.
Options on Serialization
Serialization and XML Schemas
When you ask the compiler to perform XML serialization, the compiler wants to know the XML schemas that will control the content of the document. Just mentioned in our introduction, you don't need to know anything about XML in order to use XML serialization. In the same way, you don't need to know anything about XML schema to use XML serialization, but it may be a good idea to know what an XML document looks like and to know what an XML schema is (which is why we first studied XML and schemas in previous lessons).
When performing XML serialization, if you don't provide an XML schema, the compiler will use one of the default schemas that come with Microsoft Visual Studio. Otherwise, if you want to provide your own schema or a specific schema from Microsoft Visual Studio, the XmlSerializer class is equipped with various constructors that allow you to provide that information.
A Property of a Class/Structure Type
We already know how to create a property whose type is a class or structure type. When the class is serialized, the compiler will create a node whose name is the name of the property. The properties of the of the other class or structure would be created as child nodes.
Serializing a Tuple
After creating a tuple, to serialize it, for the argument of the typeof() operator, pass the formula of the tuple. Everything else follows the same steps as for an object. Here is an example:
using System.IO; using System.Xml.Serialization; namespace GeneralSerialization { class Program { static void Main(string[] args) { (long number, string first, string last, double salary) contractor = (297492, "Patrick", "Landsford", 48860); XmlSerializer xsHumanResources = new XmlSerializer(typeof((long, string, string, double))); TextWriter twContractor = new StreamWriter(@"C:\Exercises\Contractor.ctr"); try { xsHumanResources.Serialize(twContractor, contractor); } finally { twContractor.Close(); } } } }
In the same way, you can create a property of a tuple class in a class. When you serialize, the ccmpiler will create a node that uses the name of the property. Each of the items of the tuple will be a child node.
Practical Learning: Serializing an Object
using System; namespace WattsALoan1 { public class CustomerAccount { public int LoanNumber { get; set; } public string ProcessedBy { get; set; } public DateTime DateAllocated { get; set; } public (string FirstName, string LastName, string PhoneNumber) Customer { get; set; } public string LoanType { get; set; } public Loan Finance { get; set; } public double MonthlyPayment { get; set; } public DateTime PaymentStartDate { get; set; } public double CurrentBalance { get; set; } } }
using System; namespace WattsALoan1 { public class Payment { public int PaymentNumber { get; set; } public DateTime PaymentDate { get; set; } public string ProcessedBy { get; set; } public int LoanNumber { get; set; } public double AmountPaid { get; set; } } }
Control | (Name) | Text | Other Properties |
Label | Loan Number: | ||
TextBox | txtLoanNumber | ||
GroupBox | Loan Processed By | ||
Label | Employee #: | ||
TextBox | txtEmployeeNumber | ||
TextBox | txtEmployeeName | ||
GroupBox | Customer Information | ||
Label | First Name: | ||
TextBox | txtFirstName | ||
Label | Last Name: | ||
TextBox | txtLastName | ||
Label | Phone #: | ||
MaskedTextBox | mtbPhoneNumber | Mask: Phone Number | |
Label | Date Allocated: | ||
GroupBox | Fincancial Details | ||
Label | Loan Type: | ||
ComboBox | cbxLoansTypes | Items:
Other Personal Loan Car Financing Boat Financing Furniture Purchase Musical Instrument |
|
Label | Interest Rate: | ||
TextBox | txtInterestRate | TextAlign: Right | |
Label | % | ||
Label | Loan Amount: | ||
TextBox | txtLoanAmount | TextAlign: Right | |
Label | Periods: | ||
TextBox | txtPeriods | TextAlign: Right | |
Label | mois | ||
Label | ________________ | ||
Label | Interest Amount: | ||
TextBox | txtInterestAmount | TextAlign: Right | |
Label | Future Value: | ||
TextBox | txtFutureValue | TextAlign: Right | |
Label | ______________ | ||
Label | Monthly Payment: | ||
TextBox | txtMonthlyPayment | TextAlign: Right | |
Label | Payment Start Date: | ||
DateTimePicker | dtpPaymentStartDate | ||
Label | Previous Balance: | ||
TextBox | txtPreviousBalance | TextAlign: Right | |
Label | Current Balance: | ||
TextBox | txtCurrentBalance | TextAlign: Right | |
Button | btnSaveLoanRecord | Save Loan Record | |
Button | btnClose | Close |
using System; using System.IO; using System.Windows.Forms; using System.Xml.Serialization; namespace WattsALoan11 { public partial class LoanPreparation : Form { public LoanPreparation() { InitializeComponent(); } private void txtEmployeeNumber_Leave(object sender, EventArgs e) { if (string.IsNullOrEmpty(txtEmployeeNumber.Text)) return; string strEmployees = @"C:\Watts A Loan-1\Employees"; DirectoryInfo diEmployees = new DirectoryInfo(strEmployees); FileInfo[] fiEmployees = diEmployees.GetFiles(); int i = 1; foreach (FileInfo file in fiEmployees) { if( file.Name.Substring(0, 7) == txtEmployeeNumber.Text) { XmlSerializer xs = new XmlSerializer(typeof(Employee)); FileStream fsEmployees = new FileStream(file.FullName, FileMode.Open, FileAccess.Read, FileShare.Read); Employee empl = (Employee)xs.Deserialize(fsEmployees); txtEmployeeName.Text = empl.LastName + ", " + empl.FirstName; fsEmployees.Close(); return; } else txtEmployeeName.Text = " "; } } private void btnSaveLoanRecord_Click(object sender, EventArgs e) { if (string.IsNullOrEmpty(txtLoanNumber.Text)) { MessageBox.Show("You must provide a natural number as the loan identifier.", "Watts' A Loan"); return; } if (string.IsNullOrEmpty(txtEmployeeNumber.Text)) { MessageBox.Show("You must enter the employee number of the staff member " + "who processed (and probably approved) the loan.", "Watts' A Loan"); return; } TextWriter twLoan = null; try { string strLoan = @"C:\Watts A Loan-1\Loans Contracts\" + txtLoanNumber.Text + ".xml"; Loan loan = new Loan(); loan.LoanAmount = double.Parse(txtLoanAmount.Text); loan.InterestRate = double.Parse(txtInterestRate.Text); loan.Periods = int.Parse(txtPeriods.Text); loan.InterestAmount = double.Parse(txtInterestAmount.Text); loan.FutureValue = double.Parse(txtFutureValue.Text); loan.MonthlyPayment = double.Parse(txtMonthlyPayment.Text); CustomerAccount account = new CustomerAccount(); account.LoanNumber = int.Parse(txtLoanNumber.Text); account.ProcessedBy = txtEmployeeNumber.Text; account.DateAllocated = dtpDateAllocated.Value; account.Customer = (txtFirstName.Text, txtLastName.Text, mtbPhoneNumber.Text); account.LoanType = cbxLoansTypes.Text; account.Finance = loan; account.PaymentStartDate = dtpPaymentStartDate.Value; account.CurrentBalance = double.Parse(txtCurrentBalance.Text); XmlSerializer xsLoan = new XmlSerializer(typeof(CustomerAccount)); twLoan = new StreamWriter(strLoan); xsLoan.Serialize(twLoan, account); } finally { twLoan.Close(); } Close(); } private void btnClose_Click(object sender, EventArgs e) { Close(); } } }
(Name) btnOpen Text: Open
using System; using System.IO; using System.Windows.Forms; using System.Xml.Serialization; namespace WattsALoan11 { public partial class LoanEditor : Form { public LoanEditor() { InitializeComponent(); } private void btnOpen_Click(object sender, EventArgs e) { if (string.IsNullOrEmpty(txtLoanNumber.Text)) return; string strEmployees = @"C:\Watts A Loan-1\Employees"; string strContracts = @"C:\Watts A Loan-1\Loans Contracts"; DirectoryInfo diContracts = new DirectoryInfo(strContracts); FileInfo[] fiContracts = diContracts.GetFiles(); foreach (FileInfo file in fiContracts) { if (file.Name.Substring(0, 6) == txtLoanNumber.Text) { using (FileStream fsContracts = new FileStream(file.FullName, FileMode.Open, FileAccess.Read, FileShare.Read)) { XmlSerializer xsContracts = new XmlSerializer(typeof(CustomerAccount)); CustomerAccount contract = (CustomerAccount)xsContracts.Deserialize(fsContracts); txtEmployeeNumber.Text = contract.ProcessedBy; dtpDateAllocated.Value = contract.DateAllocated; txtFirstName.Text = contract.Customer.FirstName; txtLastName.Text = contract.Customer.LastName; mtbPhoneNumber.Text = contract.Customer.PhoneNumber; cbxLoansTypes.Text = contract.LoanType; txtLoanAmount.Text = contract.Finance.LoanAmount.ToString("F"); txtInterestRate.Text = contract.Finance.InterestRate.ToString("F"); txtPeriods.Text = contract.Finance.Periods.ToString("F"); txtInterestAmount.Text = contract.Finance.InterestAmount.ToString("F"); txtFutureValue.Text = contract.Finance.FutureValue.ToString("F"); txtMonthlyPayment.Text = contract.Finance.MonthlyPayment.ToString("F"); dtpPaymentStartDate.Value = contract.PaymentStartDate; txtCurrentBalance.Text = txtPreviousBalance.Text = contract.CurrentBalance.ToString("F"); } } } DirectoryInfo diEmployees = new DirectoryInfo(strEmployees); FileInfo[] fiEmployees = diEmployees.GetFiles(); foreach (FileInfo file in fiEmployees) { if (file.Name.Substring(0, 7) == txtEmployeeNumber.Text) { XmlSerializer xs = new XmlSerializer(typeof(Employee)); FileStream fsEmployees = new FileStream(file.FullName, FileMode.Open, FileAccess.Read, FileShare.Read); Employee empl = (Employee)xs.Deserialize(fsEmployees); txtEmployeeName.Text = empl.LastName + ", " + empl.FirstName; fsEmployees.Close(); return; } } } } }
Control | (Name) | Text |
Button | btnLoanPreparation | Loan Preparation... |
Button | btnLoanEditon | Loan Editor... |
Button | btnEmployees | Employees... |
Button | btnClose | Close |
using System; using System.Windows.Forms; namespace WattsALoan11 { public partial class WattsALoan : Form { public WattsALoan() { InitializeComponent(); } private void WattsALoan_Load(object sender, EventArgs e) { } private void btnLoanPreparation_Click(object sender, EventArgs e) { LoanPreparation lp = new LoanPreparation(); lp.ShowDialog(); } private void btnLoanEditor_Click(object sender, EventArgs e) { LoanEditor le = new LoanEditor(); le.ShowDialog(); } private void btnEmployees_Click(object sender, EventArgs e) { Employees staff = new Employees(); staff.ShowDialog(); } private void btnClose_Click(object sender, EventArgs e) { Close(); } } }
Loan Number: 100001 Employee #: 429-374 First Name: Joanne Last Name: Kennan Phone Number: 3011824957 Date Allocated: January 18, 2021 Loan Type: Personal Loan Interest Rate: 14.65 Loan Amount: 2500 Periods: 36 Interest Amount: 1098.92 Future Value: 3598.92 Monthly Payment: 99.97 Payment Start Date: March 1st, 2021 Previous Balance: 3598.92 Current Balance: 3598.92
Loan Number: 100002 Employee #: 492-947 First Name: Stephen Last Name: Haller Phone Number: 2401668369 Date Allocated: February 22, 2021 Loan Type: Boat Financing Interest Rate: 12.25 Loan Amount: 16500 Periods: 60 Interest Amount: $10,106.40 Future Value: 26,606.40 Monthly Payment: 443.44 Payment Start Date: March 1st, 2021 Previous Balance: 26,606.40 Current Balance: 26,606.40
|
||
Previous | Copyright © 2001-2021, C# Key | Next |
|