Giter VIP home page Giter VIP logo

hk-painter-and-decorator's Introduction

HK Painting and Decorating Website.

This website was made for the ficticious company HK Painting and Decorating. It is designed to be easy for customers to hire Helen Kent and to view some of her previous work.

It is a simple, three page website, made to be easy to navigate and to give as musch detail as possible, without being confusing for the customer.

This website was designed with many devices in mind, so it needed to be responsive and easy to navigate, for potential customers.

Screenshot of landing page


User Experience


  • User Stories

    • Site Owner Goals

      • To give information about their service.
      • To show work they have completed in the past.
      • To gain more customers.
      • Allow customers to leave their contact details in regards to a quote.
    • Visitor Goals

      • Visitors should be able to quickly contact and hire the tradesperson, quickly and hassle free.

      • Visitors Should be able to come to the site and immediately understand the purpose of the site.

      • They should be able to easily achieve what they came to do (i.e get a quote for a decorating service).

      • They should be able to view past works on a portfolio page, which is set out clearly and easy to see.

      • They will also be able to find their social media sites and other contact information.


Design


  • Colours

    • The colours that I used, were the two main colours from the businesses logo. A green/blue colour and a mid tone orange.

    • The main text color for the body was slategray. For the headers, I used aliceblue.

  • Typography

    • I used the font Poppins as the main font for the website, and I used Sans Serif as a secondary font, incase Poppins did not load correctly. I used Poppins, as it is easy to read and has a soft rounded look, which feels welcoming.
  • Imagery

    • The imagery I used on the landing page is contextual to the product being promoted on the site, as it is of a paint roller for the landing page.
      I edited the photo on canva and adjusted the brightness, just enough to give some contrast to the text above it, but not so much as to stop the viewer from making it out.
  • Wireframes

    • I made wire frames for each type of device that would potentially be used when viewing the website.

    Screenshot of Wireframe design process

    Screenshot of Wireframe for desktop

Features

Page Headers

  • Each page has a header, with a responsive Nav bar, containing links to other pages of the site and a logo that brings the user back to the home page.

  • Below the Nav bar on each page is a hero with a contextual image and an overview of the page.

Carousel

  • On the home page there is a carousel that shows some images of previous work.

Buttons

  • On all pages, there are some buttons that relate to the particular part of the page. They are linked to the relevant parts of the site, making it easy for the user to navigate to where they need to go.

iframe

  • On the home page, there is an iframe with a google map embedded, to allow to user to find the location of HK painting and decorating. This can be used without having to leave the page.

footer

  • Each page has a footer at the bottom, that contains contact details and social media links.

Cards

  • The portfolio page contains cards, to show images of, and descriptions of past work in a tidy and easy to read format.

Form

  • The contact page contains a form, to allow users to leave their contact details and a description of the project they would like Helen to work on.

Hover Effects

  • All links and buttons have hover effects, ranging from pointer events to colour changes to add some interactivity and visual feedback to the user.

Technologies Used

Launguages

Frameworks, Libraries and Programs Used

  1. Google Fonts:

    • I used Google Fonts to link the Poppins font for use on the website.
  2. Font Awesome:

    • I used Font Awesome to provide the social media links in the footer of the site.
  3. Bootstrap V5.0.0:

    • I used bootstrap to help with the responsiveness of the site, and to provide the information for the form on the quotes page.
  4. jsdelivr:

  • jsdelivr was used to enable GitHub to serve my web files without any configuration.
  1. Git:

    • Git was used for version control of the website by using the git commit and git push functions in the terminal, to to ensure any changes I made were not lost and were also meaningful to the development process. It would also help any other developers to assess or make changes in a real world setting.
  2. GitHub:

    • GitHub was used to store the code from the project after being pushed from the terminal.
  3. Adobe XD:

    • I used Adobe XD for the Wireframe, to full site visual design process.

Testing

For my testing I used manual testing.

For testing the code, I used the following;

These were used in particular, to check for errors in the code to enable me to rectify these and have a fully functioning website.

There were three errors on the index.html page.

  • The "hero" element was inside the "main" element.

  • The a tag was a descendent of the button tag X 2.

There was one error on the porfolio page.

  • The a tag was a descendent of the button tag.

There were no errors on the Contact page.

There were no errors in the CSS code.


Fixing the errors


All The above errors were fixed.

The first error was simple to fix. All I needed to change, was the "hero" to a regular div. I had some trouble fixing the second error, as I had to restyle the links to look like the buttons I had used initially. Once I had done this, there were zero errors on all pages. (PHEW!)


Testing on multiple browsers

All browser tests were carried out on desktop, iPad, large Huawei mobile phone and a small iPhone.

I tested the site on multiple browsers, to check that everything loaded. In particular I wanted to check the animations, where I needed to ensure I used @-moz- @-webkit and @-o- for the keyframes.

To do this I simply visited the site on Chrome, Firefox and Opera browsers to see if it worked. Next I inspected the code and tested the responsiveness on various screen sizes.

All the browsers loaded with no problems and all the responsiveness tests (Viewing the site on various devices and dragging the responsive screen) passed with no problems. As well as testing the site on various browsers and mock up devices on my desktop, I downloaded the browsers on my mobile phone and viewed it on there too. All the browsers loaded with no problems on the mobile versions of the browsers too.

