Skip to content

Latest commit

 

History

History
329 lines (223 loc) · 17.6 KB

README.md

File metadata and controls

329 lines (223 loc) · 17.6 KB

THIS TEMPLATE IS ONLY TO BE USED ON THE JANUARY HACKATHON PROJECT

Please do not use it for the course project work


💲💲💲 Budget Busters: New Year, New Numbers 💲💲💲

BudgetBustersBanner

SUBMISSION

BalanceBuddy

BalanceBuddy is a personal budgeting application that empowers users to efficiently manage their finances. The app provides a comprehensive financial overview, allowing users to track income, expenses and savings. Its intuitive interface and automated functionalities simplify the budgeting process. With BalanceBuddy, gain control over your money both in the present and for the future.

Table of Contents

Demo

![Website look on different devices](INSERT LINK)

A live demo to the website can be found here

UX

This website is not targeting any specific demographic of users. The site is focused on simplicity and ease of navigation so users can interact with features as easily as possible.

User stories

We decided upon the following points, which are applicable to the users:

  • As a user, I want to see a clear logo and the name of the application so that I know I'm using the right app.
  • As a user, I want to see a logout button for my security.
  • As a user, I desire to access the settings to adjust my app settings or personal preferences.
  • As a user, I want to see an overview of my upcoming bills, savings, spending, and income on the dashboard so I can easily track my financial health.
  • As a user, I want to be able to navigate to a budget tab to view and manage my monthly budget.
  • As a user, I want to view my budget history and make comparisons to previous months.
  • As a user, I want a tab for reports where I can see detailed spending, income and budget overview reports.
  • As a user, I would like a dedicated tab for a currency converter tool with a straightforward interface to convert between currencies.
  • As a user, I want to be able to view the current exchange rates and my past conversions for reference.
  • As a user, I expect to find links to legal information, privacy policy, and terms of service in the footer section.
  • As a user, I want to see copyright information in the footer to understand the ownership of the app content.

Strategy

Multiple developers were involved in this project. Our goal was to create a peronal budgeting app which is accessible to a wide rande of people and provides a simple way to help users manage their finances.

Scope

The scope of the project includes designing and developing the BalanceBuddy application. This includes implementing features for income, expense tracking and savings management. The project encompasses ensuring user-friendly interface and robust security measures. Additionally, it includes comprehensive testing to guarantee optimal functionality, and post-launch maintenance and updates.

Website Sections:

  1. Header: The header section of this website contains a navigation menu bar that appears at the top of the page. The navigation menu includes the website logo, the website name "BalanceBuddy", and a collapsible button for mobile navigation. The menu items vary depending on whether the user is authenticated or not. If the user is authenticated, the menu includes options for email settings, changing password, and logging out. If the user is not authenticated, the menu includes options for registering and logging in.

header-large

header-small

  1. Footer: The footer section of this website contains copyright information and links to legal information, privacy policy, and terms of service. It is placed at the bottom of the webpage and has a light background with a hint of green. The footer is divided into two columns, with the left column displaying the copyright text and the right column displaying the links in a right-aligned manner.

header

  1. Landing Page: This section includes a text box with a brief message welcoming users to BalanceBuddy and describing it as a trusted companion for personal finance management. It encourages users to sign up or log in to start their journey towards financial freedom and balance. The text is centered in the middle of the section for easy readability. There is a stock image of financial documents set as the background image. This page is designed to provide a short description on what the site offers and lead users towards the login or registering page.

landing_page

  1. Log-in Page: The login page features a form with the fields required to authenticate a user. The required fields are: Username and Password. Additonally there are included links for if the user forgot their password, and returning to the dashboard. The login page is styled according to the designated color palette.

login_page

  1. Register Page: The register page is accessed using the link in the top right of the site. This section provides users with the oppertunity to register their credientials and create an account to avccess the site's features. This page is styled in the same way as the login page. The required fields are: Username, Password and repeat password. The field for email address is optional. All optional fields are labelled clearly. If any required fields are left blank, an alert will inform the user.

register_page

  1. Dashboard: The dashboard area contains 5 clickable tabs:
  • Upcoming Bills - where users can input any upcoming bills they will have to pay. Here they can input the title, amount, date and status. There are also buttons to edit and delete the field. bills

  • Expenses - This section is where users can record their expenses. The user records the source, category, amount and description using the add new expense button. There are also buttons to edit and delete the field. expenses

  • Income - This section is where users can record their income. The user records the source, amount, date received, frequency and description using the add new income button. There are also buttons to edit and delete the field. income

  • Charts - this is where all the data is visualised into a pie chart for the user to clearly see how their finances currently look. charts

  • Currency Converter - this is an additional utility where users can convert multiple currencies. converter

  1. Email Settings: This page provides the user with the opportunity to manage their email address linked to their account. Users have the option to assign a primary email, verify an email address by sending a verification email and remove an email address. The page clearly shows whether the users currently assigned email address is verified or not. The page also includes a link back to the dashboard.

email_settings

  1. Change Password: This page provides the user with the ability to change their password for their account. The user will be required input their current password, their new desired password and a repeat of the new password. If any of these fields are not completed or pass validataion, the user will be informed by an alert. There is also a link incase the user has forgotten their password. This will take them to the password reset page.

change_password

  1. Forgotten Password: This page give the user the opportunity to reset their password in case they forget it. The user is required to complete their email field, this will trigger an email to be sent and the password can be reset using the link provided in that email.

forgotten_password

  1. Logout: This page informs the user they are about to log out of their account. It provides a final opportunity to return to their dashboard or confirm the sign-out action.

