We'll Look Into It is designed as a county/council agnostic pothole reporting system that can be used by the public and administered by users in a council. This initial site gives reporting capabilities and some admin features. There is scope to develop the site further to make it even more useful to both the public and councils.
- Project Goals
- User Experience
- Scope
- Wireframes
- Features
- Technologies Used
- Testing
- Deployment
- Credits
- Acknowledgements
- To have a quick and easy way to report pot holes.
- To provide comments comments when reporting a pothole.
- To see what potholes they've reported and their status.
- To delete or update the details of potholes they've reported.
- To see all potholes reported and their status.
- To be able to request re-assesment of potholes marked as no repair requied if they've gotten worse.
- To view a list of publicly reported potholes for assessment.
- To update the status of potholes as they progress through internal systems.
- To be able to mark potholes as resolved or not.
- To be able to grant registered users admin rights to manage potholes.
- To NOT have the ability to delete potholes, only update status.
- To see a list of newly added/unread pothole reports.
- To be able to add comments to pothole reports.
The site is to be designed with simplicity and ease of access in mind. It will have a mobile first approach to make reporting potholes quick and easy. Users will be required to register for an account to report and manage their pothole submissions. Users will be given the opportunity to comment on their submissions to provide helpful information as to why the pothole should be dealt with. Search capability will be provided so users, registered or not, can check if a pothole has been reported already to save duplicate reports.
- Public road users
- Council employees responsible for road maintenance
As a first time visitor I want...
- to be able to search pothole reports to see if a report has already been made.
- to easily register for the site and submit a pothole report.
Upon returning to the site I want to...
- view a list of my reports and check their status.
- update my reports to add or remove information.
- upvote other users reports.
- request a previously unrepaired pothole be reviewed following a change to it's condition.
As someone administering potholes for a coucil I want to...
- view a list of all pothole reports for my county.
- see any newly submitted pothole reports.
- update the status of existing reports and add comments.
- grant access to my colleagues to be able to update reports.
- add or update Areas for my county.
- add or update Pothole Status'.
As the site owner I want to...
- have access to admin level controls.
- add new Councils to the system.
- set users as Admin or Master Admin.
Based on the project goals the site will use the templating language flask so content can be built dynamically based on a backend database. For this project MongoDB will be used for the data because of the simple data structure.
The following features will be included based on the goals and user stories.
- Limited user management with the ability to register for a new account.
- Create new pothole reports.
- Search existing pothole reports.
- Edit your own pothole reports.
- Delete your own reports.
- See the status of reports.
Admin features:
- Add and remove Areas from counties.
- Grant other users admin privileges.
Master Admin account features:
- Add, Edit and Delete counties.
- Add, Edit and Delete Pothole status'.
- Revoke user admin privileges.
I used Materialize framework to style the site for it's range of features and Material Design styling (although this is now out of date based on Google's latest Material You style). During development I found some limitation with the customisability of the colours used throughout the framework and it has not been updated for some years. I will not use it in the future.
I designed the database schema to allow fo flexibility of use to be adaptable to a wide range of councils.
I selected a colour scheme from the range of colours provided by Materialize. I chose a purple colour for the main theme of the site as I think this looked clean and profressional without being boring.
To distinguish the separate data types on the site from the main data of Pothole Reports I themed the Counties, Areas and Pothole Status pages in separate colours so it is clear what area you're interacting with.
I selelcted the Lato font for the majority of this project as it has nice round lettering and closely matches Google's Product Sans front.
The only image used on the site is the logo that I created. It was inspired by style of the images in this istock image. I created it using Google Drawings which can be found here.
Desktop
Manage Counties, Areas or Status'
Add Counties, Areas or Status'
Tablet
Manage Counties, Areas or Status'
Add Counties, Areas or Status'
Mobile
Manage Counties, Areas or Status'
Add Counties, Areas or Status'
These features can be seen in action in the Testing documentation.
Users
- Anyone can visit the site and see and search for pothole reports.
- Members of the public can register for an account to start reporting potholes.
- Users can edit their pothole reports.
- Users can delete their pothole reports before they've been seen by an Admin user.
- Users can see the status updates of their pothole reports.
- Users cannot edit other's reports.
- Users can upvote existing pothole reports.
- Users can see a list of only their reports on their Profile page.
Admins
Admins can:
- add comments to and set the status of reports.
- not delete reports.
- set registered users to be other Admins.
- add areas to counties.
- edit & delete areas of counties.
- add, edit & delete pothole status'
Master Admins can:
- perform all admin tasks above.
- set other users as Master Admins.
- add counties to the system.
- Limit upvotes to one per user.
- Admin users filter reports to their county.
- Admin users see new, unread reports.
- Admin uploads photo of fixed pothole.
- Daily digest email to Admins of potholes reported in last 24 hours in their County.
- Theme site for each County inclduing a logo
- Features to manage user's own data, update name, email, password, primary county etc.
Google Fonts Site fonts and icons
Testing has been documented in the separate TESTING.md file
I have used Heroku to deploy this site. If you would like to do the same follow these steps.
- Within your project directory create a .gitignore file & an env.py file
- Open env.py and enter
import os
- Then set the following environment variables:
os.environ.setdefault("IP", "0.0.0.0")
os.environ.setdefault("PORT", "5000")
os.environ.setdefault("SECRET_KEY", "your unique secret key")
os.environ.setdefault("MONGO_URI", "your unique mongo db link")
os.environ.setdefault("MONGO_DBNAME", "your database name")
- Add env.py to the .gitignore file so this senstive information is not pushed to Github
- In a bash terminal type
pip3 freeze __local > requirements.txt
- Type
echo web: python app.py > Procfile
(note the capital P of Procfile) - Open the Procfile and remove any blank line from the bottom
git add
thengit push
these files to your repository- Visit heroku.com and sign in or sign up
- Click the New button > Create new app in the top right
- Enter a unique app name, this is unique to all of Heroku, not just your account
- Select the region closest to you
- Click Create app
- Make sure you're on the Deploy tab and select GitHub from Deployment Method
- Check that your GitHub account name is showing
- Type part of the name of your repo to search and click Search
- Click connect for the repo oyu want to connect
- Select the Settings tab
- Click Reveal config vars
- Enter the config vars as set in your env.py file above
- Ensure that your Procfile and requirements.txt files are committed and pushed to GitHub
- Return to the Deploy tab
- Enable automatic deployments
- Select the branch (usually main) and click Deploy Branch
- Once the app been deployed, click on the Open app tab at the top right of the page.
If you would like to fork this respository so you can make changes without affecting the original please follow these steps:
- Log into your GitHub account and find the repository.
- Click 'Fork' (last button on the top right of the repository page).
- You will then have a copy of the repository in your own GitHub account.
In order to make a clone of this repository to work on locally, follow these steps:
- Log into your GitHub account and find the repository.
- Click on the 'Code' button (next to 'Add file').
- To clone the repository using HTTPS, under clone with HTTPS, copy the link.
- For SSH, click the SSH tab and copy that link.
- Then open Git Bash.
- Change the current working directory to where you want the cloned directory to be made.
- In your IDE's terminal type 'git clone' followed by the URL you copied.
- Press Enter.
- Your local clone will now be made.
These resources were used throughout the project to either directly address an issue or implement a feature. Where appropriate (e.g the knowledge is not a general understanding) a "REFERENCE" comment has been included in the code. Any references not included directly in the code are provided here as a reference.
π Mozialla Developer Network - Web Docs CSS
CSS: Cascading Style Sheets | MDN
For reading up on the correct use of CSS selectors, particulary CSS Grid and shorthand properties.
π W3 Schools
For reading up on and experimenting with CSS. For python as a refresher reference to course content covered.
Specific references to creating custom Select inputs and Range inputs are included in the style.css file.
π Mongo DB Docs
Perform CRUD operations - Mongo DB Shell
For reading up on each CRUD operation and to use non-depricated methods like those used in course content.
π Flask Web Developemnt - Developing web applications with python
Grinberg, M. (2018) Flask Web Development. 2nd edn. O'Reilly Media, Inc.
π Reading form elements on form submit
https://stackoverflow.com/questions/37487826/send-form-data-to-javascript-on-submit/#57047920
π Confirming delete
https://stackoverflow.com/questions/45874906/flask-and-javascript-confirm-before-deleting#52675996
π Adding labels to slider
https://stackoverflow.com/questions/61204680/html-range-slider-with-labels-every-5#61205099
π CSS Appearance property
https://developer.mozilla.org/en-US/docs/Web/CSS/appearance
π Correct use of input=range datalist labels
https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/range#adding_hash_marks_and_labels
π Optional parameters on flask routes
https://www.kite.com/python/answers/how-to-have-optional-url-parameters-using-flask-in-python
π Pre-populating Subject & Body in mailto: links
https://css-tricks.com/snippets/html/mailto-links/
- Firstly to my Husband Graham for putting up with being lonely (yet again) whilst I spent most of my free time working on this project.
- And to my peers from the Coleg Y Cymoedd April 2021 cohort who have supported me and kept me sane, chiefly Llewelyn Williams and Andy Llewellyn.
- And to everyone on Code Institute's Slack channels who have helped and answered questions.
- Finally to Millie Kat who has been equal parts a loving companion and pest.