Site owner Goals testing

  • To give information about their service.

    • At the top of the home page, there is a description in the hero section explaining what Helen does.

    • There is an iframe on the home page that allows users to find the location of the business. This can be used without leaving the current page.

    • There is a footer on each page containing, phone number, email and social media links. ( The social media links open on a new tab, so the user does not have to leave the current page).

    • There are testimonials on the home page, allowing users to understand more about how Helen works.


  • To show work they have completed in the past.

    • There is a carousel on the home page showing some recent projects.
      There are controls, allowing some user interaction.

    • There is a portfolio page, detailing some recent projects. The page displays the projects on cards with an image on top and a description underneath. When the user hovers over the cards with the mouse, the card scales up to enable the user to better focus on that particular card.


  • To gain more customers.

    • All the previous information helps to gain more customers, by allowing the users to make an informed descision on if they would like to hire Helen or not.

    • There is a contact page with a form, allowing users to give Helen their details and a description of the work they need doing.

    • There is a footer on each page providing contact details for Helen, enabling users to hire her.


  • Allow customers to leave their contact details in regards to a quote.

    • There is a contact page containing a form to allow users to leave their name, phone number and email address for Helen. This not only allows the user to contact Helen, but it enables Helen to contact the user, if they decide not to leave details about the job. The name and email address are both required fields. This is to allows Helen enough information to be able to contact the user in case the user is unable to leave a phone number or job description.

Visitor Goals

  • Visitors should be able to quickly contact and hire the tradesperson, quickly and hassle free.

    • There is a footer on each page containing contact details.

    • There is a contact page with a form allowing the customer to leave their contact information and details about the job.

    • There are buttons on the home page and portfolio page that direct the user to the contact# page. There is also a link to the contact page in the navbar.


  • Visitors Should be able to come to the site and immediately understand the purpose of the site.

    • On the home page, there is a logo in the navbar with the words "Painter" and "Decorator".

    • There is a description in the hero section, with a button underneath. This shows the user what the site is about and it shows them that they can hire Helen.


  • They should be able to easily achieve what they came to do (i.e get a quote for a decorating service).

    • Straight away on the home page, there is a contact link in the navbar and a button in the hero section saying "contact us".

    • There is a footer on each page with contact details, allowing the user to contact and hire Helen.

    • There are testimonials and recent project sections that allow the user to see more about Helen and make an informed descision on whether they would like to hire her.

    • There is a contact page with a form, allowing the user to leave their details and contact Helen about a job they need doing.


  • They should be able to view past works on a portfolio page, which is set out clearly and easy to see.

    • There is a portoflio page that shows recent projects. They are set out on cards, which clearly shows an image of the project and gives a detailed description below.

  • They will also be able to find their social media sites and other contact information.

    • At the bottom of each page, there is a footer that contains Helen's social media links, phone number and email address.

    • On the home page, there is an iframe where the user can find the address and location of the business.


Client based testing

  • For the client based tests, I sent the link to the website to various people and asked them, to use it. I asked the first person to test it on mobile devices such as , mobile phones and tablets.

    They were asked to check both orientations, to see if the responsiveness worked, and then to load the pages one by one to see if the animations worked. They were also asked to check the site accross Chrome, Firefox and Opera browsers to check compatability.

  • For the next test I asked three people to check the desktop version of the site. Each of them had a different browser. One had Chrome, one had Firefox and one had Opera.

    I asked them to check the animations for the pages and to check for any gramatical errors.

  • After the tests were completed, they reported back that the animations worked fine accross all browsers and the responsiveness worked on all the mobile devices that were used. However, there were some gramatical errors on the home page and portfolio page. I had used first person speech rather than the third person. I then went through and rectified these errors.

Deployment

  • To deploy the website, I used GitHub pages.

    The process for this was simple. I used the terminal on the Gitpod IDE. I used the git add . command to add all the files that had been worked on. Next I used the git commit command, to commit my files ready for deployment, followed by the git push command, to push the code to GitHub.

    I also did this during development, so as not to loose and changes or work that I had done.

  • To link Github pages to the correct files I went to settings and scrolled down to the GitHub pages section of the page.
    Next, I clicked the drop down menu on the source section and chose the master branch and the root folder from my repository. This is how GitHub pages built my site.

  • I then waited for the site to be built and followed the link at the top of the section.


Running the site locally

  • To run the site locally, you will need to clone the GitHub repository

  • To do this, simply go to the GitHub repository

    • Next, click the dropdown menu named "code". This will bring up the clone menu.

    • Select HTTPS and copy the link.

    • Create a location on your local computer, where you would like to clone the repository.

    • Then on your local terminal use the "git clone" command and paste the link after it and hit return.

    • This will create a folder in the location you have created. This will contain all the files from the repository, allowing you to run the site.

Credits

Content

  • All code was written by myself (Rob Hunns)

Media

  • All images for this site were from Pexels.

  • The HK Painting and Decorating logo was made by me using Photoshop

Acknowledgements

  • I would first like to acknowledge my mentor Ignatius, for the suppoprt he has given me during the project. Particularly for giding me towards good documentation for the parts of the project where I needed to do a bit more research.

  • Codeinstitute: For providing such good training and tutorials, giving me the confidence to keep going and to hone my problenm solving skills.

hk-painter-and-decorator's People

Contributors

hunnser86 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.