logout

Skeleton

The website is designed to be clear and simple. The site has a main login page which wen completed opens to a dashboard page. On this dashboard there are multiple tabs which the user can use to navigate the various tools availiable to them.

Wireframes The wireframes were designed using Balsamiq software. These designs were completed at the inception of our project and may not be a true representation of how the site looks today.

wireframe1 wireframe2 wireframe3 wireframe4 wireframe5 wireframe6

Planning

The project was designed meticulously using the agile framework, epitomizing the benefits of a dynamic team-based workflow. Our major planning and communication tool was a Kanban board, used to visualize tasks, outline their status and progress, and precisely denote who was responsible for what. The project was broken down into several manageable tasks and then plotted on the Kanban board, structured into columns specifying stages such as 'To-Do', 'In Progress', and 'Done'. The use of the Kanban board ensured real-time communication of work status to the team, providing a rich landscape of our project progress at any given time. This fostered timely reviews, quick alterations, and overall fluidity, propelling the project towards successful accomplishment.

kanban

Surface

The color pallette for the site was chosen because it matched the colour associated with currency and also provided good contrast and accessibility. The font family was chosen as it is easy to read.

Hex RGB
#244c3c (36,76,60)
#526c5b (82,108,91)
#dcdcbb (220,220,187)
#425e6a (66,94,106)
#fa6e06 (250,110,6)

color-pallette

Technologies used

The website is designed using following technologies: HTML, CSS, Bootstrap, Javascript, Django, MarkDown

Libraries

  • Font Awesome - Font Awesome icons were used throughout the web-site.

Frameworks & Extensions

  • Django – Django is a high-level Python Web framework that encourages rapid development and clean, pragmatic design.
  • Bootstrap – Bootstrap is a web framework that focuses on simplifying the development of informative web pages.

Others

  • GitHub - GitHub is a global company that provides hosting for software development version control using Git.
  • Gitpod - One-click ready-to-code development environments for GitHub.
  • Heroku - Heroku is a cloud platform that lets companies build, deliver, monitor and scale apps.

Features

Existing Features

  1. Content
  • Home page with introduction to app and option to login or register.
  • Navbar/Register: Click on to open sign up page. In sign up page add username, email, password and repeat password.
  • Navbar/Login: Click on to enter username and password. Also option to go to the dashboard.
  • Footer: Footer with legal information, privacy policy and terms of service.
  1. Functionality
  • User account:

    • Sign up / Log in / Log out (with confirmation email sent.)?

    • Edit profile: personal information

    • Spending history

    • Search for a bill or expense

    • Item filtering by categories

    • Upcoming Bills:

      • Add Title
      • Add Amount
      • Add date
      • Add status
      • Edit data
      • Delete data
    • Monthly Expenses:

      • Add Title
      • Add Amount
      • Add date
      • Add status
      • Edit data
      • Delete data
      • Generate Charts
    • Monthly Income:

      • Add Title
      • Add Amount
      • Add date
      • Add status
      • Edit data
      • Delete data
      • Generate Charts
    • Charts:

      • View spending and saving history
    • Currency Converter: *

  • Admin management:

    • CRUD functionalities for Upcoming Bills
    • CRUD functionalities for Monthly Expenses
    • CRUD functionalities for Monthly Income
    • CRUD functionalities for users
    • CRUD functionalities for orders

Features Left to Implement

In the future we would like to add.

  • A feature where the user could take a photo of a receipt and the information would autofil the required fields.
  • An account page the user could customise with a profile picture.
  • A more in depth settings section where users could customize the UI of the page including themes and tabs available in the dashboard.
  • An addition to the profile page where the user can select the currency they wish to view their finances in
  • Add more personalized style to the dashboard tab sections
  • Add tabs for months or years to get a better understanding of what is happening

Testing

  • We tested the site, and it works in different web browsers: Chrome, Firefox, and Microsoft Edge.
  • We confirmed that the site is responsive and functions on different screen sizes using the devtools device toolbar.
Section Tested Input To Validate Expected Outcome Actual Outcome Pass/Fail
Login/Logout Click Open login or logout page Opened login or logout page PASS
Upcoming Bills tab Click Open the Upcoming Bills tab Opened the Upcoming Bills tab PASS
Expenses tab Click Open the Expenses tab Opened the Expenses tab PASS
Income tab Click Open the Income tab Opened the Income tab PASS
Charts tab Click Open the Charts tab Opened the Charts tab PASS
Currency Converter tab Click Open the Currency Converter tab Opened the Currency Converter tab PASS

Validator Testing

WebAim Contrast checker

No errors or warnings were found when passing through the contrast validator.

contrast_validator

Fixed Bugs

  • Two Logout buttons were displayed on the nav bar. The resolution was to delete the duplicated list item.

Unfixed Bugs

  • When I try to change my email, it gives me this error down below

error-when-sending-emails.png

  • When ever I click on the Header logo, it doesn't take me back to the homepage

error-on-homepage-logo.png

  • The pound symbol doesn't sit quiet on the same line as the amount

error-pound-not-on-same-line.png

Deployment

Version Control

The following git commands were used throughout development to push code to the remote repo:

  • git add - This command was used to add the file(s) to the staging area before they are committed.

  • git commit -m “commit message” - This command was used to commit changes to the local repository queue ready for the final step.

  • git push - This command was used to push all committed code to the remote repository on github.

Heroku Deployment

  • Heroku provides a platform for hosting web applications.
  • The deployed site will update automatically upon new commits to the main branch.

Credits

Contributers

Content

Media