Skip to content

D0nni387/FragileArt

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

Fragile Art

Fragile Art is a website to showcase and sell the works of Jim Vickers an artist located in Sheffield. He has previously worked with bands such as InMe, Dave McPhearson & Fei Comodo, alongside other projects for brands such as Acoda, Balance, Arkaik Clothing & many more.

Table of Contents

  1. UX

  2. Features

  3. Information Architecture

  4. Technology Used

  5. Testing

  6. Deployment

  7. Credits

  8. Disclaimer

UX

Visitor Goals

  • Provide access to a portfolio of works for visitors to browse.
  • Give potential clients a list of previous clients and their type of business.
  • Allow customers the option to purchase items directly from the site.
  • Give the user additional places to view more current WIP items through social media.
  • Allow the visitor to be able to contact the artist easily and through a variety of methods.
  • Allow the visitor to be able to create and account, add items to their basket and checkout when they have completed shopping.
  • Allow the visitor to return to their basket if they leave and come back to the site.

User Stories

User

  • As a user i want to be able to see their portfolio and discover items i haven't seen before.
  • As a user i want to be able to purchase items that i like.
  • As a user i want to be able to shop with confidence and pay with my card directly not through a third party site.
  • As a user i want to be able to contact the artist to discuss my own projects.
  • As a user and potential client i want to be able to see their past collection of works and clients.
  • As a user i want to be able to find social media links so i can follow the artists latest works.

Admin

  • As a user i want to be able to add products easily.
  • As a user i want to be able to manage orders in a simple and easy manner.
  • As a user i want to be able to upload to my portfolio easily.

Developer

  • As a user i want to ensure the user can't break the flow of the site with correct defensive design choices.
  • As a user i want to ensure an authenticated user can access all required information correctly.
  • As a user i want to include options for the admin to quickly edit the site.

Design Choices

Fonts

The artist has request that the site use Playfair Display as they feel this best suits their work and style they want to achieve.

As a secondary font i have chosen to use Montserrat to compliment this and allow for the extra content to stand out from the rest of the site content.

Colours

The client has specified #323e48 as their desired choice but has said they would allow anything to go with this as long as it contrasted well with the main colour choice.

With this information i have chosen to use the following colours to provide a great contrast and to help the content stand out.

Styling

Wireframes

Desktop

Tablet

Mobile

Features

Exisiting Features

Portfolio

The portfolio section provides the artist a platform to add his works to the site and gives the user the chance to view all his current and past works in one place, each item has a description and a look at who the client for project was.

If the item is also available for sale then the user can also add this to their shopping cart.

Clients

The clients section of the site allows the user and potential new clients to see an overview of previous clients and in what field they operate also pointing the user to get in touch with the artist with regards to their own potential projects

Store

The store will provide the user the oppertunity to purchase any available products directly from the web page and this was previously handled through a third party site.

The user is able to add multiple items to the cart and either securely checkout in their current session or the items can be held until the user returns to the site later.

Payment is handle on the site and keeps the user in the same loop without having to redirect to a third party site.

Contact

The contact page allows the user a variety of methods to contact the artist in relation to either new potential clients or with regards to queries related to existing orders, potential orders or stock queries.

Future Goals

Information Architecture

Data Storage

User Table

Title Key In Database Form Validation Data Type
Account id _id No Validation Primary Key
First Name first_name max length 20 CharField
Last Name last_name hashed min length 8 CharField
E-mail Address email Must contain @ & .com etc Email
Street Address default_street_address1 max length 128 CharField
Street Address 2 default_street_address2 max length 128 CharField
City Or Town default_city_town max length 128 CharField
County/State default_county_state max length 64 CharField
Postal Code default_postcode_zi max length 12 CharField
Contact Number default_telephone_number Number max length 20 CharField
Country country pycountry select Option

Products Table

As the brief for the project requires a portfolio and seperate store one table is created to ensure data isn't stored twice and can be user by both components

Title Key In Database Form Validation Data Type
Product Id _id No Validation Primary Key
Product Name name max length 254 CharField
Product Category category max length 100 CharField
Price price Max Digits 6 Decimal Places 2 DecimalField
Client client No validation CharField
description description No validation CharField
tools colour No validation CharField
is sold is_sold Default True BooleanField
sale_type sale_type max length 20 DecimalField
image image Null True Blank True ImageField

Orders Table

Title Key In Database Form Validation Data Type
Order Number order_number No Validation Primary Key
User Profile user_profile text Foreign Key
First Name first_name max length 100 CharField
Last Name last name max length 100 CharField
email email max length 100 CharField
telephone Number telephone_number max length 20 CharField
street address 1 street_address1 max length 100 CharField
street address 2 street_address2 max length 100 CharField
City Town city_town max length 100 CharField
County/State county_state max length 100 CharField
Postcode Zip postcode_zip max length 8 CharField
Country country country select Option
Order Date order_date datetime.date.today DateField
Total Order total_order max digits 10 DecimalField
Delivery Charge delivery_charge max digits 5 DecimalField
Grand total grand_total max digits 10 DecimalField

