The goal of this project is to create an online store which offers automotive window tinting supplies and tools.
- Overview/Description
- User Stories
- User Experience (UX)
- Features
- Technologies Used
- Trials & Testing
- Problem Solving
- Code Validation
- Website Deployment
- Credits & Acknowledgments
- Repository Support
This project aims to create an e-commerce store utilising Django and Stripe.
The website will allow the user to purchase window tinting related items from the comfort of their home.
Below are some user stories which reveal how this website is useful for the end user. Viewing The Store:
- 'A shopper: I want to view a list of product categories'
- 'A shopper: I want to view a list of products in each category'
- 'A shopper: I want to view product details'
- 'A shopper: I want to search & sort items by category'
- 'A shopper: I want to see my cart item total at all times'
- 'A shopper: I want to see frequently asked questions'
- 'A shopper: I want to see contact details for the store'
- 'A shopper: I want to see an about section'
Checking Out:
- 'A shopper: I want to purchase items without signing up'
- 'A shopper: I want to receive an email confirming my order'
User Profiles
- 'A shopper: I want to sign up and keep a record of my orders'
- 'A shopper: I want to be able to recover my password'
- What is the purpose of this website?
- The purpose of this project is to create an e-commerce store and sell window tinting supplies
- Who is the user?
- DIY type user
- Car owner & enthusiast
- Aged 18 and over
- Value for the user?
- Privacy in their car
- UV light protection.
- Provide products that will enable the user to tint their own car. This means providing window tint film as well as installation tools.
- Search function in the store.
- User accounts
- Home page where users can view product categories to help them navigate with ease.
- Private profile where you can see their previous orders.
- A collection of frequently asked questions.
- An about and contact section.
- Scroll to item in FAQ
'userProfile' Model
key | type | required? |
---|---|---|
user | OneToOneField | Yes |
default_phone_number | CharField | No |
default_street_address1 | CharField | No |
default_street_address2 | CharField | No |
default_town_or_city | CharField | No |
default_county | CharField | No |
default_postcode | CharField | No |
default_country | CountryField | No |
'Category' Model
key | type | required? |
---|---|---|
name | CharField | No |
description | CharField | No |
friendly_name | CharField | No |
image | ImageField | No |
'Product' Model
key | type | required? |
---|---|---|
category | ForeignKey | No |
sku | CharField | No |
name | CharField | No |
description | TextField | No |
price | DecimalField | Yes |
image | ImageField | No |
'Order' Model
key | type | required? |
---|---|---|
order_number | CharField | Yes |
user_profile | ForeignKey | No |
full_name | CharField | Yes |
EmailField | Yes | |
phone_number | CharField | Yes |
country | CountryField | Yes |
postcode | CharField | No |
town_or_city | CharField | Yes |
street_address1 | CharField | Yes |
street_address2 | CharField | No |
county | CharField | No |
date | DateTimeField | Yes(auto) |
delivery_cost | DecimalField | Yes |
order_total | DecimalField | Yes |
grand_total | DecimalField | Yes |
original_cart | TextField | Yes |
stripe_pid | CharField | Yes |
'OrderLineItem' Model
key | type | required? |
---|---|---|
order | ForeignKey | Yes |
product | ForeignKey | Yes |
quantity | IntegerField | Yes |
lineitem_total | DecimalField | Yes |
'Faq' Model
key | type | required? |
---|---|---|
collapse_id | CharField | Yes |
title | CharField | Yes |
body | TextField | Yes |
'Review' Model
key | type | required? |
---|---|---|
product | ForeignKey | Yes |
user | ForeignKey | Yes |
body | TextField | Yes |
date | DateTimeField | Yes(auto) |
recommend | BooleanField | Yes |
- Check out with or without an account.
- Search & sort functionality
- View categories, products, faq, about and contact details.
Wireframes can be found here
Primary Colours:
Colour | Colour Code | Preview |
---|---|---|
Black | #000000 | |
Grey | #212529 | |
White | #FFFFFF |
Text Body Colours:
Colour | Colour Code | Preview |
---|---|---|
White | #ffffff | |
Black | #212529 |
"Bebas Neue" will be used for any headings.
"Open Sans" will be used for the body.
- Products
- Product Detail page
- Admin: Edit/Delete Product
- Reviews
- Add or remove you own reviews
- Admin: Remove any review
- Product Detail page
- Categories
- View Categories on homepage/navbar
- Cart
- View cart
- Edit and update cart items
- Calculate total cost
- Checkout
- Complete an order using Stripe payments
- Email order to user
- FAQ
- Admin: Manage FAQ sections
- Profile
- Update saved delivery info
- View order history
- View previous orders
I learned so much about Django throughout this project but I really didn't give myself enough time to create something I was really proud of. I definitely want to create more with Django now that I'm more familiar with e-commerce websites and how their procedures work.
Some features I would add are listed below:
- Forum feature
- Override the Django user model instead of creating a UserProfile model
- Complete redesign
This project uses the following technologies:
- HTML5
- CSS3
- JavaScript
- jQuery
- Python
- Django
- Postgres
- AWS
- Stripe
- Bootstrap 5
- FontAwesome Icons
- Google Fonts
- Github & Git
- GitPod
- Heroku
- Website was run through the Mobile-Friendly Test by Google and was deemed Mobile Friendly. To further test this, I opened the website on my phone as well as friends and co-workers phones.
- Validated HTML, CSS and JS using validators.
- Checked that all links are working using w3 Link Checker.
- Ran style.css through Autoprefixer to add vendor prefixes.
- TESTING.md for more app specific testing.
- I wanted to link to specific items in the FAQ page but I couldn't find a clear way to do so.
- Solution: I added some javascript to handle the URL hash, if a hash is present it will open and scroll to the relevant collapse item.
- Django doesn't have a form field with the
type="tel"
attribute and wouldn't let me change the attribute in the forms.py file.- Solution: I added some javascript to update the type from
text
totel
.
- Solution: I added some javascript to update the type from
HTML was Validated using the W3 Validator.
CSS was Validated using Jigsaw W3 Validator and returned no errors.
JavaScript was Validated using JSHint with no major errors.
bash command flake8 --exclude=*/migrations/*
was used to tidy up Python code.
This project is deployed to the public by using Heroku. This is how I did it.
To deploy this app you will need an AWS account, a Heroku account and a Stripe account. You can follow the links to register with those service providers.
Also, make sure you install all the app dependencies from requirements.txt
and that no files such as the Procfile
are missing before you begin.
AWS Setup:
- Log in to your AWS account and search for S3.
- Create an S3 Bucket for your files and unblock public access to it, take note of your ARN here.
- In the permissions tab use the following configuration.
[
{
"AllowedHeaders": [
"Authorization"
],
"AllowedMethods": [
"GET"
],
"AllowedOrigins": [
"*"
],
"ExposeHeaders": []
}
]
- In the policy tab, use the policy generator and generate an
S3 Bucket Policy
and allow all pricipals by typing a star. Take your ARN from before and paste it into the ARN box. Click add statement then generate your policy. - Copy your policy into your bucket and add a
/*
to the end of the resource key and save. - In the access control list tab, under public access click on everyone, select List Objects and save.
- Next search for IAM and create a new group with a name of your choosing.
- On the left hand side, under "Access Management" click on Policies and create a policy. Go to the JSON tab and import a managed policy named
AmazonS3FullAccess
. Get your S3 bucket ARN again and paste that in after "Resource", as a list (first the ARN, then also the ARN with a slash and star). Click "next tags" and then "next review". Give it any name and description. Click "create policy". - Back in your Groups, click on the group you created, go to permissions and attach the policy you just created.(add permisions, attach policy).
- Under "Access Management" again, this time click on "Users" and add a user, give it programmatic access and click next. Add this user to your previously created group and download the CSV file at the end.
- You will need to update
settings.py
at the bottom of the file. Variables likeAWS_STORAGE_BUCKET_NAME
andAWS_S3_REGION_NAME
need to match your bucket.
Heroku Setup
- Create a new app using the dashboard on Heroku and select a region closest to you.
- In the Resources tab of your App, add Heroku Postgres to store your database tables.
- Add your Heroku app url to
ALLOWED_HOSTS
insettings.py
. - Add the following variables to your
settings tab
DATABASE_URL = This is prefilled for you.
SECRET_KEY = Generate your own key at https://djecrety.ir/
USE_AWS = True
AWS_ACCESS_KEY_ID = From CSV downloaded earlier
AWS_SECRET_ACCESS_KEY = From CSV downloaded earlier
STRIPE_PUBLIC_KEY = We will fill this at the end
STRIPE_SECRET_KEY = We will fill this at the end
STRIPE_WH_SECRET = We will fill this at the end
- In the
Deploy
tab, connect your GitHub and select the repo for this project. - At the bottom you can enable automatic deploys or manually click
Deploy Branch
. - Once that's running. Using dj_database_url in
settings.py
use your Heroku Postgres URL from your Config Variables to connect to your new database. - From your dev environment, use
python3 manage.py migrate
to create the necessary tables to run the app. - Use
python3 manage.py loaddata
to load any fixtures. - Create a superuser using
python3 manage.py createsuperuser
so you can log in to the admin panel. - You can now go back to
settings.py
and switch yourDATABASE
settings back so it searches env variables for the Heroku Postgres URL again.
Stripe Setup:
- Log in to your Stripe account and click "Developers" top right of the page.
- In the API Keys section on the left. Take note of your Publishable Key and Secret Key, use these to fill your Heroku config variables.
- Next click on Webhooks on the left and add an endpoint.
- Your URL should look like this "
your_heroku_app_url
/checkout/wh/" - Add all events to your endpoint.
- Reveal your Signing Secret and add it to your Heroku config variable
STRIPE_WH_SECRET
- First and foremost, the creator of Boutique Ado's walk-through project could not have been any more useful as a resource to get this project to where it is today. Biggest credit of all to the creator at Code Institute.
- Django Documentation
- Python Documentation
- AllAuth Documentation
For support please email at [email protected]