Skouter mortgage estimates. Web application with view written in PHP and Vue, but controller and models in Go.
Du kannst nicht mehr als 25 Themen auswählen Themen müssen entweder mit einem Buchstaben oder einer Ziffer beginnen. Sie können Bindestriche („-“) enthalten und bis zu 35 Zeichen lang sein.
 
 
 
 
 
 

75 Zeilen
1.5 KiB

  1. <template>
  2. <Dialog @close="$emit('close')">
  3. <h3>{{heading || "New Fee"}}</h3>
  4. <label>Name</label>
  5. <input type=""
  6. :value="fee.name"
  7. @input="(e) => fee.name = stripLetters(e)">
  8. <label>Amount</label>
  9. <input
  10. type=""
  11. :value="fee.amount / 100 || ''"
  12. @input="(e) => {fee.perc = 0; fee.amount = Math.round(strip(e) * 100)}">
  13. <label>Percentage of price</label>
  14. <input
  15. type=""
  16. :value="fee.perc"
  17. @input="changePerc">
  18. <select id="" name="" v-model="fee.type">
  19. <option value="Title">Title Company</option>
  20. <option value="Government">Government</option>
  21. <option value="Lender">Lender</option>
  22. <option value="Required">Required by Lender</option>
  23. <option value="Other">Other</option>
  24. </select>
  25. <button :disabled="!validFee" @click="() => $emit('save', fee, true)">
  26. Debit
  27. </button>
  28. <button :disabled="!validFee" @click="() => $emit('save', fee, false)">
  29. Credit
  30. </button>
  31. </Dialog>
  32. </template>
  33. <script>
  34. import Dialog from "./dialog.vue"
  35. import { stripLetters, strip, stripInt, stripPerc } from "../helpers.js"
  36. function validFee() {
  37. const fee = this.fee
  38. if (!fee.name || !fee.type) return false
  39. if (!fee.amount && !fee.perc) return false
  40. return true
  41. }
  42. function changePerc(e){
  43. this.fee.perc = stripPerc(e)
  44. this.fee.amount = stripPerc(e)/100*this.price
  45. }
  46. export default {
  47. components: { Dialog },
  48. methods: {
  49. stripLetters, strip, stripInt, stripPerc, changePerc
  50. },
  51. computed: {
  52. validFee,
  53. },
  54. props: ['initial', 'heading', 'price'],
  55. emits: ['close', 'save'],
  56. data() {
  57. return { fee: Object.assign({}, this.initial) }
  58. },
  59. }
  60. </script>