Giter VIP home page Giter VIP logo

code-institute-submissions / house_wars Goto Github PK

View Code? Open in Web Editor NEW

This project forked from maelou363/house_wars

0.0 1.0 0.0 9.82 MB

Wanted a calculator that could quickly tell how much you may be able to potentially borrow and type of house you could afford. May the housing Gods be in our favour as we enter the Dublin housing market.

Home Page: https://maelou363.github.io/house_wars/

HTML 71.65% CSS 13.75% JavaScript 14.61%

house_wars's Introduction

Welcome to House Wars


Code Institute: Milestone Project 2

website mockup on different devices


What does it do and what does it need to fulfill?

The goal of House Wars is to create a calculator that won't ask a bunch of unnecessary questions just to get an idea of how much you can borrow and what the required deposit would be. As I begin my house hunting the oppressive reality of the Dublin housing market has made me want to create this. Just one less thing to enter to check what our buying power is. There are plenty of calculators out there but they ask so many questions like your date of birth, how many children you have etc. etc. For house searches just wanting to get a rough idea on how much they could potentially borrow with their income and the deposit House Wars is created with this need in mind.

House wars is created with mobile first in mind. You'll be able to quickly enter in your income and get a result on how much you can borrow along with the potential deposit you'll have to come up with which gives you your total buying power.

It is a clean design that is streamlined and to the point. A one page calculator where you can enter your basic details to get that rough mortgage buying power saving the user time and giving them the information quickly by creating a the best kind of user experience - the experience where it's so streamlined and free of any impediences. See more about design as we go into details on why we designed it the way we did.

This is my second of four Milestone Projects that are a part of the Full Stack Web Development Program at The Code Insitute. That requirements were to make a responsive application using HTML, CSS and Javascript.

Click here to view the project live

User Experience:

Main Objectives

  • To create a seemless experience for the user. Created with mobile first in mind as majority of users will be 'on-the-go' when they are simply curious if they could afford a certain house or perhaps if their financial position changes.
  • Allow user to quickly be able to see results with just one click.
  • From start to finish with as few clicks as possible to get user to the end of their journey.
  • To allow user to save results so they don't have to continually go back to remember what the results were.
  • To create a design that is responsive on all devices and screen sizes but with mobile first thinking.

User Stories:

The ideal user of this application would be a incoming house buyer either just entering the market or something who has been looking and their financial position has changed and would like to know what that means for drawing down on the mortgage.

Current User:

  • As a current user I want to be able to click once to see what my borrowing and buying power is so I can save time and spend time with family.
  • As a current user I'd like to be able to save the results so I don't have to continue to go back and remember what the results were because it's hard to remember when so much is going on.
  • As a current user I would like to send the results to myself or a family member so that we can discuss and see what our options are together.

New User:

  • As a new user I would like to not be overwhelmed with questions that I am not used too so I can easily get my buying power.
  • As a new user I'm not sure what counts as income so I would like to find out what does easily from one spot so that I can quickly get my result.
  • As a new user I want to be able to easily navigate and be clear what I'm doing when and where within the site.

Design

  • I'm designing this with mobile first in mind. Which brings some things into play. When the user lands on the page they can access everything (no scrolling) to the income, expense, calculate and reset mobile in one spot. I want to design it to be visually clean and free from any impediences.
  • I want this to be a clean design. Visually appealing and the call to action obvious on what they need to do at each step.
  • The design to be a smooth transition to the calculate and view results. With that in mind I implemented a few things like commas in the input and results so users can visually see what they are entering better, automatically entering 'O' for total debt/major expenses and making input fields numbers so when on mobile there is no need to for that extra click to make that change to the number keyboard.

1. Font

2. Colour Scheme

Our colour scheme was created with a goal of a colour palette that would portray sophisticated elegance. Using navy blue as our stand out colour and our gold for accent. We chose colours that would all be AA compliant at mininum but ended up finding a scheme that made them all AAA compliant

** Colour Scheme AAA Compliant Verification **

Compliant AAA Verification for 3A3A44

Compliant AAA Verification for DDBC69

Compliant AAA Verification for D6D9E1

Compliant AAA Verification for C2DEFF

  • #3A3A44 #3A3A44 - Primary colour
  • #DDBC69 #DDBC69 - Secondary colour
  • #D6D9E1 #D6D9E1 - Supplementary colour
  • #C2DEFF #C2DEFF - Supplementary colour 2

3. Logo

logo of house wars calculator

4. Wireframing & Proposed/Implemented Functionality per Page

Wireframes for this project were created using Affinity Design to sketch my general ideas out and then Balsamiq to get a more solid vision. Each element was structurally planned out before building the project to be sure all elements were accounted for and worked together.

