Skip to content

CSC-510-G55/project1-ats

 
 

Repository files navigation

GitHub license DOI GitHub issues GitHub issues GitHub top language Build Pytest Codecov Pylint Prettier

J-Tracker - Your Job Tracking Assistant

Introductory_Video.mp4

The process of applying for jobs and internships is not a cakewalk. Managing job applications is a time-consuming process. Due to the referrals and deadlines, the entire procedure can be stressful. Our application allows you to track and manage your job application process, as well as regulate it, without the use of cumbersome Excel spreadsheets.

Our application keeps track of the jobs you've added to your wish list. It also keeps track of the companies you've already applied to and keeps a list of any rejections. Rather than having the user browse each company's site for potential prospects, our application allows the applicant to search for them directly using basic keywords. Any prospective work offers can then be added to the applicant's wishlist.

Table of contents

Basic Design

Basic Design

Demo Video

https://drive.google.com/file/d/1ex5-YLe7Nk8qPSVuC0A4Oy5Kil-VJqz9/view

Improvements and Feature Additions Fall 2024 CSC-510-G55

1) Apply via job portals:

To enhance user interaction and simplify the application process, the platform includes direct links for applying for each job listing from the corresponding job board where the job was originally posted. These links enable users to seamlessly connect with the job poster and apply to the job, facilitating a direct and efficient application process. This feature not only saves users valuable time but also improves the overall user experience by eliminating unnecessary steps and ensuring a smoother journey through the platform. With a single click, users can initiate the application process, contributing to a more user-friendly and streamlined platform. Apply Job Portal

2) Added a new page for My Applications:

This page is a visual board that helps manage work in progress and optimize workflow. It is a useful way to organize and visualize the different stages of your job application process.

Rejected: This column represents the stage where applications that have been reviewed and rejected by the prospective employers are placed. Applicants can use this column to keep track of the positions that did not progress further in the hiring process.

Applied: This column is for applications that have been submitted but are still awaiting a response from the employers. It helps candidates to easily identify the positions they've applied for and are currently under consideration.

Wishlist: The Wishlist column is for positions that the applicant is interested in but hasn't applied for yet. This can serve as a reminder of potential job opportunities, and applicants can move them to the "Applied" column once they submit their applications.

Waiting for Referral: In this column, applicants can track positions for which they are waiting for a referral or some kind of internal recommendation. Networking and referrals are crucial in the job search process, and this column helps candidates keep track of such opportunities.

Move Cards: Applications can be represented as cards, with each card moving across the columns as the application progresses. Visualize Progress: The board provides a visual representation of the overall status of your job applications. Prioritize: Applicants can prioritize applications in the Wishlist column and focus on applying for those positions. Identify Bottlenecks: If many applications are stuck in a particular column, it may indicate a bottleneck or an area that needs attention in the job search process. My Applications Page

My Applications Page

3) Filtering applications:

To enhance user convenience, especially for students managing a multitude of applications, the inclusion of filters is crucial. These filters enable users to categorize applications based on their status—such as accepted, rejected, waitlisted, wish-listed, or awaiting referrals. Additionally, the filter functionality extends to sorting applications based on location, job title, and even the company name, providing a comprehensive and efficient way to organize and navigate through the application process. Filtering

4) Adding Notes to Applications:

Applicant Tracking Systems (ATS) traditionally cater to hiring professionals, but an innovative addition involves enabling applicants to add notes and updates to their applications. The integration of a notes feature is a powerful tool that enables users, particularly applicants, to add real-time, personalized notes and updates for each application. This dynamic feature allows candidates to actively document their application journey, noting essential dates, interactions, and any pertinent details they find important. By doing so, applicants maintain a heightened sense of organization and stay well-informed throughout the entire hiring process. The real-time nature of this notes feature becomes a valuable asset for applicants. It empowers them to reflect on their progress and express their thoughts, motivations, and distinctive qualifications instantaneously. Notes

5) Adding Profile Picture:

To enhance user profiles, the platform now includes an option to upload a profile picture. This simple feature helps users personalize their accounts, adding a professional touch and making profiles more identifiable. Users can easily upload, crop, and adjust their image within a few clicks. Preferences

6) Added Job links:

Implemented web scraping to enhance user interaction, enabling direct access to recommended job matches. This eliminates the need for users, particularly students, to manually search for their desired positions again. The incorporation of direct job links saves significant time and streamlines the user experience. Job Link

7) Job Search with Filters

The platform offers advanced filters to streamline job searching. Users can narrow results by criteria like location, job type (e.g., internship), and more, allowing for a more targeted and efficient search experience. Job Link

8) Sankey Graph for Visualsation

The platform features a Sankey Graph that visualizes job application flows, showing the status of all applications. Users can easily track their progress across various stages like applied, rejected, and wishlisted. This visual aid offers a clear, high-level overview of the entire job search journey, highlighting areas that may need attention. Job Link

9) Resume Building using Templates

The platform includes a resume builder that offers customizable templates, allowing users to create polished resumes efficiently. This feature provides a range of professionally designed layouts tailored for different industries, making it easier for users to highlight relevant skills and experiences. Resume Builder

10) Additonal Feilds in Profile Section

To refine job recommendations and match users with suitable positions, additional fields are included in the profile section. Users can now specify skills, experience levels, and preferred job locations. These details help enhance the job-matching algorithm, aligning job recommendations more closely with individual career aspirations. Profile Section

11) Error Handling:

a) Resolved the issue where only half of the countries were initially visible for location on the website. The error has been addressed, and the website now displays the entire list of countries. As a result, the website is functioning correctly, and users can access the complete list of countries for location purposes.

b) Previously, certain pages were redirecting to undefined or error pages, a practice deemed undesirable for a high-quality application. All errors within the application have now been effectively addressed, ensuring users are seamlessly redirected to the appropriate pages.

Future Scope:

  • Include deadline reminders for the application and interview.
  • Add a feature that allows users to attach these reminders to their Google calendar.
  • Incorporate notifications for upcoming deadlines.
  • Include a link to the university’s career fair page.
  • Drag and drop functionality to change the status of the applications in MyApplications page.

Modules:

Currently, we have four fundamental steps in our project:

  1. The SearchPage where users can search about the Job Postings, along with filters like Job Type and Location
  2. The MatchesPage where users get recommendation about the jobs according to their preferences
  3. The ApplicationsPage where users can add and see the position they applied to and can update/delete the the information. Any details in any table can be modified at any time during the process
  4. The ProfilePage where user can add his skills, experience level and preffered location. This information is used to recommend user jobs that require similar skillsets.
  5. The My Applications page enables users to track all their job applications visually on a Kanban-style board with sections like "Applied," "Rejected," "Waiting for Referrals," and "Wishlist." Additionally, it displays a Sankey chart summarizing the flow of applications across different statuses and categories, providing a visual overview of all bookmarked or applied positions.

Technologies Used:

  • Python
  • Node.Js
  • Flask
  • MongoDB
  • React

Installation:

Requirements:

  • Python (recommended >= 3.8)
  • pip (Latest version 21.3 used as of 11/3)
  • npm (Latest version 6.14.4 used as of 11/3)

Strongly Recommended:

  • A terminal environment capable of handling bash scripts.

To install all required packages, while within the context of project root directory, run:

./setup.sh

This will handle all npm and pip package installations required for both the front and backend.

If the script says "command not found" or something similar, run chmod +x ./setup.sh. This grants the script execution privileges. Depending on your setup, this may occur for the boot_dockerless files, amongst others. The same command will fix the issue.

Getting Started:

Boot:

To run a testing environment, run:

./startup.sh

This will run flask and npm simultaneously, booting both the front and backend. Note - npm takes substantially longer to boot compared to flask.

Shutdown:

To ensure that flask is no longer occupying a port, run:

./shutdown.sh

This will search for any active process containing "flask" and kill the process.

Hosting the Database:

Local MongoDB:

  1. Download MongoDB Community Server
  2. Follow the Installion Guide
  3. In app.py set 'host' string to 'localhost'
  4. Run the local database:

mongodb

  • Recommended: Use a GUI such as Studio 3T to more easily interact with the database

Hosted database with MongoDB Atlas:

  1. Create account for MongoDB
  • If current MongoDB Atlas owner adds your username/password to the cluster, skip to step 4 *
  1. Follow MongoDB Atlas Setup Guide to create a database collection for hosting applications
  2. In app.py set 'host' string to your MongoDB Atlas connection string
  3. Create a .env file in the /backend directory with the specifications:
  • MONGODB_HOST_STRING: MongoDB Atlas cluster link
  • BASE_FRONTEND_URL: The url of the port is it exposed
  1. For testing through CI to function as expected, repository secrets will need to be added through the settings. Create individual secrets with the following keys/values:
  • MONGODB_HOST_STRING: MongoDB Atlas cluster non-prod link
  • BASE_FRONTEND_URL: The url of the port is it exposed

License

The project is licensed under the MIT license.

How to Contribute?

Please see our CONTRIBUTING.md for instructions on how to contribute to the repository and assist us in improving the project.

Team Members


Balaji Sankar

Bhushan Patil


Cyril Melvin Vincent

About

No description, website, or topics provided.

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 46.4%
  • Python 35.3%
  • TypeScript 6.9%
  • TeX 4.9%
  • CSS 3.5%
  • HTML 1.2%
  • Other 1.8%