Created
May 3, 2017 07:39
-
-
Save rexfordkelly/c798be2d346b1acb1d5843fea191287b to your computer and use it in GitHub Desktop.
JS Bin // source http://jsbin.com/pevunaniqo
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<!DOCTYPE html> | |
<html> | |
<head> | |
<meta charset="utf-8"> | |
<meta name="viewport" content="width=device-width"> | |
<title>JS Bin</title> | |
<link rel="shortcut icon" href="/images/quicklistings/favicon.ico" type="image/x-icon"> | |
<!-- CSS --> | |
<link href="http://carpe.quicktours.net/css/reset.css" rel="stylesheet"> | |
<link href="http://carpe.quicktours.net/css/forms.css" rel="stylesheet"> | |
<link href="http://carpe.quicktours.net/css/global.css?20170501172111" rel="stylesheet"> | |
<style> | |
/* Reset Buttons */ | |
section .global_button { | |
text-transform: uppercase; | |
clear:both; | |
font-size: 14px; | |
padding: 12px 18px; | |
border-radius: 20px; | |
float:none; | |
margin: 0, auto; | |
max-width: 200px; | |
display:block; | |
margin: 0 auto; | |
} | |
#next-steps span { | |
width: 100%; | |
text-align: center; | |
margin: 0 auto; | |
max-width: 200px; | |
display: block; | |
padding: 10px; | |
} | |
.global_input_simple { | |
width: 25%; | |
float: left; | |
padding-right: 2%; | |
} | |
#calculator{ | |
width: 86%; | |
margin: 0 auto; | |
max-width: 1024px; | |
} | |
form#calculator-form { | |
padding: 40px; | |
margin: 10px; | |
background-color: #222d38; | |
display: block; | |
padding-bottom: 6%; | |
border-radius: 10px; | |
margin-top: 40px; | |
} | |
form div { | |
top: -11px; | |
} | |
.dark-bg input, .dark-bg select { | |
border-color: #59626a; | |
width: 100%; | |
height: 40px; | |
} | |
.global_input_simple label { | |
color: white; | |
opacity: 0.8; | |
} | |
#calculator h1 { | |
margin: 0 auto; | |
width: 98%; | |
padding-top: 31px; | |
margin-bottom: -20px; | |
font-size: 37px; | |
font-weight: 100; | |
} | |
.donut-chart-block.chart-block { | |
width: 61%; | |
float: left; | |
clear: none; | |
} | |
section { | |
display: inline-block; | |
margin: 0 auto; | |
width: 100%; | |
padding-bottom: 50px; | |
} | |
#next-steps { | |
float: right; | |
padding: 5%; | |
border-left: 1px solid #2c3a48; | |
width: 32%; | |
} | |
#calculator-details { | |
margin-top: 49px; | |
} | |
.donut-chart-block.chart-block { | |
width: 63%; | |
float: left; | |
clear: none; | |
} | |
form#calculator-form { | |
padding: 40px; | |
margin: 10px; | |
background-color: #222d38; | |
display: block; | |
padding-bottom: 8%; | |
border-radius: 10px; | |
margin-top: 40px; | |
} | |
.results-list ul { | |
width: 100%; | |
} | |
.results-list li span { | |
float: right; | |
} | |
.results-list li { | |
height: 30px; | |
width: 100%; | |
} | |
.results-list { | |
float: right; | |
padding-top: 41px; | |
width: 41%; | |
} | |
form .msg { | |
position: relative; | |
top: -22px; | |
left: -16px; | |
color: #e64c65; | |
} | |
@media (max-width: 985px) { | |
form#calculator-form{ | |
padding-bottom: 0px; | |
} | |
.global_input_simple{ | |
width:100%; | |
} | |
.donut-chart-block.chart-block { | |
width: 91%; | |
} | |
#calculator-form{ | |
float:left; | |
} | |
.calculator-results { | |
width:91%; | |
} | |
.donut-chart { | |
margin-left: 10%!important; | |
} | |
#next-steps { | |
width: 100%; | |
border: none; | |
border-top: 1px solid; | |
margin-top: 44px; | |
border-color: #394856; | |
} | |
#next-steps a { | |
width: 45%; | |
float: left; | |
margin: 0px; | |
display: inline; | |
clear: none; | |
} | |
#next-steps span { | |
width: 10%; | |
margin: 0px; | |
float: left; | |
text-align: center; | |
} | |
#next-steps span { | |
width: 10%; | |
} | |
.links { | |
margin: 0 auto; | |
width: 83%; | |
max-width: 490px; | |
} | |
} | |
@media (max-width: 628px) { | |
.results-list { | |
clear: both; | |
width: 75%; | |
float: none; | |
margin: 0 auto; | |
} | |
.donut-chart { | |
left: 25%; | |
} | |
#next-steps a, #next-steps span{ | |
width: 55%; | |
text-align: center; | |
margin-left: 25%; | |
} | |
} | |
/****************************************** | |
Donut Chart CSS | |
******************************************/ | |
#calculator-details * { | |
-webkit-box-sizing: border-box; | |
-moz-box-sizing: border-box; | |
box-sizing: border-box; | |
} | |
.chart-block { | |
margin: 25px 25px 0 0; | |
border-radius: 5px; | |
float: left; | |
width: 200px; | |
overflow: hidden; | |
} | |
.donut-chart { | |
position: relative; | |
width: 200px; | |
height: 200px; | |
margin: 3px 13%; | |
border-radius: 100%; | |
float: left; | |
margin-right: -200px; | |
} | |
p.center-data { | |
background: #171f29; | |
position: absolute; | |
text-align: center; | |
font-size: 20px; | |
top: 0; | |
left: 0; | |
bottom: 0; | |
right: 0; | |
width: 150px; | |
height: 150px; | |
margin: auto; | |
border-radius: 50%; | |
line-height: 35px; | |
padding: 23% 0 0; | |
font-weight: 200; | |
} | |
.ring { | |
border-radius: 50%; | |
clip: rect(0px, 200px, 200px, 100px); | |
height: 100%; | |
position: absolute; | |
width: 100%; | |
} | |
.segment { | |
border-radius: 50%; | |
clip: rect(0px, 100px, 200px, 0px); | |
height: 100%; | |
position: absolute; | |
width: 100%; | |
font-family: monospace; | |
font-size: 1.5rem; | |
} | |
.pie-360{ | |
float:left; | |
} | |
.ring.right { | |
transform: rotate(180deg); | |
} | |
.ring.right .segment { | |
background-color: #E64C65; | |
transform: rotate(180deg); | |
} | |
.ring.left { | |
transform: rotate(0deg); | |
} | |
.ring.left .segment { | |
background-color: #E64C65; | |
transform: rotate(180deg); | |
} | |
.center-data i.monthly-total { | |
font-size: 24px; | |
color: white; | |
margin: 0px; | |
margin-bottom: -16px; | |
} | |
.center-data i { | |
font-weight: 100; | |
font-size: 17px; | |
color: grey; | |
margin-top: -16px; | |
display: block; | |
font-style: normal; | |
} | |
/** | |
Result Colors | |
**/ | |
.dark-bg { background-color:#171f29; color: #fff; } | |
.dark-bg .accent-bg{ background-color:#222d38;} | |
.dark-bg .bold-bg{ background:#2fa6cd;} | |
.dark-bg .outline { border-color: #2f363f;} | |
.dark-bg input { border-color: #59626a; } | |
.dark-txt{ color:#ffffff; } | |
.pni-bg { background-color:#2fa6cd; } | |
.pni-txt { color:#2fa6cd; } | |
.pt-bg { background-color:#55dde0; } | |
.pt-txt { color:#55dde0; } | |
.hi-bg { background-color:#e28413; } | |
.hi-txt { color:#e28413; } | |
.other-bg { background-color:#5c2751; } | |
.other-txt{ color:#5c2751; } | |
/** End of Donut Chart**/ | |
</style> | |
</head> | |
<body> | |
<section class="dark-bg"> | |
<div id="calculator"> | |
<h1>Monthly Payment Calculator</h1> | |
<form id="calculator-form"> | |
<div class="msg"> User Message </div> | |
<div class="global_input_simple underline"> | |
<label>Home Price</label> | |
<input id="home-price" min="1" step="any" type="number"/> | |
</div> | |
<div class="global_input_simple underline"> | |
<label>Down Payment</label> | |
<input id="down-payment" min="1" step="any" type="number"/> | |
</div> | |
<div class="global_input_simple"> | |
<label>Interest Rate</label> | |
<input id="interest-rate" min="0.00" step="any" type="number"/> | |
</div> | |
<div class="global_input_simple"> | |
<label>Loan-Term</label> | |
<select id="loan-term" > | |
<option value=""> Term Length </option> | |
<option value="10">10 Year</option> | |
<option value="15">15 Year</option> | |
<option value="30">30 Year</option> | |
<option value="40">40 Year</option> | |
<option value="50">50 Year</option> | |
</select> | |
</div> | |
</form> | |
<div id="calculator-details"> | |
<div id="calculator-results"> | |
<div class="donut-chart-block chart-block "> | |
<style> | |
/* | |
#portion1 { | |
transform: rotate(0deg); | |
} | |
#portion1 .segment { | |
background-color: #E64C65; | |
transform: rotate(76deg); | |
} | |
#portion2 { | |
transform: rotate(76deg); | |
} | |
#portion2 .segment { | |
background-color: #11A8AB; | |
transform: rotate(140deg); | |
} | |
#portion3 { | |
transform: rotate(215deg); | |
} | |
#portion3 .segment { | |
background-color: #4FC4F6; | |
transform: rotate(113deg); | |
} | |
#portion3 { | |
transform: rotate(215deg); | |
} | |
#portion3 .segment { | |
background-color: #4FC4F6; | |
transform: rotate(113deg); | |
} | |
#portionLast { | |
transform: rotate(-32deg); | |
} | |
#portionLast .segment { | |
background-color: #FCB150; | |
transform: rotate(32deg); | |
} */ | |
.360:nth-last-child(1) .segment { | |
background-color:orange; | |
} | |
</style> | |
<div class="donut-chart"> | |
<div class="pie-360"> | |
<div class="ring right"> | |
<div class="segment" data-rel="10"></div> | |
</div> | |
<div class="ring left"> | |
<div class="segment" data-rel="10"></div> | |
</div> | |
</div> | |
<div class="pie-360"> | |
<div class="ring right"> | |
<div class="segment" data-rel="10"></div> | |
</div> | |
<div class="ring left"> | |
<div class="segment" data-rel="10"></div> | |
</div> | |
</div> | |
<p class="center-data"><i class="monthly-total"> $1,142</i> <br><i>/ month</i></p> | |
</div> | |
<div class="results-list"> | |
<style> | |
li{ | |
background-repeat: no-repeat; | |
padding-left: 25px; | |
background-position-y: 1px; | |
} | |
.principal-and-interest{ | |
background-image: url(''); | |
} | |
.property-taxes{ | |
background-image: url(''); | |
} | |
.home-insurance{ | |
background-image: url(''); | |
} | |
.other{ | |
background-image: url(''); | |
} | |
</style> | |
<ul> | |
<li class="principal-and-interest"> Principal & Interest <span> ($714) </span> </li> | |
<li class="property-taxes"> Property taxes <span> ($353) </span> </li> | |
<li class="home-insurance"> Home insurance <span> ($75) </span> </li> | |
<li class="other"> Other <span> ($0) </span> </li> | |
</ul> | |
</div> | |
</div> | |
<div id="next-steps"> | |
<div class="links"> | |
<a class="global_button blue" href="/contact">Get Pre-Approved </a> | |
<span>or</span> | |
<a class="global_button white hollow padded all-caps" href="/contact">Contact an Agent</a> | |
</div> | |
</div> | |
</div> | |
</div> | |
</section> | |
<script id="jsbin-javascript"> | |
/** | |
* | |
* MorgCal - Simple Morgage Calculator V 0.0.1 | |
* Copyright 2017 by Onsors/rexfordkelly | |
* | |
* You are free to use this script, on your site or project. | |
* | |
**/ | |
var calculator = (function(){ | |
function isNumber(fieldinput){ | |
return typeof Number(fieldInput) === 'number'; | |
} | |
function myPayment(){ | |
// Reset user messages. | |
clearMsgs(); | |
// Input Validation | |
if ((document.mortgagecalc.loan.value === null) || (document.mortgagecalc.loan.value.length === 0) || (isNaN(document.mortgagecalc.loan.value) === true)){ | |
document.getElementById('monthlyPayment').innerHTML = 'Please enter the missing information.'; | |
document.getElementById('loanError').innerHTML = 'Numeric value required. Example: 165000'; | |
} else if ((document.mortgagecalc.years.value === null) || (document.mortgagecalc.years.value.length === 0) || (isNaN(document.mortgagecalc.years.value) === true)){ | |
document.getElementById('monthlyPayment').innerHTML = 'Please enter the missing information.'; | |
document.getElementById('yearsError').innerHTML = 'Numeric value required. Example: 30'; | |
} else if ((document.mortgagecalc.rate.value === null) || (document.mortgagecalc.rate.value.length === 0) || (isNaN(document.mortgagecalc.rate.value) === true)){ | |
document.getElementById('monthlyPayment').innerHTML = 'Please enter the missing information.'; | |
document.getElementById('rateError').innerHTML = 'Numeric value required. Example: 5.25'; | |
} else { | |
// Set variables from form data | |
var loanprincipal = document.mortgagecalc.loan.value; | |
var months = document.mortgagecalc.years.value * 12; | |
var interest = document.mortgagecalc.rate.value / 1200; | |
// Calculate mortgage payment and display result | |
document.getElementById('monthlyPayment').innerHTML = 'Your monthly mortgage payment will be ' + '$' + (loanprincipal * interest / (1 - (Math.pow(1/(1 + interest), months)))).toFixed(2)+'.'; | |
document.getElementById('friendlyReminder').style.display = 'block'; | |
} | |
// payment = principle * monthly interest/(1 - (1/(1+MonthlyInterest)*Months)) | |
} | |
function resetCalculator(){ | |
} | |
function validateInputs(inputs){ | |
for(input in inputs ){ | |
if( isNaN(Number(inputs[input].value)) ){ | |
if(inputs[input] === '') return false; | |
} else { | |
if(Number(inputs[input].value) === 0 ) return false; | |
} | |
} | |
return true; | |
} | |
function calculateResults(inputs, rtn = {}){ | |
for(input in inputs){ | |
console.log(inputs[input].value) | |
} | |
return rtn; | |
} | |
function initialize(options){ | |
// reset input values... | |
var inputs = {} | |
options.inputs.forEach(function(input){ | |
// attach listeners... | |
var el = document.getElementById(input); | |
inputs[input] = el; | |
function handleUpdates(inputs){ | |
if( validateInputs(inputs) ){ | |
calculateResults(inputs); | |
} | |
} | |
el.addEventListener('change', function(){ handleUpdates(inputs); }); | |
el.addEventListener('focus', function(){ handleUpdates(inputs); }); | |
}); | |
} | |
function dial(start, end, color = "#E64C65"){ | |
this.start = start || 0; | |
this.end = start && end ? start + end : 360; | |
this.background-color = color; | |
} | |
function renderDial( vars ){ | |
} | |
return { | |
dial: renderDial, | |
calculate:'', | |
clearFields: '', | |
getValues:'', | |
init: initialize | |
} | |
})() | |
calculator.init({ | |
inputs: ["home-price", "down-payment", "interest-rate", "loan-term"] | |
}); | |
</script> | |
<script id="jsbin-source-javascript" type="text/javascript">/** | |
* | |
* MorgCal - Simple Morgage Calculator V 0.0.1 | |
* Copyright 2017 by Onsors/rexfordkelly | |
* | |
* You are free to use this script, on your site or project. | |
* | |
**/ | |
var calculator = (function(){ | |
function isNumber(fieldinput){ | |
return typeof Number(fieldInput) === 'number'; | |
} | |
function myPayment(){ | |
// Reset user messages. | |
clearMsgs(); | |
// Input Validation | |
if ((document.mortgagecalc.loan.value === null) || (document.mortgagecalc.loan.value.length === 0) || (isNaN(document.mortgagecalc.loan.value) === true)){ | |
document.getElementById('monthlyPayment').innerHTML = 'Please enter the missing information.'; | |
document.getElementById('loanError').innerHTML = 'Numeric value required. Example: 165000'; | |
} else if ((document.mortgagecalc.years.value === null) || (document.mortgagecalc.years.value.length === 0) || (isNaN(document.mortgagecalc.years.value) === true)){ | |
document.getElementById('monthlyPayment').innerHTML = 'Please enter the missing information.'; | |
document.getElementById('yearsError').innerHTML = 'Numeric value required. Example: 30'; | |
} else if ((document.mortgagecalc.rate.value === null) || (document.mortgagecalc.rate.value.length === 0) || (isNaN(document.mortgagecalc.rate.value) === true)){ | |
document.getElementById('monthlyPayment').innerHTML = 'Please enter the missing information.'; | |
document.getElementById('rateError').innerHTML = 'Numeric value required. Example: 5.25'; | |
} else { | |
// Set variables from form data | |
var loanprincipal = document.mortgagecalc.loan.value; | |
var months = document.mortgagecalc.years.value * 12; | |
var interest = document.mortgagecalc.rate.value / 1200; | |
// Calculate mortgage payment and display result | |
document.getElementById('monthlyPayment').innerHTML = 'Your monthly mortgage payment will be ' + '$' + (loanprincipal * interest / (1 - (Math.pow(1/(1 + interest), months)))).toFixed(2)+'.'; | |
document.getElementById('friendlyReminder').style.display = 'block'; | |
} | |
// payment = principle * monthly interest/(1 - (1/(1+MonthlyInterest)*Months)) | |
} | |
function resetCalculator(){ | |
} | |
function validateInputs(inputs){ | |
for(input in inputs ){ | |
if( isNaN(Number(inputs[input].value)) ){ | |
if(inputs[input] === '') return false; | |
} else { | |
if(Number(inputs[input].value) === 0 ) return false; | |
} | |
} | |
return true; | |
} | |
function calculateResults(inputs, rtn = {}){ | |
for(input in inputs){ | |
console.log(inputs[input].value) | |
} | |
return rtn; | |
} | |
function initialize(options){ | |
// reset input values... | |
var inputs = {} | |
options.inputs.forEach(function(input){ | |
// attach listeners... | |
var el = document.getElementById(input); | |
inputs[input] = el; | |
function handleUpdates(inputs){ | |
if( validateInputs(inputs) ){ | |
calculateResults(inputs); | |
} | |
} | |
el.addEventListener('change', function(){ handleUpdates(inputs); }); | |
el.addEventListener('focus', function(){ handleUpdates(inputs); }); | |
}); | |
} | |
function dial(start, end, color = "#E64C65"){ | |
this.start = start || 0; | |
this.end = start && end ? start + end : 360; | |
this.background-color = color; | |
} | |
function renderDial( vars ){ | |
} | |
return { | |
dial: renderDial, | |
calculate:'', | |
clearFields: '', | |
getValues:'', | |
init: initialize | |
} | |
})() | |
calculator.init({ | |
inputs: ["home-price", "down-payment", "interest-rate", "loan-term"] | |
}); | |
</script></body> | |
</html> |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/** | |
* | |
* MorgCal - Simple Morgage Calculator V 0.0.1 | |
* Copyright 2017 by Onsors/rexfordkelly | |
* | |
* You are free to use this script, on your site or project. | |
* | |
**/ | |
var calculator = (function(){ | |
function isNumber(fieldinput){ | |
return typeof Number(fieldInput) === 'number'; | |
} | |
function myPayment(){ | |
// Reset user messages. | |
clearMsgs(); | |
// Input Validation | |
if ((document.mortgagecalc.loan.value === null) || (document.mortgagecalc.loan.value.length === 0) || (isNaN(document.mortgagecalc.loan.value) === true)){ | |
document.getElementById('monthlyPayment').innerHTML = 'Please enter the missing information.'; | |
document.getElementById('loanError').innerHTML = 'Numeric value required. Example: 165000'; | |
} else if ((document.mortgagecalc.years.value === null) || (document.mortgagecalc.years.value.length === 0) || (isNaN(document.mortgagecalc.years.value) === true)){ | |
document.getElementById('monthlyPayment').innerHTML = 'Please enter the missing information.'; | |
document.getElementById('yearsError').innerHTML = 'Numeric value required. Example: 30'; | |
} else if ((document.mortgagecalc.rate.value === null) || (document.mortgagecalc.rate.value.length === 0) || (isNaN(document.mortgagecalc.rate.value) === true)){ | |
document.getElementById('monthlyPayment').innerHTML = 'Please enter the missing information.'; | |
document.getElementById('rateError').innerHTML = 'Numeric value required. Example: 5.25'; | |
} else { | |
// Set variables from form data | |
var loanprincipal = document.mortgagecalc.loan.value; | |
var months = document.mortgagecalc.years.value * 12; | |
var interest = document.mortgagecalc.rate.value / 1200; | |
// Calculate mortgage payment and display result | |
document.getElementById('monthlyPayment').innerHTML = 'Your monthly mortgage payment will be ' + '$' + (loanprincipal * interest / (1 - (Math.pow(1/(1 + interest), months)))).toFixed(2)+'.'; | |
document.getElementById('friendlyReminder').style.display = 'block'; | |
} | |
// payment = principle * monthly interest/(1 - (1/(1+MonthlyInterest)*Months)) | |
} | |
function resetCalculator(){ | |
} | |
function validateInputs(inputs){ | |
for(input in inputs ){ | |
if( isNaN(Number(inputs[input].value)) ){ | |
if(inputs[input] === '') return false; | |
} else { | |
if(Number(inputs[input].value) === 0 ) return false; | |
} | |
} | |
return true; | |
} | |
function calculateResults(inputs, rtn = {}){ | |
for(input in inputs){ | |
console.log(inputs[input].value) | |
} | |
return rtn; | |
} | |
function initialize(options){ | |
// reset input values... | |
var inputs = {} | |
options.inputs.forEach(function(input){ | |
// attach listeners... | |
var el = document.getElementById(input); | |
inputs[input] = el; | |
function handleUpdates(inputs){ | |
if( validateInputs(inputs) ){ | |
calculateResults(inputs); | |
} | |
} | |
el.addEventListener('change', function(){ handleUpdates(inputs); }); | |
el.addEventListener('focus', function(){ handleUpdates(inputs); }); | |
}); | |
} | |
function dial(start, end, color = "#E64C65"){ | |
this.start = start || 0; | |
this.end = start && end ? start + end : 360; | |
this.background-color = color; | |
} | |
function renderDial( vars ){ | |
} | |
return { | |
dial: renderDial, | |
calculate:'', | |
clearFields: '', | |
getValues:'', | |
init: initialize | |
} | |
})() | |
calculator.init({ | |
inputs: ["home-price", "down-payment", "interest-rate", "loan-term"] | |
}); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment