Last active
February 22, 2018 19:26
-
-
Save hanxue/63eb5f03a4bd78df2111c9b64a625fcf to your computer and use it in GitHub Desktop.
Webpack 3 Vue.js error
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
| eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var accounting__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! accounting */ \"./node_modules/accounting/accounting.js\");\n/* harmony import */ var accounting__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(accounting__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var vuelidate__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! vuelidate */ \"./node_modules/vuelidate/lib/index.js\");\n/* harmony import */ var vuelidate__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(vuelidate__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var vuelidate_lib_validators__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! vuelidate/lib/validators */ \"./node_modules/vuelidate/lib/validators/index.js\");\n/* harmony import */ var vuelidate_lib_validators__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(vuelidate_lib_validators__WEBPACK_IMPORTED_MODULE_2__);\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n\n\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n name: 'PMI',\n mixins: [vuelidate__WEBPACK_IMPORTED_MODULE_1__[\"validationMixin\"]],\n data: function data() {\n return {\n menuVisible: false,\n ficoScores: ['760+', '740-759', '720-739', '700-719', '680-699', '660-679', '640-659', '620-639'],\n selectedFicoScore: '660-679',\n houseValue: accounting__WEBPACK_IMPORTED_MODULE_0___default.a.formatMoney(300000, '$', 0),\n loanAmount: accounting__WEBPACK_IMPORTED_MODULE_0___default.a.formatMoney(285000, '$', 0),\n basisPoints: 0,\n userSaved: false,\n sending: false,\n lastUser: null\n };\n },\n validations: {\n // form: {\n houseValue: {\n required: vuelidate_lib_validators__WEBPACK_IMPORTED_MODULE_2__[\"required\"],\n between: Object(vuelidate_lib_validators__WEBPACK_IMPORTED_MODULE_2__[\"between\"])(0, 100000000)\n },\n loanAmount: {\n required: vuelidate_lib_validators__WEBPACK_IMPORTED_MODULE_2__[\"required\"],\n between: Object(vuelidate_lib_validators__WEBPACK_IMPORTED_MODULE_2__[\"between\"])(0, 100000000),\n maxLength: Object(vuelidate_lib_validators__WEBPACK_IMPORTED_MODULE_2__[\"maxLength\"])(undefined.houseValue)\n },\n selectedFicoScore: {\n required: vuelidate_lib_validators__WEBPACK_IMPORTED_MODULE_2__[\"required\"]\n },\n email: {\n required: vuelidate_lib_validators__WEBPACK_IMPORTED_MODULE_2__[\"required\"],\n email: vuelidate_lib_validators__WEBPACK_IMPORTED_MODULE_2__[\"email\"]\n }\n // }\n },\n computed: {\n ltv: function ltv() {\n var ltv = (accounting__WEBPACK_IMPORTED_MODULE_0___default.a.unformat(this.loanAmount) / accounting__WEBPACK_IMPORTED_MODULE_0___default.a.unformat(this.houseValue) * 100).toFixed(2);\n\n switch (this.selectedFicoScore) {\n\n case '760+':\n if (ltv <= 85) this.basisPoints = .0019;else if (ltv >= 85.01 && ltv <= 90) this.basisPoints = .0030;else if (ltv >= 90.01 && ltv <= 95) this.basisPoints = .0041;else if (ltv >= 95.01 && ltv <= 97) this.basisPoints = .0055;\n break;\n\n case '740-759':\n if (ltv <= 85) this.basisPoints = .0020;else if (ltv >= 85.01 && ltv <= 90) this.basisPoints = .0041;else if (ltv >= 90.01 && ltv <= 95) this.basisPoints = .0059;else if (ltv >= 95.01 && ltv <= 97) this.basisPoints = .0075;\n break;\n\n case '720-739':\n if (ltv <= 85) this.basisPoints = .0023;else if (ltv >= 85.01 && ltv <= 90) this.basisPoints = .0050;else if (ltv >= 90.01 && ltv <= 95) this.basisPoints = .0073;else if (ltv >= 95.01 && ltv <= 97) this.basisPoints = .0095;\n break;\n\n case '700-719':\n if (ltv <= 85) this.basisPoints = .0027;else if (ltv >= 85.01 && ltv <= 90) this.basisPoints = .0060;else if (ltv >= 90.01 && ltv <= 95) this.basisPoints = .0087;else if (ltv >= 95.01 && ltv <= 97) this.basisPoints = .0115;\n break;\n\n case '680-699':\n if (ltv <= 85) this.basisPoints = .0032;else if (ltv >= 85.01 && ltv <= 90) this.basisPoints = .0073;else if (ltv >= 90.01 && ltv <= 95) this.basisPoints = .0108;else if (ltv >= 95.01 && ltv <= 97) this.basisPoints = .0140;\n break;\n\n case '660-979':\n if (ltv <= 85) this.basisPoints = .0041;else if (ltv >= 85.01 && ltv <= 90) this.basisPoints = .0100;else if (ltv >= 90.01 && ltv <= 95) this.basisPoints = .0142;else if (ltv >= 95.01 && ltv <= 97) this.basisPoints = .0190;\n break;\n\n case '640-659':\n if (ltv <= 85) this.basisPoints = .0043;else if (ltv >= 85.01 && ltv <= 90) this.basisPoints = .0105;else if (ltv >= 90.01 && ltv <= 95) this.basisPoints = .0150;else if (ltv >= 95.01 && ltv <= 97) this.basisPoints = .0205;\n break;\n\n case '620-639':\n if (ltv <= 85) this.basisPoints = .0045;else if (ltv >= 85.01 && ltv <= 90) this.basisPoints = .0110;else if (ltv >= 90.01 && ltv <= 95) this.basisPoints = .0161;else if (ltv >= 95.01 && ltv <= 97) this.basisPoints = .0225;\n break;\n\n }\n return ltv;\n },\n equityPercentage: function equityPercentage() {\n return (100 - this.ltv).toFixed(2);\n },\n equity: function equity() {\n return accounting__WEBPACK_IMPORTED_MODULE_0___default.a.formatMoney(accounting__WEBPACK_IMPORTED_MODULE_0___default.a.unformat(this.houseValue) - accounting__WEBPACK_IMPORTED_MODULE_0___default.a.unformat(this.loanAmount), '$', 0);\n },\n pmi: function pmi() {\n if (this.ltv <= 80) {\n return 0;\n } else {\n return accounting__WEBPACK_IMPORTED_MODULE_0___default.a.formatMoney(this.basisPoints * accounting__WEBPACK_IMPORTED_MODULE_0___default.a.unformat(this.loanAmount) / 12);\n }\n }\n },\n methods: {\n getValidationClass: function getValidationClass(fieldName) {\n var field = this.$v[fieldName];\n\n if (field) {\n return {\n 'md-invalid': field.$invalid && field.$dirty\n };\n }\n },\n clearForm: function clearForm() {\n this.$v.$reset();\n this.houseValue = null;\n this.loanAmount = null;\n this.selectedFicoScore = null;\n },\n saveUser: function saveUser() {\n var _this = this;\n\n this.sending = true;\n\n // Instead of this timeout, here you can call your API\n window.setTimeout(function () {\n _this.lastUser = _this.loanAmount + ' ' + _this.houseValue;\n _this.userSaved = true;\n _this.sending = false;\n _this.clearForm();\n }, 1500);\n },\n validateUser: function validateUser() {\n this.$v.$touch();\n\n if (!this.$v.$invalid) {\n this.saveUser();\n }\n }\n }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./node_modules/babel-loader/lib/index.js!./node_modules/vue-loader/lib/selector.js?type=script&index=0!./src/components/PMI.vue.js","sources":["webpack:///PMI.vue?7ff8"],"sourcesContent":["<template>\n        <form novalidate class=\"md-layout-row md-gutter\" @submit.prevent=\"validateUser\">\n          <md-card class=\"md-flex-50 md-flex-small-100\">\n            <md-card-header>\n              <div class=\"md-title\">PMI Calculator</div>\n            </md-card-header>\n\n            <md-card-content>\n              <div class=\"md-layout-row md-layout-wrap md-gutter\">\n                <div class=\"md-flex md-flex-small-100\">\n                  <md-field :class=\"getValidationClass('houseValue')\">\n                    <label for=\"purchase-price\">Purchase Price/Estimated Property Value</label>\n                    <md-input name=\"purchase-price\" id=\"purchase-price\" autocomplete=\"given-name\" v-model=\"houseValue\" :disabled=\"sending\" />\n                    <span class=\"md-error\" v-if=\"!$v.houseValue.required\">The purchase price is required</span>\n                    <span class=\"md-error\" v-else-if=\"!$v.houseValue.between\">Invalid purchase price</span>\n                  </md-field>\n                </div>\n\n                <div class=\"md-flex md-flex-small-100\">\n                  <md-field :class=\"getValidationClass('loanAmount')\">\n                    <label for=\"last-name\">Loan Amount</label>\n                    <md-input name=\"last-name\" id=\"loan-amount\" autocomplete=\"loan-amount\" v-model=\"loanAmount\" :disabled=\"sending\" />\n                    <span class=\"md-error\" v-if=\"!$v.loanAmount.required\">The loan amount is required</span>\n                    <span class=\"md-error\" v-else-if=\"!$v.loanAmount.between\">Invalid loan amount</span>\n                    <span class=\"md-error\" v-else-if=\"!$v.loanAmount.maxLength\">Loan amount cannot be more than purchase price</span>\n                  </md-field>\n                </div>\n              </div>\n\n              <div class=\"md-layout-row md-gutter md-layout-wrap\">\n                <div class=\"md-flex md-flex-small-100\">\n                  <md-field :class=\"getValidationClass('selectedFicoScore')\">\n                    <label for=\"fico-score\">Fico Score</label>\n                    <md-select v-model=\"selectedFicoScore\" md-dense>\n                        <md-option v-for=\"score in ficoScores\" :key='score'>{{score}}</md-option>\n                    </md-select>\n                    <!-- <select class=\"form-control\" v-model=\"selectedFicoScore\">\n                        <option v-for=\"score in ficoScores\" :key='score'>{{score}}</option>\n                      </select> -->\n                    <span class=\"md-error\">FICO score is required</span>\n                  </md-field>\n                </div>\n              </div>\n\n                Your LTV (Loan to Value) is <strong>{{ltv}}%</strong> <br />\n\n                You have <strong>{{equityPercentage}}%</strong> equity which is <strong>{{equity}}</strong><br />\n\n                Selected FICO score is <b>{{selectedFicoScore}}</b> <br />\n\n                <span v-if=\"ltv > 80\">\n                  Your will pay approximatley <strong>{{pmi}}</strong> in Private Mortgage Insurance per month.\n                </span>\n                <span v-if=\"ltv < 80\">\n                  YAY no PMI for you!\n                </span>\n            </md-card-content>\n\n            <md-progress-bar md-mode=\"indeterminate\" v-if=\"sending\" />\n      </md-card>\n\n      <md-snackbar :md-active.sync=\"userSaved\">The user {{ lastUser }} was saved with success!</md-snackbar>\n    </form>\n\n</template>\n\n<script>\nimport accounting from 'accounting'\nimport { validationMixin } from 'vuelidate'\nimport {\n    required,\n    email,\n    minLength,\n    maxLength,\n    between\n  } from 'vuelidate/lib/validators'\n\nexport default {\n  name: 'PMI',\n  mixins: [validationMixin],\n  data: () => ({\n    menuVisible: false,\n    ficoScores: [ '760+', '740-759','720-739', '700-719', '680-699',\n              '660-679', '640-659', '620-639'],\n    selectedFicoScore: '660-679',\n    houseValue: accounting.formatMoney(300000,'$', 0),\n    loanAmount: accounting.formatMoney(285000,'$', 0),\n    basisPoints: 0,\n    userSaved: false,\n    sending: false,\n    lastUser: null,\n  }),\n  validations: {\n    // form: {\n      houseValue: {\n        required,\n        between: between(0, 100000000)\n      },\n      loanAmount: {\n        required,\n        between: between(0, 100000000),\n        maxLength: maxLength(this.houseValue)\n      },\n      selectedFicoScore: {\n        required\n      },\n      email: {\n        required,\n        email\n      },\n    // }\n  },\n  computed: {\n    ltv: function() {\n      var ltv = (accounting.unformat(this.loanAmount) /\n        accounting.unformat(this.houseValue) * 100).toFixed(2);\n\n      switch(this.selectedFicoScore) {\n\n          case '760+':\n          if ( ltv <= 85 )\n              this.basisPoints = .0019;\n          else if ( ltv >= 85.01 && ltv <= 90 )\n              this.basisPoints = .0030;\n          else if ( ltv >= 90.01 && ltv <= 95 )\n              this.basisPoints = .0041;\n          else if ( ltv >= 95.01 && ltv <= 97 )\n              this.basisPoints = .0055;\n              break;\n\n          case '740-759':\n          if ( ltv <= 85 )\n              this.basisPoints = .0020;\n          else if ( ltv >= 85.01 && ltv <= 90 )\n              this.basisPoints = .0041;\n          else if ( ltv >= 90.01 && ltv <= 95 )\n              this.basisPoints = .0059;\n          else if ( ltv >= 95.01 && ltv <= 97 )\n              this.basisPoints = .0075;\n              break;\n\n          case '720-739':\n          if ( ltv <= 85 )\n              this.basisPoints = .0023;\n          else if ( ltv >= 85.01 && ltv <= 90 )\n              this.basisPoints = .0050;\n          else if ( ltv >= 90.01 && ltv <= 95 )\n              this.basisPoints = .0073;\n          else if ( ltv >= 95.01 && ltv <= 97 )\n              this.basisPoints = .0095;\n              break;\n\n          case '700-719':\n          if ( ltv <= 85 )\n              this.basisPoints = .0027;\n          else if ( ltv >= 85.01 && ltv <= 90 )\n              this.basisPoints = .0060;\n          else if ( ltv >= 90.01 && ltv <= 95 )\n              this.basisPoints = .0087;\n          else if ( ltv >= 95.01 && ltv <= 97 )\n              this.basisPoints = .0115;\n              break;\n\n          case '680-699':\n          if ( ltv <= 85 )\n              this.basisPoints = .0032;\n          else if ( ltv >= 85.01 && ltv <= 90 )\n              this.basisPoints = .0073;\n          else if ( ltv >= 90.01 && ltv <= 95 )\n              this.basisPoints = .0108;\n          else if ( ltv >= 95.01 && ltv <= 97 )\n              this.basisPoints = .0140;\n              break;\n\n          case '660-979':\n          if ( ltv <= 85 )\n              this.basisPoints = .0041;\n          else if ( ltv >= 85.01 && ltv <= 90 )\n              this.basisPoints = .0100;\n          else if ( ltv >= 90.01 && ltv <= 95 )\n              this.basisPoints = .0142;\n          else if ( ltv >= 95.01 && ltv <= 97 )\n              this.basisPoints = .0190;\n              break;\n\n          case '640-659':\n          if ( ltv <= 85 )\n              this.basisPoints = .0043;\n          else if ( ltv >= 85.01 && ltv <= 90 )\n              this.basisPoints = .0105;\n          else if ( ltv >= 90.01 && ltv <= 95 )\n              this.basisPoints = .0150;\n          else if ( ltv >= 95.01 && ltv <= 97 )\n              this.basisPoints = .0205;\n              break;\n\n          case '620-639':\n          if ( ltv <= 85 )\n              this.basisPoints = .0045;\n          else if ( ltv >= 85.01 && ltv <= 90 )\n              this.basisPoints = .0110;\n          else if ( ltv >= 90.01 && ltv <= 95 )\n              this.basisPoints = .0161;\n          else if ( ltv >= 95.01 && ltv <= 97 )\n              this.basisPoints = .0225;\n              break;\n\n      }\n      return ltv;\n    },\n    equityPercentage: function() {\n      return (100 - this.ltv).toFixed(2);\n    },\n    equity: function() {\n      return accounting.formatMoney(accounting.unformat(this.houseValue) -\n        accounting.unformat(this.loanAmount), '$', 0);\n    },\n    pmi: function() {\n      if(this.ltv <= 80) {\n        return 0\n      }\n      else {\n        return accounting.formatMoney(\n          (this.basisPoints * accounting.unformat(this.loanAmount)) / 12);\n      }\n    }\n  },\n  methods: {\n      getValidationClass (fieldName) {\n        const field = this.$v[fieldName]\n\n        if (field) {\n          return {\n            'md-invalid': field.$invalid && field.$dirty\n          }\n        }\n      },\n      clearForm () {\n        this.$v.$reset()\n        this.houseValue = null\n        this.loanAmount = null\n        this.selectedFicoScore = null\n      },\n      saveUser () {\n        this.sending = true\n\n        // Instead of this timeout, here you can call your API\n        window.setTimeout(() => {\n          this.lastUser = `${this.loanAmount} ${this.houseValue}`\n          this.userSaved = true\n          this.sending = false\n          this.clearForm()\n        }, 1500)\n      },\n      validateUser () {\n        this.$v.$touch()\n\n        if (!this.$v.$invalid) {\n          this.saveUser()\n        }\n      }\n    },\n};\n</script>\n\n<!-- Add \"scoped\" attribute to limit CSS to this component only -->\n<style scoped>\nh1, h2 {\n  font-weight: normal;\n}\nul {\n  list-style-type: none;\n  padding: 0;\n}\nli {\n  display: inline-block;\n  margin: 0 10px;\n}\na {\n  color: #42b983;\n}\n</style>\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAmEA;AACA;AACA;AACA;AAOA;AAEA;AACA;;;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAVA;;;AAaA;;AAEA;AACA;AAFA;;AAKA;AACA;AACA;AAHA;;AAMA;AADA;;AAIA;AACA;AAFA;AAIA;AAlBA;;AAqBA;AACA;AACA;AAGA;AACA;AAAA;AACA;AASA;AACA;AAAA;AACA;AASA;AACA;AAAA;AACA;AASA;AACA;AAAA;AACA;AASA;AACA;AAAA;AACA;AASA;AACA;AAAA;AACA;AASA;AACA;AAAA;AACA;AASA;AACA;AAAA;AACA;AASA;AACA;;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AAjHA;;AAoHA;AAEA;AACA;AAAA;;AAEA;AADA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AACA;AACA;AACA;AAjCA;AAtJA","sourceRoot":""}\n//# sourceURL=webpack-internal:///./node_modules/babel-loader/lib/index.js!./node_modules/vue-loader/lib/selector.js?type=script&index=0!./src/components/PMI.vue\n"); |
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
| <template> | |
| <form novalidate class="md-layout-row md-gutter" @submit.prevent="validateUser"> | |
| <md-card class="md-flex-50 md-flex-small-100"> | |
| <md-card-header> | |
| <div class="md-title">PMI Calculator</div> | |
| </md-card-header> | |
| <md-card-content> | |
| <div class="md-layout-row md-layout-wrap md-gutter"> | |
| <div class="md-flex md-flex-small-100"> | |
| <md-field :class="getValidationClass('houseValue')"> | |
| <label for="purchase-price">Purchase Price/Estimated Property Value</label> | |
| <md-input name="purchase-price" id="purchase-price" autocomplete="given-name" v-model="houseValue" :disabled="sending" /> | |
| <span class="md-error" v-if="!$v.houseValue.required">The purchase price is required</span> | |
| <span class="md-error" v-else-if="!$v.houseValue.between">Invalid purchase price</span> | |
| </md-field> | |
| </div> | |
| <div class="md-flex md-flex-small-100"> | |
| <md-field :class="getValidationClass('loanAmount')"> | |
| <label for="last-name">Loan Amount</label> | |
| <md-input name="last-name" id="loan-amount" autocomplete="loan-amount" v-model="loanAmount" :disabled="sending" /> | |
| <span class="md-error" v-if="!$v.loanAmount.required">The loan amount is required</span> | |
| <span class="md-error" v-else-if="!$v.loanAmount.between">Invalid loan amount</span> | |
| <span class="md-error" v-else-if="!$v.loanAmount.maxLength">Loan amount cannot be more than purchase price</span> | |
| </md-field> | |
| </div> | |
| </div> | |
| <div class="md-layout-row md-gutter md-layout-wrap"> | |
| <div class="md-flex md-flex-small-100"> | |
| <md-field :class="getValidationClass('selectedFicoScore')"> | |
| <label for="fico-score">Fico Score</label> | |
| <md-select v-model="selectedFicoScore" md-dense> | |
| <md-option v-for="score in ficoScores" :key='score'>{{score}}</md-option> | |
| </md-select> | |
| <!-- <select class="form-control" v-model="selectedFicoScore"> | |
| <option v-for="score in ficoScores" :key='score'>{{score}}</option> | |
| </select> --> | |
| <span class="md-error">FICO score is required</span> | |
| </md-field> | |
| </div> | |
| </div> | |
| Your LTV (Loan to Value) is <strong>{{ltv}}%</strong> <br /> | |
| You have <strong>{{equityPercentage}}%</strong> equity which is <strong>{{equity}}</strong><br /> | |
| Selected FICO score is <b>{{selectedFicoScore}}</b> <br /> | |
| <span v-if="ltv > 80"> | |
| Your will pay approximatley <strong>{{pmi}}</strong> in Private Mortgage Insurance per month. | |
| </span> | |
| <span v-if="ltv < 80"> | |
| YAY no PMI for you! | |
| </span> | |
| </md-card-content> | |
| <md-progress-bar md-mode="indeterminate" v-if="sending" /> | |
| </md-card> | |
| <md-snackbar :md-active.sync="userSaved">The user {{ lastUser }} was saved with success!</md-snackbar> | |
| </form> | |
| </template> | |
| <script> | |
| import accounting from 'accounting' | |
| import { validationMixin } from 'vuelidate' | |
| import { | |
| required, | |
| email, | |
| minLength, | |
| maxLength, | |
| between | |
| } from 'vuelidate/lib/validators' | |
| export default { | |
| name: 'PMI', | |
| mixins: [validationMixin], | |
| data: () => ({ | |
| menuVisible: false, | |
| ficoScores: [ '760+', '740-759','720-739', '700-719', '680-699', | |
| '660-679', '640-659', '620-639'], | |
| selectedFicoScore: '660-679', | |
| houseValue: accounting.formatMoney(300000,'$', 0), | |
| loanAmount: accounting.formatMoney(285000,'$', 0), | |
| basisPoints: 0, | |
| userSaved: false, | |
| sending: false, | |
| lastUser: null, | |
| }), | |
| validations: { | |
| // form: { | |
| houseValue: { | |
| required, | |
| between: between(0, 100000000) | |
| }, | |
| loanAmount: { | |
| required, | |
| between: between(0, 100000000), | |
| maxLength: maxLength(this.houseValue) | |
| }, | |
| selectedFicoScore: { | |
| required | |
| }, | |
| email: { | |
| required, | |
| }, | |
| // } | |
| }, | |
| computed: { | |
| ltv: function() { | |
| var ltv = (accounting.unformat(this.loanAmount) / | |
| accounting.unformat(this.houseValue) * 100).toFixed(2); | |
| switch(this.selectedFicoScore) { | |
| case '760+': | |
| if ( ltv <= 85 ) | |
| this.basisPoints = .0019; | |
| else if ( ltv >= 85.01 && ltv <= 90 ) | |
| this.basisPoints = .0030; | |
| else if ( ltv >= 90.01 && ltv <= 95 ) | |
| this.basisPoints = .0041; | |
| else if ( ltv >= 95.01 && ltv <= 97 ) | |
| this.basisPoints = .0055; | |
| break; | |
| case '740-759': | |
| if ( ltv <= 85 ) | |
| this.basisPoints = .0020; | |
| else if ( ltv >= 85.01 && ltv <= 90 ) | |
| this.basisPoints = .0041; | |
| else if ( ltv >= 90.01 && ltv <= 95 ) | |
| this.basisPoints = .0059; | |
| else if ( ltv >= 95.01 && ltv <= 97 ) | |
| this.basisPoints = .0075; | |
| break; | |
| case '720-739': | |
| if ( ltv <= 85 ) | |
| this.basisPoints = .0023; | |
| else if ( ltv >= 85.01 && ltv <= 90 ) | |
| this.basisPoints = .0050; | |
| else if ( ltv >= 90.01 && ltv <= 95 ) | |
| this.basisPoints = .0073; | |
| else if ( ltv >= 95.01 && ltv <= 97 ) | |
| this.basisPoints = .0095; | |
| break; | |
| case '700-719': | |
| if ( ltv <= 85 ) | |
| this.basisPoints = .0027; | |
| else if ( ltv >= 85.01 && ltv <= 90 ) | |
| this.basisPoints = .0060; | |
| else if ( ltv >= 90.01 && ltv <= 95 ) | |
| this.basisPoints = .0087; | |
| else if ( ltv >= 95.01 && ltv <= 97 ) | |
| this.basisPoints = .0115; | |
| break; | |
| case '680-699': | |
| if ( ltv <= 85 ) | |
| this.basisPoints = .0032; | |
| else if ( ltv >= 85.01 && ltv <= 90 ) | |
| this.basisPoints = .0073; | |
| else if ( ltv >= 90.01 && ltv <= 95 ) | |
| this.basisPoints = .0108; | |
| else if ( ltv >= 95.01 && ltv <= 97 ) | |
| this.basisPoints = .0140; | |
| break; | |
| case '660-979': | |
| if ( ltv <= 85 ) | |
| this.basisPoints = .0041; | |
| else if ( ltv >= 85.01 && ltv <= 90 ) | |
| this.basisPoints = .0100; | |
| else if ( ltv >= 90.01 && ltv <= 95 ) | |
| this.basisPoints = .0142; | |
| else if ( ltv >= 95.01 && ltv <= 97 ) | |
| this.basisPoints = .0190; | |
| break; | |
| case '640-659': | |
| if ( ltv <= 85 ) | |
| this.basisPoints = .0043; | |
| else if ( ltv >= 85.01 && ltv <= 90 ) | |
| this.basisPoints = .0105; | |
| else if ( ltv >= 90.01 && ltv <= 95 ) | |
| this.basisPoints = .0150; | |
| else if ( ltv >= 95.01 && ltv <= 97 ) | |
| this.basisPoints = .0205; | |
| break; | |
| case '620-639': | |
| if ( ltv <= 85 ) | |
| this.basisPoints = .0045; | |
| else if ( ltv >= 85.01 && ltv <= 90 ) | |
| this.basisPoints = .0110; | |
| else if ( ltv >= 90.01 && ltv <= 95 ) | |
| this.basisPoints = .0161; | |
| else if ( ltv >= 95.01 && ltv <= 97 ) | |
| this.basisPoints = .0225; | |
| break; | |
| } | |
| return ltv; | |
| }, | |
| equityPercentage: function() { | |
| return (100 - this.ltv).toFixed(2); | |
| }, | |
| equity: function() { | |
| return accounting.formatMoney(accounting.unformat(this.houseValue) - | |
| accounting.unformat(this.loanAmount), '$', 0); | |
| }, | |
| pmi: function() { | |
| if(this.ltv <= 80) { | |
| return 0 | |
| } | |
| else { | |
| return accounting.formatMoney( | |
| (this.basisPoints * accounting.unformat(this.loanAmount)) / 12); | |
| } | |
| } | |
| }, | |
| methods: { | |
| getValidationClass (fieldName) { | |
| const field = this.$v[fieldName] | |
| if (field) { | |
| return { | |
| 'md-invalid': field.$invalid && field.$dirty | |
| } | |
| } | |
| }, | |
| clearForm () { | |
| this.$v.$reset() | |
| this.houseValue = null | |
| this.loanAmount = null | |
| this.selectedFicoScore = null | |
| }, | |
| saveUser () { | |
| this.sending = true | |
| // Instead of this timeout, here you can call your API | |
| window.setTimeout(() => { | |
| this.lastUser = `${this.loanAmount} ${this.houseValue}` | |
| this.userSaved = true | |
| this.sending = false | |
| this.clearForm() | |
| }, 1500) | |
| }, | |
| validateUser () { | |
| this.$v.$touch() | |
| if (!this.$v.$invalid) { | |
| this.saveUser() | |
| } | |
| } | |
| }, | |
| }; | |
| </script> | |
| <!-- Add "scoped" attribute to limit CSS to this component only --> | |
| <style scoped> | |
| h1, h2 { | |
| font-weight: normal; | |
| } | |
| ul { | |
| list-style-type: none; | |
| padding: 0; | |
| } | |
| li { | |
| display: inline-block; | |
| margin: 0 10px; | |
| } | |
| a { | |
| color: #42b983; | |
| } | |
| </style> |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment