Skip to content

πŸ“š This repository contains the source code for the Snigdha OS website, built with React and Tailwind CSS. It serves as the official web presence for Snigdha OS, providing information, downloads, documentation, and updates to users, while offering a responsive and user-friendly interface.

License

Notifications You must be signed in to change notification settings

Snigdha-OS/snigdhaos-web-dev

Repository files navigation

Snigdha OS Web Dev 🌐

Welcome to the Snigdha OS Web Dev repository! This repository contains the source code, components, and resources used for building and maintaining the official website for Snigdha OS. πŸš€

Netlify Status

Table of Contents πŸ“‘

Overview 🌟

The Snigdha OS Web Dev repository powers the official Snigdha OS website. It includes various web development components, styles, and scripts necessary for the website's functionality. The website is designed to be clean, lightweight, and user-friendly, aligning with the philosophy of Snigdha OS. πŸŽ¨πŸ’»

Features πŸ”§

  • Responsive Design πŸ“±: The website is fully responsive and works across various devices and screen sizes.
  • User Registration & Authentication πŸ”’: Integrated with the Snigdha OS user system for registration and authentication.
  • Region-based Downloads 🌍: Allows users to select regional mirrors for downloading Snigdha OS.
  • Customizable UI 🎨: Built with flexibility in mind for future enhancements and easy theming.
  • SEO Optimization πŸ“ˆ: The website is optimized for search engines to ensure better discoverability.

Technologies Used πŸ› οΈ

This project utilizes a range of modern web technologies to create a seamless and performant experience:

  • React.js βš›οΈ: A JavaScript library for building user interfaces, allowing for reusable components and a fast development workflow.
  • Node.js 🌐: A runtime environment for executing JavaScript on the server-side.
  • Express.js ⚑: A minimal web framework for Node.js used for backend API routes.
  • Redux πŸ“¦: A state management library to handle the application's state in a predictable way.
  • CSS3 🎨: For styling the website with modern layout techniques (Flexbox, Grid).
  • Sass 🧢: A CSS preprocessor to manage complex stylesheets and make the development process more efficient.
  • Webpack βš™οΈ: A module bundler for JavaScript and other assets, ensuring optimal performance and organization.
  • Jest πŸ§ͺ: A testing framework used for running unit and integration tests.
  • ESLint πŸ“: A tool for identifying and fixing issues in JavaScript code to ensure consistency and adherence to coding standards.

Dependencies & Scripts Explanation πŸ“¦πŸ› οΈ

Dependencies πŸš€

These are the core libraries required for the website to run in production:

  • lucide-react πŸ’Ž: A library of open-source, customizable SVG-based icons for React. It helps add vector icons to the UI.
  • octokit πŸ¦‘: A JavaScript library for interacting with GitHub’s API, useful for fetching data from GitHub repositories.
  • react βš›οΈ: The core React library to build user interfaces. React components handle rendering and interactivity.
  • react-dom 🌐: Provides methods to render React components in the browser and manage updates.
  • react-icons πŸ”—: A set of icons packaged as React components. It simplifies adding icons to the UI.
  • react-router-dom πŸ›£οΈ: A routing library for React, enabling navigation between pages and managing URL parameters.

DevDependencies 🧰

These are tools used during development to build, lint, and optimize the project:

  • @eslint/js πŸ§‘β€πŸ’»: Core ESLint library to identify and fix JavaScript code issues.
  • @types/react and @types/react-dom πŸ’¬: TypeScript definitions for React and ReactDOM, providing type safety and better development experience.
  • @vitejs/plugin-react βš™οΈ: Vite plugin for React, enabling features like React Fast Refresh and JSX transformation.
  • autoprefixer 🌐: PostCSS plugin that automatically adds vendor prefixes to CSS to ensure cross-browser compatibility.
  • eslint πŸ“: The linter for JavaScript/TypeScript to ensure consistent code quality.
  • eslint-plugin-react-hooks πŸͺ: An ESLint plugin to enforce rules of React Hooks usage.
  • eslint-plugin-react-refresh πŸ”„: Ensures that React Fast Refresh works correctly during development.
  • globals 🌍: Provides a list of global variables in different environments, such as browser and Node.js, for linting.
  • postcss 🧩: A tool to transform CSS with plugins, such as autoprefixing, minification, and more.
  • tailwindcss 🌈: A utility-first CSS framework to rapidly build custom and responsive designs.
  • typescript πŸ”€: A superset of JavaScript that adds static typing for more maintainable and reliable code.
  • typescript-eslint πŸ”: Enables ESLint to lint TypeScript code, enforcing consistent styling and error-free code.
  • vite ⚑: A fast, next-generation build tool optimized for modern web development.
  • lint-staged πŸš€: Runs linters on staged files before committing, ensuring that only clean code is committed.
  • storybook πŸ“š: A tool to develop and test UI components in isolation, ideal for building reusable UI elements.

