mortgage
TypeScript icon, indicating that this package has built-in type declarations

0.3.0 • Public • Published

Loan utils

Project with different functions to calculate:

-The minimun payment of a mortgage

Example parameters:

Loan = 150000.00

Interest Rate: 7.5%, //format like 0.075

Loan Length: 30 years, //format in months

import { getMonthlyPayment } from 'mortgate';

const monthlyPayment = getMonthlyPayment(150e3, 7.5e-2, 30*12);

-The loan lenght of a mortgage

Example parameters:

Loan = 150000.00

Interest Rate: 7.5%, //format like 0.075

Mountly Payment: 2000.00

import { getLoanLength } from 'mortgate';

const newLoanLenght = getLoanLength(150e3, 7.5e-2, 2000);

-The amortization table of the payoffs

Example parameters:

Loan = 200000.00

Interest Rate: 7.5% //format like 0.075

Loan Length: 30 years //format in months

Extra Payment = 1000

Initial Date: number = Date.now() //format milliseconds

Times Interest Compounds = 12 //default 12

import { getMortgagePayoff } from 'mortgate';

const payoffData = getMortgagePayoff(2e5, 7.5e-2, 30 * 12, 1000);

//payoffData
{
    mountlyPayment: 1398.429017105553,
    extraPrincipal: 0,
    interestRate: 0.075,
    defaultTotalInterest: 303434.44615799905,
    totalInterestWithSavings: 303434.4461580063,
    loan: 200000,
    defaultLoanLength: 360,
    loanLength: 360,
    startDate: 2020-09-28T08:44:15.873Z,
    endDate: 2050-08-28T08:44:15.873Z,
    defaultEndDate: 2050-08-28T08:44:15.873Z,
    data: [{
            date: 2050-09-28T08:44:15.873Z,
            interest: 1250,
            principal: 148.42901710555293,
            principalExtra: 148.42901710555293,
            balance: 199851.57098289445,
          },
          {
            date: 2050-09-28T08:44:15.873Z,
            interest: 1249.0723186430903,
            principal: 149.35669846246265,
            principalExtra: 149.35669846246265,
            balance: 199702.214284432,
          },
          ...
        ]
    }

-Calculate simple interest and amortizing interest

Total interest for a loan paying only the minimum monthly payment Use this function when you are going to calculate the lifetime interest using the minimun mountly payment.

Loan = 200000.00

Interest Rate: 7.5% //format like 0.075

Loan Length: 30 years //format in months

import { getTotalInterest } from 'mortgate';


const lifetimeInterest = getTotalInterest(2e5, 7.5e-2, 30 * 12);

Total interest for a loan paying a custom monthly payment Note: It could vary in a few decimal places far from the function getTotalInterest, by the method of recalculation of interest.

Example of variation

Using getTotalInterest: 303434.44615799905

Using getTotalAmortizingInterest: 303434.4461580063

Use getTotalAmortizingInterest if there is an Extra Payment Amount for the monthly payment

Example

Loan = 200000.00

Interest Rate: 7.5% //format like 0.075

Mountly Payment: 2000

import { getTotalAmortizingInterest } from 'mortgate';


const lifetimeInterest = getTotalAmortizingInterest(2e5, 7.5e-2, 2000);

Package Sidebar

Install

npm i mortgage

Weekly Downloads

3

Version

0.3.0

License

MIT

Unpacked Size

17.2 kB

Total Files

4

Last publish

Collaborators

  • alepaz