Skip to content

Latest commit

 

History

History
175 lines (110 loc) · 6.48 KB

DEVELOPER.md

File metadata and controls

175 lines (110 loc) · 6.48 KB

Resume Genie Developer Guide

Welcome to the Resume Genie Developers Guide! This guide provides essential information for developers who want to contribute to the project or work on the codebase. It covers the project's architecture, setup instructions, coding conventions, and more.


📑 Table of Contents


📦 Project Overview

Resume Genie is a free and open-source resume builder software that aims to make the process of creating, updating, and sharing resumes easy and efficient. It leverages technologies like React, Node.js, Tesseract.js, MongoDB, and Tailwind CSS to provide a user-friendly and feature-rich experience for users.


🔨 Architecture

Resume Genie follows a client-server architecture. The frontend is built using React and Tailwind CSS, providing a responsive and interactive user interface. The backend is developed with Node.js and Express.js, which handles API requests and interacts with the MongoDB database. Tesseract.js is integrated to extract information from resume images.

For more detailed Architecture to the project, refer to the Architecture Guide document.


💁‍♂️ Prerequisites

Before setting up the project, ensure you have the following prerequisites installed on your system:

  • Node.js (version >= 14.x)
  • Npm or Yarn package manager
  • MongoDB (running locally or a remote instance)

🏃‍♀️ Running Project in Local

To set up the Resume Genie project locally, follow these steps:

  • Fork the repo

    • For more information How to fork a repo refer: Fork Guide
  • Clone the forked repo

    • For more information How to clone a repo refer: Clone Guide

      $ git clone https://github.com/Gautam25Raj/resume-genie.git
      
  • Navigate into the project's directory & Install the dependencies.

    • Front-End

      $ cd client
      $ npm install
      
    • Back-End

      $ cd backend
      $ npm install
      
  • Setup Environment Variable:

    • Create a .env file in both folder front-end and back-end of the project and set the necessary environment variables. Refer to the Environment Variable for the required environment variables.
  • Start the development server & Run the following command to run the project in your local computer.

    • Front-End

      $ cd client
      $ npm start
      
    • Back-End

      $ cd backend
      $ npm start
      

    This command will start the development server, and you should see output indicating that the server is running.

  • Open your web browser and navigate to localhost:3000 to run Front-End and Back-End on localhost:8000.

You have now successfully set up and run the Resume Genie project on your local machine.


Note: The above instructions assume that the project uses npm as the package manager. If you're using yarn, replace npm with yarn in the commands.


⚒ Development Workflow

  • Create a new branch and check out a new branch from the main branch, if you want to and name it to what you intend to do:

    $ git branch "BRANCH_NAME"
    $ git checkout "BRANCH_NAME"
    
  • Make your changes and write clean, well-documented code.

  • Commit your changes

    • Please provide a git message that explains what you've done
    • Commit to the forked repository
      $ git commit -m "Add new feature: My Feature"
      
  • Push to the branch

    $ git push origin "BRANCH_NAME"
    
  • Make a pull request

    • Please do apply labels to pull request.
  • Collaborate with maintainers and reviewers to address feedback and make necessary improvements.

Once done, the changes will be merged to main branch.


👨‍💻 Coding Conventions, Style and Guidelines

To maintain consistency and readability across the codebase, we follow the following coding style and guidelines for Resume Genie:

  • Use meaningful and descriptive variable, function, and class names that are descriptive and self-explanatory.
  • Write code that is easy to understand and maintain.
  • Modularize the code and follow separation of concerns.
  • Keep lines of code reasonably short (preferably less than 80 characters) to enhance readability.
  • Comment your code when necessary to provide clarity and context.
  • Maintain good code structure and organization.
  • Use Prettier for better and easy Formatting

For more detailed coding conventions specific to the project, refer to the Coding Conventions document.


🔒 Deployment

Resume Genie can be deployed to various environments. Ensure you have the necessary configuration files and deployment scripts in place. The deployment process may vary based on your chosen hosting platform or infrastructure.


😇 Contributing

Contributions to Resume Genie are welcome! If you would like to contribute to the project, please read the CONTRIBUTING GUIDE file for guidelines on how to contribute, submit bug reports, and request new features.



These guidelines are meant to ensure consistent and maintainable code throughout the project. When contributing to Resume Genie, please follow these coding style and guidelines to help maintain a clean and cohesive codebase.

Thank you for choosing to contribute to Resume Genie! We appreciate your time and effort in improving the project. If you have any questions or need assistance, feel free to reach out to us at [email protected].

Happy coding! Happy contributing! 💖