Skip to content

Latest commit

 

History

History
116 lines (78 loc) · 3.07 KB

README.md

File metadata and controls

116 lines (78 loc) · 3.07 KB

Sticky Notes App

A React-based Sticky Notes Application where users can create, move, and save sticky notes on the screen. The app uses localStorage to persist the notes and their positions, providing a seamless experience when refreshing the page.

Table of Contents

Features

  • Add, move, and remove sticky notes.
  • Save note content and positions using localStorage.
  • Dynamic and draggable sticky notes.
  • Responsive design (can be restricted from mobile view if needed).
  • Styled with Tailwind CSS for easy customization and shadcn components (https://ui.shadcn.com/) for faster development.

Getting Started

Prerequisites

Ensure you have the following tools installed on your machine:

  • Node.js (v14 or higher)
  • npm or yarn

Installation

  1. Clone the repository:

    git clone https://github.com/shubham03mathur/sticky-notes
  2. Navigate to the project directory:

    cd sticky-notes
  3. Install the dependencies:

    npm install

    or if you're using yarn:

    yarn install

Running the App

To start the development server, run:

npm run dev

or with yarn:

yarn dev

The app will be available at http://localhost:5173/.

Build for Production

To build the project for production, run:

npm run build

This will output the optimized production-ready build in the dist folder.

Usage

  1. Open the app in your browser.
  2. Add sticky notes by typing in the input fields.
  3. Move notes around by clicking and dragging.
  4. The positions and content of the notes are automatically saved in localStorage.
  5. If you refresh the page, the sticky notes will retain their last state.

Technologies Used

  • React: Front-end JavaScript library for building user interfaces.
  • Tailwind CSS: Utility-first CSS framework for styling.
  • Vite: Lightning-fast development environment for modern web projects.
  • localStorage: To persist notes and their positions between page reloads.
  • ESBuild: Used for efficient and fast JavaScript and JSX bundling.

Future Improvements

  • Mobile Support: The app is currently designed for desktop use only. Add full mobile responsiveness or intentionally block it from mobile devices.
  • Handling large text: Ellipsis (...) handling for overflowing text.
  • Note Resizing: Allow users to resize sticky notes.
  • Customizable Colors: Let users change the background color of each note.
  • Better Drag and Drop: Improve the smoothness of drag-and-drop functionality across various screen sizes.
  • Tags/Categories: Organize notes into categories or use tags for better management.

License

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