Thanks to visit codestin.com
Credit goes to github.com

Skip to content

Self-hosted task management that combines the simplicity of personal with the power of professional project organization. Built for individuals and teams who value privacy, control, and efficiency.

License

Notifications You must be signed in to change notification settings

chrisvel/tududi

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

tududi

Productivity made simple

Organize your life and projects with a clear, hierarchical structure,
smart recurring tasks, and seamless Telegram integration.
Get focused, stay productive, and keep your data private.

Light Mode Screenshot

More screenshots are available here.

πŸš€ How It Works

This app allows users to manage their tasks, projects, areas, notes, and tags in an organized way. Users can create tasks, projects, areas (to group projects), notes, and tags. Each task can be associated with a project, and both tasks and notes can be tagged for better organization. Projects can belong to areas and can also have multiple notes and tags. This structure helps users categorize and track their work efficiently, whether they’re managing individual tasks, larger projects, or keeping detailed notes.

🧠 Philosophy

For the thinking behind tududi, read:

✨ Features

  • Task Management: Create, update, and delete tasks. Mark tasks as completed and view them by different filters (Today, Upcoming, Someday). Order them by Name, Due Date, Date Created, or Priority.
  • Subtasks: Break down complex tasks into smaller, manageable subtasks with progress tracking and seamless navigation.
  • Recurring Tasks: Comprehensive recurring task system with intelligent parent-child relationships:
    • Multiple Recurrence Patterns: Daily, weekly, monthly, monthly on specific weekdays, and monthly last day
    • Completion-Based Recurrence: Option to repeat based on completion date rather than due date
    • Smart Parent-Child Linking: Generated task instances maintain connection to their original recurring pattern
    • Direct Parent Editing: Edit recurrence settings directly from any generated task instance
    • Flexible Scheduling: Set custom intervals (every 2 weeks, every 3 months, etc.)
    • End Date Control: Optional end dates for recurring series
  • Project Sharing & Collaboration: Share projects with team members and collaborate effectively
  • Quick Notes: Create, update, delete, or assign text notes to projects.
  • Tags: Create tags for tasks and notes to enhance organization.
  • Project Tracking: Organize tasks into projects. Each project can contain multiple tasks and/or multiple notes.
  • Area Categorization: Group projects into areas for better organization and focus.
  • Due Date Tracking: Set due dates for tasks and view them based on due date categories.
  • Responsive Design: Accessible from various devices, ensuring a consistent experience across desktops, tablets, and mobile phones.
  • Multi-Language Support: Available in 24 languages with full localization support for a truly global productivity experience.
  • Telegram Integration:
    • Create tasks directly through Telegram messages
    • Receive daily digests of your tasks
    • Quick capture of ideas and todos on the go
  • Open API & Access Tokens: Versioned Swagger docs exposed at /api/v1 plus personal API keys for integrating tududi with your own tooling or automations.

πŸ—ΊοΈ Roadmap

Check out our GitHub Project for planned features and progress.

πŸ› οΈ Getting Started

Get up and running quickly with our comprehensive documentation:

Quick Start

docker pull chrisvel/tududi:latest

docker run \
  -e [email protected] \
  -e TUDUDI_USER_PASSWORD=your-secure-password \
  -e TUDUDI_SESSION_SECRET=$(openssl rand -hex 64) \
  -v ~/tududi_db:/app/backend/db \
  -v ~/tududi_uploads:/app/backend/uploads \
  -p 3002:3002 \
  -d chrisvel/tududi:latest

Navigate to http://localhost:3002 and login with your credentials.

πŸ“š Documentation

For detailed setup instructions, configuration options, and getting started guides, visit:

docs.tududi.com

🚧 Development

Want to contribute or run Tududi from source? Check out our comprehensive development guide:

Development Setup Guide

Quick overview:

# Clone and install
git clone https://github.com/chrisvel/tududi.git
cd tududi
npm install

# Start development servers
npm run backend:dev   # Terminal 1 - Backend on :3001
npm run frontend:dev  # Terminal 2 - Frontend on :8080

For database management, testing, and detailed development instructions, see docs.tududi.com

πŸ”Œ API

Tududi provides a comprehensive REST API for integration with external tools and automation workflows.

Base URL: http://localhost:8080/api/v1

Key Features:

  • Complete CRUD operations for tasks, projects, notes, and areas
  • Personal API keys for secure access
  • Swagger documentation available at /api-docs (requires authentication)
  • Support for recurring tasks, subtasks, and tag management
  • Real-time task metrics and productivity insights

Authentication: Uses session cookies or Bearer token authentication. Generate personal API keys through the web interface for programmatic access.

Quick Example:

# Get all tasks
curl -H "Authorization: Bearer YOUR_API_KEY" \
     http://localhost:3002/api/v1/tasks

# Create a new task
curl -X POST \
     -H "Authorization: Bearer YOUR_API_KEY" \
     -H "Content-Type: application/json" \
     -d '{"name":"Complete API documentation","priority":"medium"}' \
     http://localhost:3002/api/v1/task

For full API documentation, visit /api-docs after authentication or check the Swagger schema definitions in backend/config/swagger.js.

🀝 Contributing

Contributions to tududi are welcome! Whether it's bug fixes, new features, documentation improvements, or translations, we appreciate your help.

Before you start:

Quick contribution workflow:

  1. Fork the repository
  2. Create a feature branch (git checkout -b feature/amazing-feature)
  3. Make your changes following our code standards
  4. Run linting and tests: npm run pre-push
  5. Commit your changes with a clear message
  6. Push to your fork and open a Pull Request

Read our Contributing Guide for:

  • Development setup and workflow
  • Code standards and best practices
  • Testing requirements
  • Database migrations
  • Translation guidelines
  • Pull request checklist

πŸ“œ License

This project is licensed under the MIT License.

πŸ“¬ Contact

For questions or comments, please open an issue or contact the developer directly.

Join the tududi community:

Discord
Reddit

🌟 Please check my other projects!

  • Reconya - Network reconnaissance and asset discovery tool
  • BreachHarbor - Cybersecurity suite for digital asset protection
  • Hevetra - Digital tracking for child health milestones

Screenshots

Light Mode Screenshot

Dark Mode Screenshot

Light Mobile Screenshot

Dark Mobile Screenshot


README created by Chris Veleris for tududi.

About

Self-hosted task management that combines the simplicity of personal with the power of professional project organization. Built for individuals and teams who value privacy, control, and efficiency.

Topics

Resources

License

Code of conduct

Contributing

Security policy

Stars

Watchers

Forks

Packages

No packages published