Clients Table

Title Key in Database Form Validation Data Type
name name max length 128 CharField
Friendly name friendly_name max length 254 CharField
business type Business Type max length 50 CharField
Description description None TextField
image image None ImageField

Technology Used

Languages

Frameworks

Libraries

Tools

Testing

No automated testing has been used on this project, i have opted to do all testing manually and through numerous user experiences.

  • Implementation 🏭: When i had set up the products fixtures and loaded into the database i could then view all saleable items in the store, i wanted to ensure all products loaded as expected and that item information was visable when selected.

  • Test πŸ§ͺ: To test this, I went through each item and loaded the products information page, then looked at changing the url to ensure each item was loading correctly

  • Result πŸ†: All products loaded as expected to the main store page, some items were missing their images but they were still selectable and loaded their page correctly. When amending the url all items again loaded as expected however if i tried to access an item id that didn't exist i was presented with a 404 page.

  • Verdict βœ…: This test passed in it's basic form, amendments are required to the fixtures to ensure all the items images load correctly, also as the 404 page is the generic template provided with Django creating a custom page to handle these errors is desireable.


  • Implementation 🏭: As with the store the portfolio page is populated from all items even if they aren't saleable. i need to ensure these load correctly to their specific pages and the overlays work correctly.

  • Test πŸ§ͺ: To test this, I went through each item and loaded the portfolio item information page, then looked at changing the url to ensure each item was loading correctly

  • Result πŸ†: All portfolio items again populated the main page correctly, some with missing images and when clicked presented their specific pages with information displaying correctly.

  • Verdict βœ…: This test was deemed to be a pass, some minor edits are needed to the fixtures to ensure when the items are loaded out of development branches they are displaying as expected.


  • Implementation 🏭: As a user can purchase items without signing in, i wanted to ensure that an order can be completed from start to finish.

  • Test πŸ§ͺ: To test this i will select items at random and add them to the basket and proceed through checkout.

  • Result πŸ†: Items were added to the basket correctly and the totals calculated as expected, going through the checkout process i was able to complete the order with stripes debug card ref and the order was confirmed and added to the db correctly.

  • Verdict βœ…: This test completed as expected without bugs.


  • Implementation 🏭: With a logged in user, i want to make sure the user can view previous orders through the users account page.

  • Test πŸ§ͺ: To test this i created a new user and proceeded to add items to the basket and complete the checkout process.

  • Result πŸ†: As expected the checkout process completed and upon checking the users account page i could see the order details. upon completing multiple orders i was able to view these in a list as designed

  • Verdict βœ…: This test completed as expected without bugs, it did flag a minor style change needed to the account page but information was present.


  • Implementation 🏭: To ensure the user can navigate the site as expected i need to test each view and link to ensure the user isn't 'lost' within the page.

  • Test πŸ§ͺ: This test will be carried out by systematically navigating to each page from the previous and all links are clicked until all checked.

  • Result πŸ†: Each page and link was checked and each provided a positive result, at no point was the user sent to an unexpected destination.

  • Verdict βœ…: This test passed and no amendments were required.


  • Implementation 🏭: To test the responsiveness of the site, the page was loaded on local mobile devices to check design choices

  • Test πŸ§ͺ: This test was carried out by loading the site and navigating to each page and adding and completing an order with more than one item

  • Result πŸ†: Each page loaded and displayed correctly, an issue was found with the basket which caused the table to overflow the edge of the page.

  • Verdict βœ…: This test was classed as a fail and upon rereading the code a redesign of the basket was required to ensure mobile users were presented with the correct information that could be easily read.

Bugs


  • Problem 🐞: Confirmation e-mail link produces a 404 error.
  • CauseπŸ› : The environmental variable isn't configured correctly.
  • Resolutionβœ…: adding an initial / to the env path allows the confirmation e-mail to work correctly.

  • Problem 🐞: Custom AllAuth templates not loading
  • CauseπŸ› : Base template no correctly being referenced.
  • Resolutionβœ…: removing allauth from the templates file and reinstating fixed this issue.

  • Problem 🐞: Application won't deploy.
  • CauseπŸ› : A migration file was deleted accidently and hadn't been commited to GitHub
  • Resolutionβœ…: The only sure fire way i found to fix this was to 'nuke' the database on the server, delete all local migration files and run all migrations again and reimporting all fixtures.

  • Problem 🐞: Images when uploaded were not being displayed.
  • CauseπŸ› : When the S3 bucket was enabled static files were not being served correctly.
  • Resolutionβœ…: on checking the img tag urls each file was being referenced incorrectly, each was required to reference the store.product.image.url instead of store.product.image

  • Problem 🐞: Account system failed to register user.
  • CauseπŸ› : As the sign up was intended to work without having to verify an e-mail address, when sign-up the process failed due to no e-mail setting being available.
  • Resolutionβœ…: Added ACCOUNT_EMAIL_VERIFICATION = 'none' to settings.py to stop an e-mail verification trying to be sent.