Wireframes

house wars wireframes affinity design

house wars wireframes balsamiq

Structure

Our information architecture to demonstrate the flow and key aspects of function throughout the site.

information architecture for house wars

Back to Top

Technology Used

Languages, Frameworks, Editors & Version Control:

  • HTML5/CSS3/Javascript - core languages used to build this site.
  • Bootstrap Framework - Pure CSS Component Frontend framework for layout and overall fronend architecture.
  • Google Fonts - used to import the fonts "Poppins" and "Roboto+Condensed" into the style.css file.
  • JQuery - Open source javascript library design to simplify HTML DOM tree manipulation and event handling.
  • VSCode/Gitpod - preferred used editors/IDEs to develop the project.
  • Git - installed on local machines or default built into Gitpod.
  • Github - used to host the repository and version control the site, aswell as used for deployment of the project.

Tools Used:

  • W3C Markup Validation Service - Used to check the validity and efficiency of the HTML and CSS code base.
  • JSHint - Used to check validity of javascript code
  • Font Awesome - For iconography added to the site.
  • Balsamiq - Used to create the wireframes.
  • TinyPNG - Used to compress images used throughout the site without affecting image integrity/quality.
  • W3C Schools - Used several times whislt building the project and used code snippet for the contact.html form section
  • Am I Responsive - Tool to double check the responsiveness of application
  • WebAIM - Contrast checker to make sure that colours are AA compliant at least. We made sure that our colours were all AAA compliant.

Features

Back to Top

Design Features

House wars was design with loads of UI in mind. Every section of the application was design to create a smooth user experience.

  • The header contains a simple logo at the top in the center of the page which also acts as the navigation when clicked will take you back to the homepage. There really is only one other page FAQ and I made the decision to omit a navigation bar in this design. And instead have a CTA to the FAQ straight below the calculator should a new user enter the application and have additional questions before using. This CTA conveniently is shown on all screen sizes when loading application which fits with our design goals of a one-stop-shop without scrolling.
  • The footer also contain social media icons along with terms/conditions page and FAQ page as well to have another option for navigation of the site.

Home

The Home Page is a clean UI with one column wide on mobile, tablet and computer devices. This application was designed with mobile first so it works on desktop still but from a design standpoint it's created for mobile.

  • Calculator - Occupying almost 90% of the viewing on a mobile. This layout was choosen as to allow the user to simply add inputs and calculate. There are several UI features involved in this design.

    • Automatically putting Total Debt input at '0' to allow user who has no debt to not have to enter in. But if clicked, automatically does remove the 'O' and user can enter in their data.
    • Reset Button that allows user to remove prior inputs and when reset is clicked will autofocus back into 'Total Gross Income' input.

      Calculator Feedback

      • For visual reasons we added commas into the numbers as the user is typing in the number. Allowing the user the ability to have clear feedback on what they have entered.
      • Autofocus on the first input field (Total Gross Income) which if using on desktop requires so clicking but from a UX perspective we didn't want the keyboard showing up immediately so they will have to click the input upon entering the site. We did create a feature where if they click 'reset' buttons it will autofocus back to the total gross income and allow them enter in a new number automatically.
      • Question Popovers - next to our input labels we have more information that can be displayed should user have questions about what should be counted.
  • FAQ Section - Occupying around 10% of the viewing on mobile over 375 allows users to see that they have an option to research and answer further questions should they have them.

  • Results Page - Hidden initially until user clicks 'calculate' Which then will slow scroll automatically to the results page. There is three results populated to give them an idea what they can draw down, deposit needed and total buying potential. Below that is a CTA to share the results.

  • Send Results - Modal popup to send results to whoever they choose to send the results too. There is feedback on the send message button letting user know the message has in fact been sent. They can either close the modal or reset. Reset will bringing back to the calculator section and reset the message sent feedback. We felt it was good UX to keep the name and email populated so when they recalculate all they have to do is hit the 'Send Message' button.

FAQ

The FAQ page is a clean UI with collapsing single column wide across all devices. This was design to allow the page to be clean and the ability to allow the user to be able to see what the questions are and click to view the answers. My thought to this design way to unclutter the space and allow the user to be able to view what they want when they want. 

Future Features:

  • Create a future feature where once established how much you can borrow to bring up properties within that price range.
  • To create a feature that allows First Time Homebuyers to click so it calculates a 10% down deposit.

Code Validation

The W3C Markup Validator was used to validate the HTML code.

Results

  • Index.html
    • There were no errors but a few warnings about a suggestion of headings in our sections. From a design point I do not believe this will add benefit to the user and therefore disregarded.

index.html validator

  • Faq.html

faq.html validator

  • terms-conditions.html

terms-conditions.html validator

  • 404.html

