This is the repository for The Philanthropist website.
The deployed site can be visited by clicking here.
The site code can be viewed in this GitHub Repository.
My name is Paul Quinn and I designed and developed this site in its entirety as part of my Fullstack Web Development Diploma with the Code Institute, Ireland. For my Milestone 4 project, I designed a fully functional fullstack e-commerce site called 'The Philanthropist'. The inspiration for this came from my background as an archaeologist and a love for history and our cultural heritage. The concept is that site users can donate an amount of money to their selected site, monument, artefact or text. These donations would then nominally go to a fictional charity called The World Heritage Foundation™, which would distribute the funds proportionately to help preserve the antiquities the user had selected.
The site is built on a fullstack Django framework, is deployed live on Heroku and uses AWS S3 to host media and static files. Locally, it uses the built-in Django Db.sqlite3 database, whereas when deployed live it uses Heroku's Postgres database. Their is full authentication functionality on site using Django's Allauth: admin superusers can add and edit items in the Antiquities and Latest Options apps, whereas normal users can register and login, gaining access to antiquity descriptions and their order history in the Checkout and Profile apps.
There is a full overview of the design/development process below, along with an extensive outline of the testing process, future features, user stories, responsivity and deployment.
-
- Testing Devices
- Developer Tools
- Media Queries
- BrowserStack
- Validation
- User Scenarios
- Unauthenticated user looking to browse antiquities
- Unauthenticated user looking to make a donation
- Unauthenticated user trying to register for an account
- Authenticated user trying to login
- Authenticated user trying to view profile information
- Site administrator looking to view backend information
- Site administrator trying to add or edit an antiquity
- Outstanding Bugs
I wanted the user experience to be clean and clear, where the sites purpose and concept was quickly and intuitively conveyed. I wanted the antiquities and the images of them to be the main focus of the site. I used a combination of a Bootstrap Template called Amado and a selection of high quality photos of the antiquities to achieve this. The chosen template already had a smooth and elegant UI which I could incorporate into my code. I tried to include extra non-template features (such as the edit and delete buttons for superusers or the use of the template home page as the Latest Options App) into the existing flow to the site.
There are different types of user which may visit the site, each with different goals and motivations. I have listed their stories in three categories; The Unauthenticated Site User, The Authenticated Site User, The Site Administrator.
- As an Unauthenticated Site User, I can browse the latest antiquities open to donations on the Latest Options page.
- As an Unauthenticated Site User, I can browse all antiquities and sort and filter by name, value, period and category on the All Antiquities page.
- As an Unauthenticated Site User, I can select my chosen antiquities to donate to on the All Antiquities page and then go to the Cart Page to review my order.
- As an Unauthenticated Site User, I can navigate from the Cart Page to the Checkout Page to enter my billing details and finalise my donation anonymously.
- As an Authenticated Site User, I can Register to create a New Profile from the navbar.
- As an Authenticated Site User, I can Login to my previously created profile from the navbar and gain access to antiquity descriptions on Single Antiquity pages.
- As an Authenticated Site User, I can Login and view my User Profile, along with my Order History, via the link in the navbar.
- As a Site Administrator, I can create a Superuser Profile through Django.
- As a Site Administrator, I can access my Superuser Profile by typing the '/admin' url into the browser.
- As a Site Administrator, I can access all orders, emails, users and app fixtures by viewing the Django admin backend.
I used Adobe XD to design and create Wireframes for this site. For the database schema I used DBDiagram. These documents can be found as PNGs (wireframes) and PDFs (schema) in the Design Docs Folder.
The basic Wireframes are available in 8 PNGs; one which shows the Home Page, one for Selected Products, one for a Shop screen, the Single Item screen, the Shopping Cart screen, one for Checkout, Registration and Login. Any colour used is for contrast only. Simple text headings were added to each element to denote its purpose. These overall Design Choices can be traced to the final deployed Website, with some changes (see Design Changes).
As the templae came with its own colour scheme that complimented the assets I had for the project, there was no need for full colour design mockups of the project.
The template was amended and shaped to match the overall aesthetic, allowing the image's colours to really shine through. The template I used was called Amado (live site here). It was created by Colorlib and distributed by Themewagon. The theme needs several of its own static files to work (CSS and JavaScript). I changed and added to the CSS with my own CSS.
I wanted a selection of high quality images for the site, which would accurately bring across the nature of the antiquities. Where these images would be used was already decided in the design Wireframes (see above). I found the art I sought in various places, including Pinterest, the Museum of Ireland website, the British Museum website, the BBC website and various museum and heritage website sources (see below for full Credits List). All images were re-sized and compressed in Photoshop before use.
The fonts I used were mostly from the [Amado Theme] and were mostly of the Helvetica Neue font family. I combined the Napoli Initialen font (from typographer Mediengestaltung) with Times New Roman to create the different iterations of the Logo.
A Navicon was created for the site using the original Psygnosis Games logo, which I edited in Photoshop Social media link icons were supplied by Font Awesome.
The main difference from the original design is the use of the navbar to the left of screen rather than along the top. The left sided nav was part of the Amado template design, and provides a robust wrapping element for the 'base.html' file, into which all block content could be inserted to the right. This made for easy insertion and application of the various views and pages throughout site. I also used the original home page of the template to make a Latest Options page on site, with a new Landing Page created to greet the user when they first visit the site.
This is a multi-page fullstack framework site, with 6 separate Django apps. The basic layout of the site was created using the Bootstrap 4 grid system (which is based on Flexbox), with alterations and additions. The core of this is the use of containers, rows and columns as classes for elements. All anchor links within text are fully navigable; they also change colour when hovered over.
This the is main template for the site, which contains the Head and Footer and Navbar elements for every other page, route or view. There is also a Subscription section which appears just above the Footer on each page.
-
Navbar
This Navbar is the fully responsive navigation element. It contains links to the following screens: Home, Latest Options, All Antiquities, Cart, links for Login, Registration and Add Antiquity. There is also a Cart Total icon, a Search icon and some Social Media links. I added my own logo to the top of the navbar to connect it with the overall site theme. This element collapses to a dropdown on smaller resolutions.
-
Subscription This is a simple element where users can subscribe to the site via an EmailJS enabled form.
-
Footer
The Footer is a basic element that contains a small Copyright text and the site logo. The links in the navbar also appear here, and become a dropdown on smaller devices.
The games opening page, containing the main logo and some information about the site, along with the Landing Page Background which is an image of the Parthenon in Athens at night. There is also a CTA button asking the user to 'Donate Now'.
Here I amended the original Amado home page to create a new app for the latest antiquities to become available for donation. There is a separate 'latest_options' model and fixture which superusers can update from the admin panel, so the items can be refreshed when new ones become available for donation. Each option links through to the 'single_antiquity' view for that antiquity_id. I created an opaque background and styled the item's title information as it wasn't legible on the bright and detailed antiquity images (as opposed to the austere and white images used in the orginal template).
-
All Antiquities View
This app adds an extra column between the navbar to the left and the antiquities information to the right. This is where you can sort by category or period. The antiquities section contains the image, value, date and name of each item, along with a shopping cart icon so you can add one donation to your cart. If logged in as a superuser, there are edit and delete options for each item. -
Single Antiquity View Here the user can see the antiquities information, including a 4-image carousel of photos, value, name, date and category. If the user is logged in, they also get a description. If not, there is a link instead to either login or register for the site. THere is a quantity input field so users can donate more than once for the same antiquity. The edit and delete options for superusers also appear here.
This page has two main sections: a Shopping Cart Detail section, with image, name, quantity and value of each item; a Cart Total section with a list of cultures supported, number of items and the total donation. Quantity can be changed for each item here, and the edit and delete options for supperusers appear again. The two sections appear side by side on larger resolutions, and with the cart detail above the cart total section on smaller resolutions.
Similar to the Bag App, this page has two main sections: Chosen Donations section, where the user's order is detailed once more (but without the update, edit or delete options); Checkout Information section, where the user inputs their billing info and credit card details before checking out. The credit card section is linked to and enabled by Stripe. The form needs to be fully validated before submission. As with the Bag App, the two sections appear side by side on larger resolutions, and above one another on smaller resolutions.
Once again this page has two main sections: Default Billing Information where the billing information the user has used for previous orders appears and can be updated; the Checkout information section, where each previous order appears with its order number, date, item name x quantity, and order total information visible. The user can click through via a link on the order number to the full details of the original order in the Order History view As with the last two apps above, the two sections appear side by side on larger resolutions, and above one another on smaller resolutions.
-
Pagination
The Amado template comes with pagination elements builtin, so it would be easy to add pagination as a future feature on the All Antiquities page.
-
Sorting by Date through Age Field addition to 'antiquities.json'
Users can already sort by alphabetical order ascending and descending, as well as value of item ascending and descending. However, date is stored as a string in the 'antiquities.json' fixture, as it needs to use the AD and BC suffixes. A possible futreu addition to site would be to calculate the real-time age of each feature from the current year, add a field in the model that gives each antiquity its own Age value, and then sort through this field both ascending and descending.
-
Full Subscription Service linked to Django ADmin backend
The Sunscription Link that appears in the 'base.html' at the bottom of every page is currently enabled by EmailJS. In future, the emails could be linked to the Django backend, enabling the admin superusers to deal with them in the admin login.
-
Extra Information Wikipedia link available on Single Antiquities detail view upon login
The item description on the Single Antiquity page is only viewable if you are a registered and logged in user of the site. A possible future feature would be to expand upon this, offering a longer description along with a link to the items Wikipedia page upon logging in.
All the technologies used to create this project are listed below, along with their usage. Simply click on the title for a link to the main site. When there were separate instances where a technology was used, I have listed each link below.
HTML - This project's structure is based on HTML 5.
CSS - This project's style was created using CSS 3.
Javascript - A number of elements on the site have Javascript functionality (JS 1.8.5).
Python 3 - This project's app routing was created using Python 3.
Git - I used Git to create this project's local repository and to maintain version control.
Github - A remote repository was done through Github.
Heroku - The site was deployed live on Heroku.
AWS - The site was deployed live on Amazon Web Services was used to store the media and static files for the Heroku enabled live version of the site.
Django - This is a fullstack site which uses the Django fullstack framework.
Postgres - This project's live relational database was ennabled by the open-source Postgres database.
VSCode - All code for this site (including this README file), and all Github versioning of this code, was done with VSCode.
Bootstrap - The site was built using Bootstrap's grid system (Bootstrap 4.5.0).
Colorlib - I sourced my website template from this site.
Adobe XD - The wireframes for this site were designed in Adobe XD.
DBDiagram - The database schema for this site was designed with DBDiagram.
Photoshop - I used Photoshop to edit all images, the Favicon and the site Logo.
BrowserStack - Multi-platform testing site.
The site was tested on various devices, including on mobile, laptop and desktop platforms. I list these below:
- Galaxy A5 (Running Android Oreo 8.0.0)
- Fairphone 3 (Running Fairphone OS C20134228)
- iPhone XR (Running iOS 13)
- iPhone SE (Running iOS 13)
- iPhone 7 (Running iOS 13.4.1)
- iPhone 6 (Running iOS 12.4.4)
- HP Pavilion (Running Windows 10)
- Dell Latitude (Running Windows 10)
- MacBook Air (Running Mojave)
- Asus G20CB-UK032T Core i7-6700 (Running Windows 10)
I tested the site in Developer Tools on six internet browsers (Chrome, Firefox, Opera, Edge, Internet Explorer & Safari). Bugs and errors were tackled successfully in this way throughout the development process.
-
Chrome (Version 81.0.4044.138)
-
Firefox (Version 76.0.1)
-
Opera (Version 68.0.3618.104)
-
Edge (Version 44.18362.449.0)
-
Internet Explorer (Version 11.836.18362.0)
-
Safari (Version 13.1)
I used the full gamut of responsivity in Developer Tools, but I also tested on the specific resolutions shown below:
- iPhone 4 (320 x 480)
- Galaxy S5 (360 x 640)
- iPhone X (375 x 812)
- iPad (768 x 1024)
- iPad Pro (1024 x 1366)
- Laptop with MDPI Screen (1280 x 800)
- Laptop with HiDPI Screen (1440 x 900)
- Gaming Desktop (2560 x 1440)
- 4K Monitor (3840 x 2160)
- 4k Plus (4000 x 2200)
BrowserStack - Any platform that I couldn't test in developer tools or on my own devices, I tested here.
There are multiple Media Query resolution denominations in the templates css files, and I have several in my own CSS code also. Every imaginable variation, from the smallest phone to the largest 4K monitor, was used to test the responsivity of the site. There are multiple elements being targeted and styled within several Media Queries.
-
HTML Code Checker - I checked my HTML with the W3C Markup Validation Service. All errors were caused by the validator having difficulty with Django template code. It received the following messages:
-
Several "Error: Bad value for attribute href on element link: Illegal character in path segment: { is not allowed" warnings, for Django template language code across HTML documents in all Apps.
-
Several "Error: Text not allowed in element ul in this context" errors, once again due to Django template code.
-
The '{% load static %} code at the top of 'base.html' was the cause of these errors:
- "Error: Element head is missing a required instance of child element title".
- "Error: Stray doctype"
- "Error: Stray start tag html"
- "Fatal Error: Cannot recover after last error. Any further errors will be ignored."
-
A "Warning: Consider adding a lang attribute to the html start tag to declare the language of this document" for each template besides base.html.
-
An "Error: End of file seen without seeing a doctype first. Expected ! DOCTYPE html" for each template besides base.html.
-
An "Error: Element head is missing a required instance of child element title" for each template besides base.html.
-
Several "Error: Misplaced non-space characters inside a table" errors for Django 'if' loops.
-
Several "Error: Bad character = after <. Probable cause: Unescaped <. Try escaping it as <" errors for template language loop counters.
-
Several "Error: Text not allowed in element ol in this context" messages for template language in ordered lists.
-
-
CSS Code Checker - I checked my CSS with the W3C CSS Validation Service. It received the following messages for vendor prefixes unknown to the validator:
-
Core-style.css: Received several messages for vendor prefixes unknown to the validator, and for importing style sheets at the top of the CSS document.
-
Nice-select.css: Received several messages for vendor prefixes unknown to the validator.
-
Owl-carousel.css: Received several messages for vendor prefixes unknown to the validator.
-
style.css: Received a "Congratulations! No Error Found" message.
-
-
CSS Auto-prefixer - The CSS Online Auto-prefixer provided a Vendor Prefix check for my code. I added all suggestions to my CSS.
-
Javascript Code Checker - I checked my JavaScript JS Hint. It received the following messages:
-
Active.js: Two undefined variables (WOW and jQuery)
-
Map-active.js: One undefined variables (Google)
-
SendEmail.js: Two undefined variables (emailjs and swal)
-
-
ARIA Checker - I used Wave (Web Accessibility Evaluation Tool) to check that my code was accessible to all users. It received the following messages:
-
Several Errors referring to "Missing Empty Links", which are in fact Django template code links.
-
Several Contrast Errors (Mainly referring to the the gold Amado-btn or gold on white backgrounds)
-
Several Possible Heading Errors (Referring to the name of each antiquity in the All Antiquities view, which is not a heading.)
-
Several messages about redundant links regarding links which are legitimate.
-
Alerts for missing form labels.
-
- Go to the Main Page.
- Click on the Navbar link to All Antiquities to the left of the page.
- Go to the Main Page.
- Click on the Navbar link to All Antiquities to the left of the page.
- Select some Antiquities to donate too, either by clicking the cart iocon on a particular item, or clicking to view the antiquity's details in the Single Antiquity view and choosing a quantity of donations.
- Select either the Cart option or the cart icon in the navbar.
- On the Cart page review the order and then select Checkout.
- Enter billing and credit card information and select donate.
- Go to the Main Page.
- Click on the Register button to the left of the page.
- Enter registration details and select Sign Up.
- Find the confirmation email in your inbox.
- Go to the link and select confirm email.
- Go to the Main Page.
- Click on the Login button to the left of the page.
- Enter login details and select Sign In.
- Go to the Main Page.
- Click on the Login button to the left of the page.
- Enter login details and select the My Profile button to the left of page.
- Go to the Main Page.
- Add '/admin' to the end of the url in the browser.
- Enter admin login details.
- Go to the Main Page.
- Click on the Login button to the left of the page and login as a superuser.
- Select the Add Antiquity button to the left of page.
- Add the items details and select Save.
- Go to the Main Page.
- Click on the Login button to the left of the page and login as a superuser.
- Go to the All Antiquities page and select an item to edit, either by the links on the All Antiquities page or on the Single Antiquity details page.
- Edit the items details and select Save.
- The original JS effects that came with the template files used an earlier version of JQuery. This meant that Bootstraps Toasts did not work. I used a CDN link to get th latest version of JQuery and the Bootstrap js links. This meant that the older functions in the template JS did not work on the Latest Options page. Instead, I used Bootstrap responsive classes to style the page so it had the same effect, iterating through the latest options json and creating an element for each.
- On iPhones there is an issue with scrolling on the Cart screen. The screen would only scroll down when the user started swiping below the Shopping Cart heading. This was not seen on any other device.
- Upon load in of the site there are three Stripe JS errors each time; these are with regard to fonts that Stripe uses (message= "Refused to load the font 'https://js.stripe.com/fonts/ProximaNova-Regular.otf' because it violates the following Content Security Policy directive: "font-src 'none'".") This does not seem to effect performance or the functionality of the site in any way.
- Upon load of site this error appears in the browser console: "DevTools failed to load SourceMap: Could not load content for http://127.0.0.1:8000/static/css/bootstrap.min.css.map: HTTP error: status code 404, net::ERR_HTTP_RESPONSE_CODE_FAILURE". I supplied a CDN link to the Bootstrap CSS and this error does not seem to cause any issues with the site.
-
This project is deployed live on Heroku.
-
You can run the code in your chosen local Integrated Development Environment (IDE, e.g. VS Code, AWS CLoud9).
-
Open the Project Repository in Github.
-
Look for the green Coded button at the top right of the repository.
-
If using Github Desktop, chose to Open in Desktop.
-
If you want to Clone the files into a Git repository, chose to copy the URL from the same menu (# 2.). Open your chosen Command Line Interface (CLI, e.g. Gitbash) and use the following command:
git clone https://github.com/an-slua-sidhe/milestone-3.git
-
To set up the files manually in a local repository, chose to Download ZIP and remove the files from the ZIP folder. Place them into the chosen location. If desired, set up a Git repository in this folder in your CLI with the following command:
git init
-
You can check the state of your repository after initialising it by using this command:
git status
-
-
To push the code to a remote repository, follow the steps below (I use Github as an example).
-
After using the command 'git status' (see step 6 above) in the command line, check that the console reads:
Nothing to commit working tree clean
-
Next, link your remote repository. For Github, open your Github account and select Repositories. At the top right of the screen select New.
-
Give your repository a name. Keep it short and avoid underscores.
-
You can now choose a few different ways to link the local and remote repositories. The one we want here is "…or push an existing repository from the command line". Copy the code this option gives you and paste it into your command line. It should look something like this:
git remote add origin https://github.com/an-slua-sidhe/milestone-2 git push -u origin master
-
Now you can push any changes from the command line with:
git push
-
If you check the status of of your local repository now (using 'git status') it should give you something like this:
On branch master Your branch is up-to-date with 'origin/master'. nothing to commit, working tree clean
-
Finally, to deploy the code live with Github Pages, open the repository in your Github account and select 'Settings' at the top right of the page. Scroll down to the Github Pages section. Click on the 'None' button. Select the correct branch from the menu. Now click on the URL link to visit the deployed site.
-
-
To push the code to a Heroku and deploy it dynamically, follow the steps below.
-
Following on from Local deployment step 6 above, type the command 'git status' in the command line and check that the console reads:
Nothing to commit working tree clean
-
Next, create an App on Heroku. Log in to your previous Heroku account or set up a new one, select the New button on the top right of the screen, then select Create New App.
-
Name your app (usinb only lowercase characters and dashes) and choose the regional server that best suits your location.
-
Next, login to your Heroku account from your CLI using:
heroku login
A browser window should open up where you can click to login to your account through your local IDE. If this does not open, select the link on the CLI with ctrl + c and open it manually.
-
Link your existing Git repository to Heroku by adding Heroku as a remote repository:
heroku git:remote -a <project-name>
-
From now on you can push your code from the CLI with:
git push heroku master
-
Set the necessary Environment Variables. Select the Settings tab, and then select the Config Vars button. Enter the KEY - VALUE pairs for your config variables here (e.g. SECRET_KEY, IP, PORT etc.)
-
Finally, select the Open App button the top right of the screen to see your deployed application.
-
- Amado Template
The template used to create the site.
- Source: https://colorlib.com/wp/template/amado/
- Preview Site: https://colorlib.com/preview/#amado
- Boutique Ado
I learned so much while creating the above Code Institute mini-project. The HTML and CSS in The Philanthropist are largely my own dissection of the Amado template code into the various Django apps, but for the python needed to get such a complex site up and running I had to lean heavily on what I had learning in the Fullstack Frameworks and Django Module. I would like to acknowledge that here and give credit where credit is due.
All rights for the images used lies with their respective owners. Images used here for illustrative purposes only in the context of this academic project. Any future professional deployment of the site will use only my own assets.
- Several images were sourced from Pinterest.
- Several images were sourced from the Museum of Ireland website.
- Several images were sourced from the British Museum website.
- Several images were sourced from the BBC website.
- I would like to acknowledge all the archaeologists I have worked besides over the years, and all those who strive to keep our cultural and archaeological heritage safe and available for the next generation.