Unresolved Issues

The only known but that is still present in the site is that the user can remove the max limit on the quantity by removing the flag in the html using Dev tools, should this site go live and used, a different solution would need to be found on the backend to ensure this can't be submitted.

Deployment

Below is an example of how to deploy this site locally based on using VsCode IDE, deploying to Heroku using Amazon S3 for hosting of static and media files. This will allow the site to deploy automatically with commits to the master branch. The code can also be run locally.

Deployment Requirements

  • VScode IDE Local development tool
  • python Documentation is based on Python v3.8
  • PIP package installer
  • Stripe Payment infrastructure

Deploying Locally

  1. Clone a copy of the repository by clicking code at the top of the page and selecting 'Download Zip' when this has downloaded, extract the files to your folder of choice. Alternatively if you have git installed on your client you can run the following command from the terminal.

    git clone https://github.com/D0nni387/FragileArt.git
  2. Open us your local IDE (For this example we will be using VScode as linked in the requirements) and open the working folder.

  3. Ideally you will want to work within a virtual environment to allow all packages to be kept within the project, this can be installed using the following command (please note some IDE's require pip3 instead of pip, please check with the documentation for your chosen IDE)

pip install pipenv
  1. In your root dir, create a new folder called .venv (ensure you have the .)

  2. To activate the virtual environment navigate to the below dir and run activate.bat

[folderinstalled]\scripts\activate\activate.bat

If you're using Linux or Mac use the below command

source .venv/bin/activate
  1. Next we need to install all modules required by the project to run, use the follow
pipenv install -r requirements.txt
  1. Create a new folder within the root dir called env.py. Within this file add the following lines to set up the environmental variables.
import os

os.environ["SECRET_KEY"] = "[Your Secret Key]"
os.environ["DEV"] = "1"
os.environ["HOSTNAME"] = "0.0.0.0"
os.environ["STRIPE_PUBLIC_KEY"] = "[Your Stripe Key]"
os.environ["STRIPE_SECRET_KEY"] = "[Your Stripe Secret Key]"
os.environ["DATABASE_URL"] = "[Your DB URL]"

Database setup

  1. To set up your database you will first need to run the following command
python manage.py migrate
  1. To create a super user to allow you to access the admin panel run the following command in your terminal and complete the required information as prompted
python manage.py createsuperuser
  1. From there you should now be able to run the server using the following command
python manage.py runserver
  1. If everything has been correctly configure you should not get a message giving you a link to your locally hosted site usually at http://127.0.0.1:8000

  2. Next close the server in your terminal using ctrl+c (cmd+c on mac) and run the following commands to populate the database

python manage.py loaddata store/fixtures/categories.json
python manage.py loaddata store/fixtures/products.json
python manage.py loaddata clients/fixtures/clients.json

Deploying to Heroku

To run this application in an online environment you will need to deploy the code to Heroku. Before moving on to this section please ensure you have followed the instructions for local deployment and this has been successful

  1. Either create an account at Heroku or log in to your account
  2. Set up a new app under a unique name
  3. In the resources section, in the addons field type the below command and select the free cost option
heroku Postgres
  1. in the settings tab select Reveal Config Vars and copy the pre populated DATABASE_URL into your settings.py file in your project
  2. in the Config Vars in Heroku you will need to populate with the following keys
Key Value
AWS_ACCESS_KEY_ID [your value]
AWS_SECRET_ACCESS_KEY [your value]
SECRET_KEY [your value]
STRIPE_PUBLIC_KEY [your value]
STRIPE_SECRET_KEY [your value]
USE_AWS TRUE
DATABASE_URL [Your Value]
  1. Now this has been configured you will now migrate the local database to the cloud database using the migrate command as below
python manage.py migrate
  1. Next you will need to create a super user and populate the database as described in the database set up section
  2. When the migrations and data has been loaded, in your Heroku dashboard select the Deploy tab
  3. From here select the Github option and connect the repository from GitHub and select the branch (Master) to deploy from.
  4. It is advised to select automatic deployment to ensure for each push to Github the hosted version is up to date.
  5. When this has deployed select open app from the top bar of the Heroku App.

Credits

Content

Media

All images have been provided by Jim Vickers to aid in the development of this project.

Acknowledgements

  • Simen Daehlin - (mentor) for his invaluable input, advice & support
  • Jim Vickers

Disclaimer

All images & content used for this site are for educational purposes only.

About

Jim Vickers - Fragile Art - Designer Site & Store

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published