JobbaHunt is a job search application built in full stack with react on the client, django REST framework API on the server and a postgreSQL datatbase. Users can create an account, search jobs on Reed API, save jobs, update progress of job applications. Interactions with the app allows the user to collect points that can be exchanged for rewards e.g. virtual coffees with CEOs, LinkedIn connections, etc.
The the aim of JobbaHunt is to improve the job searching process which can be long, stressful and demotivating. We hope the casual language, emojis, and rewards will brighten up the process and motivate users to continue job hunting.
Clone or download this repo.
Navigate to root directory of this repository and open the terminal:
To start up our server:
pipenv shell
pipenv install
cd django
python manage.py runserver
To start up the PostgreSQL database in a docker container:
docker-compose up
It should load on: http://127.0.0.1:8000/
To start up our client:
cd react-client
npm install
npm run dev
It should load on: http://localhost:8080/
- HTML, CSS, Python, JavaScript, docker, SQL
-
Server: django, JWT, django REST framework
-
Client: react, router-dom, react-router-dom, bootstrap, react-bootstrap, sass, axios, jwt-decode, react-icons
-
Server: gunicorn, whitenoise, psycopg2
-
Client: necessary loaders, webpack, babel, jest, react testing library, dotenv-webpack
- Project Plan! Set up Gists, Source of Truth, project Kanban board and use MosCow method for prioritisation
- Design and layout plan! MoqUps, dbDiagram, idea proposal slide deck
- Set up file structure for the decided tech stack - django and react
- Decided to focus on sustainable developement by setting realistic goals in daily stand ups
- Set up ticket system with estimated completion timeframes
- Prepare for deployment! And deploy! Deploy daily to welcome new changes!
- Mob/pair programming to collaborate and we had an open call available all day
- Install django - start project 'careers' and create app for 'users'
- Add Django REST Framework
- Extend base user model with profile details
- Add register route
- Add JWT authentication via simplejwt
- Add user Applications models and views
- Add Rewards app and views for getting/editing rewards
- Add UserReward Many-Many link model that allows adding rewards to a specific user (e.g uploaded CV)
- Add jobs app handling fetching jobs from Reed API using an API key stored in .env
- Edit permissions on routes only available to users/admins
- Add test suite using DRF APIClient class to test endpoints
- Set up react file structure.
- Install dependencies and devdependencies
- Add components: Profile, SearchBar, Sidebar and new Pages within /home and a landing page at /
- Set up routing, nested routes and 404 routes
- Landing page login/register form
- Start stubbing out components and elements for each page
- Install test devdepencies and add setup for test suite
- Add authentication and hide content for users that aren't logged in
- Fetch from jobs API and from our Django API. Render data in correct components and pages
- issue with switch statement / nested switch routes not working. Solved with useRouteMatch
- login/register path not rendering correctly. Solved with location.reload
- /register rendering login form. Solved by refactoring and creating new register page (but i think there could be an even better solution that requires less code lines)
- nav bar and side bar is protected from unauthed user, however main section content still shows upon logout. Solved with history.push to login and useState for style visibility change
- users and profile IDs not matching on back end
- recursive functions error causing infinite requests to our django API. Solved by using useEffect
- nav bar moving the whole main container on hover
- users can add daily streak multiple times a day
- Having a solid plan from early and great communication between the team!
- Successfully deployed front end to Netlify and backend to Heroku
- Authentication between front and back end working smoothly
- Effective use of useState to render updates dynamically
- Environment issues with python and setting up a virtual environment
- Django deployment - lots of configs and trial and error to get it work
- Posting files and images to API
- Fetching from Reed API
- Issues with migrations during deployment
- Direct platform between employers and employees
- Mail service for alerts and notifications (django mail)
- Mobile application using react native