Skip to content

Commit

Permalink
Merge pull request #301 from milansamuel609/main
Browse files Browse the repository at this point in the history
closes: #288 
Done some enhancements and also added some new sections
  • Loading branch information
dhairyagothi authored Oct 18, 2024
2 parents b27823e + e5dca35 commit 6855677
Showing 1 changed file with 216 additions and 60 deletions.
276 changes: 216 additions & 60 deletions CONTRIBUTING.md
Original file line number Diff line number Diff line change
@@ -1,99 +1,176 @@
# Contributing to Station Guide
# Contributing to Station Guide 🏅

Thank you for considering contributing to * Station Guide *! GirlScript Summer of Code (GSSoC) welcomes contributors of all skill levels, and we are excited to collaborate with you to make this project better.

Please take a moment to review this guide to help you get started.

## Table of Contents
- [Code of Conduct](#code-of-conduct)
- [How to Contribute](#how-to-contribute)
- [Reporting Issues](#reporting-issues)
- [Suggesting Enhancements](#suggesting-enhancements)
- [Submitting Pull Requests](#submitting-pull-requests)
- [Scoring System](#scoring-system)
- [Development Guidelines](#development-guidelines)
- [Getting Started](#getting-started)
- [Setup Instructions](#setup-instructions)
- [Branching Strategy](#branching-strategy)
- [Contact Us](#contact-us)

## Code of Conduct

This project adheres to the [Contributor Covenant Code of Conduct](link-to-code-of-conduct). By participating, you are expected to uphold this code. Please report any unacceptable behavior to the project maintainers.
<br>

# Code of Conduct 📃

This project adheres to the [Code of Conduct](https://github.com/dhairyagothi/StationGuide/blob/main/CODE_OF_CONDUCT.md). By participating, you are expected to uphold this code. Please report any unacceptable behavior to the project maintainers.

<br>

# Need Help with the Basics? 🤔

If you're new to Git and GitHub, no worries! Here are some useful resources:

- [Forking a Repository](https://help.github.com/en/github/getting-started-with-github/fork-a-repo)
- [Cloning a Repository](https://help.github.com/en/desktop/contributing-to-projects/creating-an-issue-or-pull-request)
- [How to Create a Pull Request](https://opensource.com/article/19/7/create-pull-request-github)
- [Getting Started with Git and GitHub](https://towardsdatascience.com/getting-started-with-git-and-github-6fcd0f2d4ac6)
- [Learn GitHub from Scratch](https://docs.github.com/en/get-started/start-your-journey/git-and-github-learning-resources)

<br>

# Project Structure 📂

```bash
STATIONGUIDE/
├── .github/ # GitHub-related configurations such as workflows, issue templates, etc.
├── backend/ # Backend code, APIs, and server-side logic.
├── frontend/ # Frontend code, UI components, and client-side logic.
├── .all-contributorsrc # Configuration file for the All Contributors specification.
├── .gitattributes # Git configuration for handling attributes like line endings.
├── .gitignore # Specifies files and directories that Git should ignore.
├── CODE_OF_CONDUCT.md # Guidelines for acceptable behavior in the project.
├── CONTRIBUTING.md # Instructions for contributing to the project.
├── docker-compose.yml # Docker Compose configuration file for setting up multi-container Docker applications.
├── Learn.md # Documentation or guides for learning aspects of the project.
├── LICENSE # License information for the project.
├── package-lock.json # Lock file generated by npm to ensure consistent dependency installation.
├── package.json # Project's metadata and dependencies for npm.
├── README.md # Overview and instructions for the project.
├── repo_structure.txt # Description or details of the project's repository structure.
├── SECURITY.md # Security policies and guidelines for reporting vulnerabilities.
├── StationGuide.md # Documentation related to the project's station guide.
├── StationGuideFigma.md # Documentation or design files related to the station guide using Figma.
├── tailwind.config.js # Configuration file for Tailwind CSS.
```

## How to Contribute
<br>

### Reporting Issues
# How to Contribute 🎯

If you find a bug, security vulnerability, or any other issue, please open an issue in the [GitHub Issue Tracker](link-to-issue-tracker) and provide the following details:
1. A clear and descriptive title.
2. Steps to reproduce the issue.
3. Any error messages or screenshots, if available.
4. Expected and actual behavior.
<br>

### Suggesting Enhancements
# Suggesting Enhancements 🔎

We welcome suggestions for improvements! Please use the same [GitHub Issue Tracker](link-to-issue-tracker) and label the issue as an "Enhancement." Provide as much context as possible, including:
We welcome suggestions for improvements! Please use the same [GitHub Issue Tracker](https://github.com/dhairyagothi/StationGuide/issues) and label the issue as an "Enhancement." Provide as much context as possible, including:
1. The current state and why it's insufficient.
2. A detailed proposal or solution, if you have one.
3. Any alternative solutions you have considered.

### Submitting Pull Requests
<br>

# Pull Request Process 🚀

When submitting a pull request, please adhere to the following:

1. **Self-review your code** before submission. 😀
2. Include a detailed description of the functionality you’ve added or modified.
3. Comment your code, especially in complex sections, to aid understanding.
4. Add relevant screenshots to assist in the review process.
5. Submit your PR using the provided template and hang tight; we'll review it as soon as possible! 🚀

To make changes, follow these steps:
1. Fork the repository and clone it to your local machine.
2. Create a new branch following the naming convention: feature/your-feature-name or bugfix/your-bugfix-name.
3. Make your changes, ensuring your code follows the project's [Development Guidelines](#development-guidelines).
4. Test your changes thoroughly.
5. Push your branch and submit a pull request (PR) to the main branch.
6. In your PR, include:
- A clear description of what changes were made and why.
- A reference to any issue it fixes or enhances.
<br>

## Scoring System
# Issue Report Process 📌

To report an issue, follow these steps:

1. Navigate to the project's issues section :- [Issues](https://github.com/dhairyagothi/StationGuide/issues)
2. Provide a clear and concise description of the issue.
3. Wait until someone looks into your report.
4. Begin working on the issue only after you have been assigned to it. 🚀

<br>

# Scoring System ⭐

As part of GSSoC, contributors will earn points based on the complexity and impact of their contributions. Here's how points are awarded:

- *Level 1 (10 points)*: Minor bug fixes, documentation improvements, or small enhancements.
- *Level 2 (25 points)*: Medium-level features or bug fixes that require more in-depth work, such as improving a module, adding new functionality, or enhancing testing.
- *Level 3 (45 points)*: Major contributions like implementing significant features, refactoring large parts of the codebase, or fixing critical bugs.
- **Level 1 (10 points)**: Minor bug fixes, documentation improvements, or small enhancements.
- **Level 2 (25 points)**: Medium-level features or bug fixes that require more in-depth work, such as improving a module, adding new functionality, or enhancing testing.
- **Level 3 (45 points)**: Major contributions like implementing significant features, refactoring large parts of the codebase, or fixing critical bugs.

All contributions will be reviewed, and the maintainers will assign points based on the effort and impact.

## Development Guidelines
<br>

# Development Guidelines 📖

- Follow the project's code style (describe the language or framework conventions).
- Write clear, maintainable, and well-documented code.
- Ensure tests cover your changes.
- Run linting and formatting tools as required.

## Getting Started
<br>

# First Pull Request ✨

### 1. Clone the Repository
1. **Star this repository**
Click on the top right corner marked as **Stars** at last.

2. **Fork this repository**
Click on the top right corner marked as **Fork** at second last.

*Understanding Cloning:*
3. **Clone the forked repository**

Cloning creates a local copy of the project on your computer, allowing you to work on it independently. This local copy is a mirror image of the original repository on GitHub or similar platforms.
```bash
git clone https://github.com/<your-github-username>/StationGuide.git
```

4. **Navigate to the project directory**

```bash
cd StationGuide
```

5. **Create a new branch**

```bash
git checkout -b <your_branch_name>
```

6. **To make changes**

```bash
git add .
```

7. **Now to commit**

Use Git to clone this repository into your local development environment:
```bash
git commit -m "add comment according to your changes or addition of features inside this"
```

bash
git clone https://github.com/dhairyagothi/StationGuide.git
8. **Push your local commits to the remote repository**

```bash
git push -u origin <your_branch_name>
```

*After Cloning*
You will see this interface in your system :
9. **Create a Pull Request**

![image](https://github.com/user-attachments/assets/20961ae0-2d63-45e7-9aa4-9adc01fcc4d0)
10. **Congratulations! 🎉 you've made your contribution**

<br>

# Running the Development Server

### 3. Running the Development Server
<br>

## Frontend:
# Frontend:

- Open a terminal or command prompt window.
- Navigate to the frontend directory:
Expand All @@ -108,7 +185,9 @@ npm run dev

This will typically launch the React application on http://localhost:3000 (or the specified port) in your browser.

## Backend:
<br>

# Backend:

- Open another terminal or command prompt window (separate from the frontend window).
- Navigate to the backend directory:
Expand All @@ -121,10 +200,87 @@ Start the backend development server (typically using nodemon server.js or a sim
npm run start
```

# Contact Us
If you have any questions or need further clarification, feel free to reach out:
<br>

# Alternatively, contribute using GitHub Desktop 🖥️

1. **Open GitHub Desktop:**
Launch GitHub Desktop and log in to your GitHub account if you haven't already.

2. **Clone the Repository:**
- If you haven't cloned the Project-Guidance repository yet, you can do so by clicking on the "File" menu and selecting "Clone Repository."
- Choose the Project-Guidance repository from the list of repositories on GitHub and clone it to your local machine.

3.**Switch to the Correct Branch:**
- Ensure you are on the branch that you want to submit a pull request for.
- If you need to switch branches, you can do so by clicking on the "Current Branch" dropdown menu and selecting the desired branch.

4. **Make Changes:**
- Make your changes to the code or files in the repository using your preferred code editor.

5. **Commit Changes:**
- In GitHub Desktop, you'll see a list of the files you've changed. Check the box next to each file you want to include in the commit.
- Enter a summary and description for your changes in the "Summary" and "Description" fields, respectively. Click the "Commit to <branch-name>" button to commit your changes to the local branch.

6. **Push Changes to GitHub:**
- After committing your changes, click the "Push origin" button in the top right corner of GitHub Desktop to push your changes to your forked repository on GitHub.

7. **Create a Pull Request:**
- Go to the GitHub website and navigate to your fork of the Project-Guidance repository.
- You should see a button to "Compare & pull request" between your fork and the original repository. Click on it.

8. **Review and Submit:**
- On the pull request page, review your changes and add any additional information, such as a title and description, that you want to include with your pull request.
- Once you're satisfied, click the "Create pull request" button to submit your pull request.

9. **Wait for Review:**
Your pull request will now be available for review by the project maintainers. They may provide feedback or ask for changes before merging your pull request into the main branch of the Project-Guidance repository.

<br>

# For Help And Support 💬

- Admin :- Dhairya Gothi
- Contact :- [Email](dhairyag31@gmail.com)

<br>

# Good Coding Practices 🧑‍💻

1. **Follow the Project's Code Style**

- Maintain consistency with the existing code style (indentation, spacing, comments).
- Use meaningful and descriptive names for variables, functions, and classes.
- Keep functions short and focused on a single task.
- Avoid hardcoding values; instead, use constants or configuration files when possible.

2. **Write Clear and Concise Comments**

- Use comments to explain why you did something, not just what you did.
- Avoid unnecessary comments that state the obvious.
- Document complex logic and functions with brief explanations to help others understand your thought -process.

3. **Keep Code DRY (Don't Repeat Yourself)**

- Avoid duplicating code. Reuse functions, methods, and components whenever possible.
- If you find yourself copying and pasting code, consider creating a new function or component.

4. **Write Tests**

- Write unit tests for your functions and components.
- Ensure your tests cover both expected outcomes and edge cases.
- Run tests locally before making a pull request to make sure your changes don’t introduce new bugs.

5. **Code Reviews and Feedback**

- Be open to receiving constructive feedback from other contributors.
- Conduct code reviews for others and provide meaningful suggestions to improve the code.
- Always refactor your code based on feedback to meet the project's standards.

<br>

Project Lead: [Dhairya Gothi] (dhairyag31@gmail.com)
# Thank you for contributing 💗

We truly appreciate your time and effort to help improve our project. Feel free to reach out if you have any questions or need guidance. Happy coding! 🚀

### This file now includes the scoring system for different levels of contributions (Level 1, Level 2, and Level 3) with corresponding points. Adjust the project-specific details such as the project name, links, and email contacts.
##

0 comments on commit 6855677

Please sign in to comment.