terms-conditions.html validator

The W3C CSS Markup Validator was used to validate the CSS code.

Results

style.css validator

JSHint was used to validate the Javascript and JQuery code used.

Results

  • Calculate.js
    • All errors pertained to variables either declared in other external script or index.html and JQuery variables

calculate.js validator

  • Reset.js
    • All errors pertained to variables either declared in other external script files and JQuery variables

reset.js validator

  • Popover.js
    • All errors pertained to variables either declared in other external script files and JQuery variables

popover.js validator

  • sendMail.js
    • All errors pertained to variables either declared in other external script files and JQuery variables

popover.js validator

Lighthouse Audit

Results

lighthouse validator

Testing Responsiveness

Manually tested the live project using google developer tools to view the project on different screen sizes. Used multiple devices and feedback from family who went to the deployed site on their devices.

  • Responsive Testing

    Responsive Testing

User Flow Testing

  • User Flow Testing

    User Flow Testing

Testing

  • In testing and thinking of the final flow of application is when it occured to me that I'd like to give the user the option to access a navigation menu. This led me to intially begin building a navbar but what I decided was to create a FAQ below our calculator that takes up just 10% of the space below. I believe this is a good use of space and since there isn't many pages within the application this would be a suitable alternative and one less click for the user.

Testing Features

  • HOME

    • Responsive Testing: Everything is responsive to the size of the screen and fits.
    • Pop-up features: Hovering over questions marks and testing clickability on mobile and hoverability on desktop.
    • Calculate:
      • When fields are not fully valid - alert is sent.
      • Input fields do not allow anything other than numerical inputs.
      • Autofocus on Total Gross Income for desktop.
      • Calculate button reveals calculations.
      • Reset button resets inputs and autofocuses back onto Total Gross Income input.
  • Results Page

    • Calculations: Calculations are accurate and rounds to whole numbers.
    • Share Results Buttton - When clicked opens up the share results modal.
  • Send Results

    • Inputs to send results. When clicked gives user feedback that message has been sent.
    • Send correct results to the email provided.

Found Bugs & Fixes:

  • When hitting the reset button it does not clear the results - only clears the inputs entered.
  • Adding commas to the input fields created a problem with our calculations. We ended up having to remove the type="number" from the input field to work with our Jquery but then was concerned from a UI standpoint that they would have to click another time to access the proper number keyboard. Our work around was type="tel" that allowed the calculations to properly calculate but still worked with our function.
  • When not entering values in input field you will be alerted to add values. When this happens it resets the results section which would show previous calculations or a blank result section. Fixed bug by making sure it hides the result section upon this alert.
  • In Share Results form after clicking to close and reset to recalculate the UI 'message sent' does not reset. Fixed this by adding a innerText change within the resetValue function.
  • EmailJS email template stopped sending results and just sending a blank email. We console logged values to confirm they were populating and they were. We confirmed on EmailJS EmailHistory that values were getting delivered. Ended up being that simply changing the color and font of the email template is what causes this bug. The fix was to make the email template plain.... unfortunately...
  • 'submit' Event Listener is firing on the FAQ button that is not connected - fix was to remove the javascript import off of faq.html page.
  • FAQ button was not entirely clickable. Only if the area directly around the text. I added an onclick in the div surrounding the button to allow that entire area to be clickable.
  • 20% deposit results were going way to far in decimal places for unique numbers. Added a Math.round to results to fix problem.

Back to Top

Deployment

This website was developed in multiple editors, Gitpod and vsCode, and version controlling was utilised via local (git) and online (github) repository technologies.

Deploying this application was achieved through Github pages by:

  • Selecting the Repository from my list in the Github Dashboard.
  • Navigating to "Settings" and to the "Github Pages" section.
  • From the "Source" section, click on the dropdown and select "main" branch from the associated list.
  • Once "main" branch is selected, the page will auto-refresh and navigate the user to the top of the page with a visual ribbon display detailing, "Github pages source saved", indicating the success of the deployment.
  • The link to the website can then be found under the "Github Pages" section, with a ribbon notification stating: "Your site is published at "https://.github.io//"

To clone the website:

Select the Repository from the Github Dashboard.

  • Click on the "Clone or download" green button located above and to the right of the "Add file" button.
  • Click on the "clipboard icon" to the right of the Git URL to copy the web URL of the Clone.
  • Open your preferred editor/IDE and navigate to the terminal window.
  • Type git clone <paste-clone-url-here> and press "Enter/Return" on your keyboard.
  • This will create a clone of the project for you.

Acknowledgements

Thank you to everyone who have helped with support, inspiration and guidance at different stages of the project.

Back to Top

house_wars's People

Contributors

maelou363 avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.