Scripts πŸ“

These are various commands that help automate tasks in the development process:

  • dev πŸ”₯: Starts the development server (vite), enabling hot reloading and fast builds.
  • build πŸ—οΈ: Builds the project for production with optimized assets.
  • lint ⚠️: Runs ESLint to check for any code quality issues.
  • preview πŸ‘€: Previews the production build locally.
  • start πŸš€: Alias for pnpm dev, starts the development server.
  • test πŸ§ͺ: Runs linting and builds the app as a testing workflow.
  • fix πŸ”§: Automatically fixes any linting errors.
  • format πŸ–‹οΈ: Runs Prettier to format code according to style conventions.
  • clean 🧹: Cleans the dist folder, removes node_modules, and reinstalls dependencies.
  • deploy 🌐: Builds the project and deploys it to Netlify.
  • analyze πŸ“Š: Analyzes the build output for performance improvements.
  • check-types βœ…: Checks TypeScript types without emitting code.
  • generate-icons πŸ–ΌοΈ: Generates an SVG sprite from the icons in the src/assets/icons folder.
  • precommit βœ…: Runs lint-staged to lint files before committing.
  • storybook πŸ“š: Starts Storybook to develop and test components in isolation.
  • build-storybook πŸ—οΈ: Builds the Storybook for deployment.
  • check-deps πŸ”: Audits and updates dependencies.
  • postinstall 🧰: Runs additional commands after dependencies are installed (like starting Vite).

Developers πŸ‘¨β€πŸ’»πŸ‘©β€πŸ’»

  • Eshanized - Lead Developer, Web Architect πŸ”§

If you would like to contribute or join the team, feel free to reach out! πŸ“¬

Development Guide πŸ“š

Prerequisites πŸ“₯

To get started with development, you need:

  • Node.js and pnpm installed on your local machine.
  • A modern web browser (Chrome, Firefox, etc.) for testing and debugging.
  • A code editor (VSCode, Sublime Text, etc.).
  • Familiarity with React.js, JavaScript, CSS, and Git.

Setting Up the Development Environment πŸ› οΈ

  1. Clone the repository:

    git clone https://github.com/Snigdha-OS/snigdhaos-web-dev.git
    cd snigdhaos-web-dev
  2. Install dependencies:

    pnpm install
  3. Run the development server:

    pnpm start

    This will start the development server at http://localhost:5173. Any changes made to the code will be reflected immediately. πŸ”„

Folder Structure πŸ“‚

  • src/: Contains all the source code for the frontend. πŸ–₯️
  • public/: Static files such as images, icons, and fonts. πŸ“Έ
  • components/: Reusable components like headers, footers, and forms. πŸ› οΈ
  • pages/: Individual pages of the website like home, about, and download pages. πŸ“„
  • styles/: CSS files for styling the website. 🎨

Contribution Guidelines ✍️

  • Fork the repository and clone your fork locally.
  • Create a new branch for each feature or bug fix:
    git checkout -b feature-name
  • Make your changes, commit them with clear and descriptive commit messages.
  • Push your changes to your fork and create a pull request to the main branch.

Code Style and Best Practices πŸ’‘

  • Follow a consistent style guide for JavaScript and CSS.
  • Use meaningful variable names, and avoid long functions.
  • Comment complex logic to explain the reasoning behind it.
  • Use pnpm run lint to check for code style issues before committing.

Testing πŸ§ͺ

To test changes locally, run:

pnpm run test

This will run the Jest test suite for any components or functions that have been set up for testing.

Contributing 🀝

We welcome contributions from everyone! If you'd like to contribute to Snigdha OS Web Dev, please follow these steps:

  1. Fork the repository.
  2. Clone your fork locally and create a new branch.
  3. Make your changes and test them.
  4. Create a pull request with a clear description of your changes.

If you have any ideas or suggestions, please feel free to open an issue or start a discussion. πŸ’¬

License πŸ“œ

This project is licensed under the MIT License. See the LICENSE file for more information.

Thanks for contributing to Snigdha OS Web Dev! 🌟

About

πŸ“š This repository contains the source code for the Snigdha OS website, built with React and Tailwind CSS. It serves as the official web presence for Snigdha OS, providing information, downloads, documentation, and updates to users, while offering a responsive and user-friendly interface.

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Contributors 4

  •  
  •  
  •  
  •