Skip to content

ilramdhan/taskmaster.ilramdhan.dev

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

9 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

TaskMaster Logo

TaskMaster

A Modern Task Management Application

Comprehensive, client-side task management dashboard with analytics, calendar view, and dark mode

React TypeScript Vite TailwindCSS


πŸ“– Overview

TaskMaster is a feature-rich, client-side task management application built with React and TypeScript. It provides a comprehensive solution for managing tasks with features like subtasks, calendar integration, analytics dashboard, and moreβ€”all running entirely in the browser with localStorage persistence.

✨ Key Features

Feature Description
πŸ“Š Dashboard Analytics Visual charts showing task distribution by priority and 30-day activity trends
βœ… Task Management Full CRUD operations with subtasks, priorities, categories, and deadlines
πŸ“… Calendar View Interactive calendar with drag-and-drop task scheduling
πŸ—„οΈ Archive & Recycle Bin Soft delete with recovery options
πŸ“₯ Import/Export JSON and CSV support for data backup and migration
πŸŒ™ Dark Mode Toggle between light and dark themes
πŸ’Ύ Persistent Storage All data saved automatically to localStorage
πŸ“± Responsive Design Works seamlessly on desktop and mobile

πŸ—οΈ Architecture

Tech Stack

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚                        Frontend                              β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚  React 18.3 + TypeScript 5.2                                β”‚
β”‚  β”œβ”€β”€ UI Components (Custom)                                 β”‚
β”‚  β”œβ”€β”€ State Management (React Hooks + useMemo)               β”‚
β”‚  └── Styling (TailwindCSS CDN)                              β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚  Libraries:                                                  β”‚
β”‚  β”œβ”€β”€ Recharts (Charts & Analytics)                          β”‚
β”‚  └── Lucide React (Icons)                                   β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚  Build Tool: Vite 7.3                                       β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚  Storage: Browser LocalStorage                               β”‚
β”‚  β”œβ”€β”€ utm_user (User session)                                β”‚
β”‚  β”œβ”€β”€ utm_tasks (Task data)                                  β”‚
β”‚  β”œβ”€β”€ utm_activities (Activity log)                          β”‚
β”‚  └── utm_theme (Theme preference)                           β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Project Structure

TaskMaster/
β”œβ”€β”€ App.tsx              # Main application component (~2000 lines)
β”‚   β”œβ”€β”€ Types & Interfaces
β”‚   β”œβ”€β”€ Constants & Helpers
β”‚   β”œβ”€β”€ Modal Component
β”‚   β”œβ”€β”€ Toast Component
β”‚   β”œβ”€β”€ TaskCard Component
β”‚   └── Main App Logic
β”œβ”€β”€ index.tsx            # React entry point
β”œβ”€β”€ index.html           # HTML template with TailwindCSS config
β”œβ”€β”€ vite.config.ts       # Vite configuration
β”œβ”€β”€ package.json         # Dependencies
β”œβ”€β”€ tsconfig.json        # TypeScript config
└── metadata.json        # App metadata

πŸš€ Getting Started

Prerequisites

  • Node.js (v18 or higher recommended)
  • npm or yarn

Installation

# Clone the repository
git clone <repository-url>
cd TaskMaster

# Install dependencies
npm install

# Start development server
npm run dev

The application will be available at http://localhost:3000

Build for Production

npm run build
npm run preview

πŸ“‹ Usage Guide

Authentication

Use the following credentials to login:

  • Username: admin
  • Password: 123

Navigation

Menu Description
Dashboard Overview with statistics and charts
My Tasks Full task list with filters and views (Grid/List/Kanban)
Calendar Monthly calendar with task visualization
Archived View archived tasks
Recycle Bin Recover or permanently delete tasks

Task Properties

Property Options
Priority High, Medium, Low
Category Work, Personal, Shopping, Health, Other
Status Pending, Completed
Dates Start Date, Deadline
Subtasks Unlimited checklist items
Image Optional URL attachment

Data Management

  • Export JSON - Backup all tasks as JSON file
  • Export CSV - Export tasks for Excel/Sheets
  • Import JSON - Restore from backup
  • Import CSV - Import from spreadsheet
  • Reset to Default - Restore sample data

πŸ› οΈ Development

Available Scripts

Command Description
npm run dev Start development server
npm run build Build for production
npm run preview Preview production build

Key Components

Component Purpose
Modal Reusable modal dialog
ToastContainer Notification system
TaskCard Task display (supports Grid/List/Board views)

State Management

The application uses React hooks for state management:

  • useState for local state
  • useMemo for computed values (stats, filtered tasks, charts)
  • useEffect for side effects (localStorage sync)

πŸ“„ License

This project is open source and available under the MIT License.


Built with ❀️ using React + TypeScript + Vite

About

A comprehensive task management dashboard with calendar view, analytics, and everything you need to stay organized and productive.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors