Skip to main content

A beautiful CLI and Web todo manager with multi-backend support (SQLite, Notion, Microsoft To Do)

Project description

Vibe Todo

一个简洁实用的 Todo 任务和工时管理工具,提供 Web 界面和命令行两种使用方式,支持多后端存储

✨ 特性

  • 📝 任务管理:创建、编辑、完成、删除任务
  • ⏱️ 工时追踪:记录任务工作时长
  • 🎨 优先级管理:低/中/高/紧急四个级别
  • 📅 截止日期:智能提醒逾期任务
  • 🏷️ 标签系统:灵活的任务分类
  • 📁 项目管理:按项目组织任务
  • 🌐 Web 界面:使用 HTMX + Jinja2 + PicoCSS 构建的现代化界面
  • 💻 精美 CLI:使用 Rich 库打造的专业终端UI
  • 🔌 多后端支持
    • 🗄️ SQLite - 本地存储
    • 📓 Notion - 同步到 Notion 数据库
    • Microsoft To Do - 同步到 Microsoft To Do

🚀 快速开始

安装

# 创建虚拟环境
python3 -m venv .venv
source .venv/bin/activate  # Windows: .venv\Scripts\activate

# 基础安装
uv pip install -e ".[dev]"

# 安装 Notion 支持
uv pip install -e ".[notion]"

# 安装 Microsoft To Do 支持
uv pip install -e ".[microsoft]"

# 安装所有后端支持
uv pip install -e ".[all]"

使用 Web 界面

vibe web
# 访问 http://localhost:8000

使用 CLI

基础操作

# 添加任务(支持完整参数)
vibe add "完成项目文档" -d "编写 README" -p high --due 2025-12-20 -t "文档,重要" --project "Vibe Todo"

# 列出所有任务(精美表格显示)
vibe list

# 按状态筛选
vibe list -s todo
vibe list -s in_progress

# 按项目筛选
vibe list -p "Vibe Todo"

# 显示逾期任务
vibe list --overdue

# 查看任务详情
vibe show 1

# 开始任务
vibe start 1

# 添加工时
vibe time 1 30  # 添加30分钟

# 完成任务
vibe done 1

# 删除任务
vibe delete 1

# 查看统计
vibe stats

后端配置

# 查看当前配置
vibe config show

# 使用 SQLite(默认)
vibe config set-backend sqlite --db-path vibe_todo.db

# 切换到 Notion
vibe config set-backend notion \
  --token secret_xxx \
  --database xxx

# 切换到 Microsoft To Do
vibe config set-backend microsoft \
  --client-id xxx

📖 多后端配置指南

Notion 配置

  1. 创建 Integration

  2. 创建 Database

    • 在 Notion 中创建一个数据库
    • 添加以下属性:
      • Name (title)
      • Description (text)
      • Status (select: To Do, In Progress, Done)
      • Priority (select: Low, Medium, High, Urgent)
      • Due Date (date)
      • Tags (multi-select)
      • Project (select)
      • Time Spent (number)
  3. 连接 Database

    • 在数据库页面,点击右上角 "..." → "Add connections"
    • 选择你创建的 Integration
    • 复制数据库 ID(URL 中的一段字符)
  4. 配置 Vibe Todo

    vibe config set-backend notion \
      --token secret_xxx \
      --database database_id
    

Microsoft To Do 配置

  1. 注册 Azure AD 应用

    • 访问 https://portal.azure.com
    • Azure Active Directory → App registrations → New registration
    • 设置 Redirect URI: http://localhost
    • 添加 API 权限:Tasks.ReadWrite
    • 复制 Application (client) ID
  2. 配置 Vibe Todo

    vibe config set-backend microsoft --client-id xxx
    
  3. 首次认证

    • 运行任意命令时会弹出浏览器进行 OAuth2 认证
    • 授权后 token 会缓存到本地

开发

运行测试

pytest

代码检查

ruff check .

技术栈

  • 后端: FastAPI + SQLAlchemy
  • 前端: HTMX + Jinja2 + PicoCSS
  • CLI: Click
  • 数据库: SQLite
  • 测试: pytest

架构

项目采用简洁的分层架构:

  • core/: 核心领域模型和业务逻辑
  • storage/: 数据持久化层
  • web/: Web 接口(FastAPI + HTMX)
  • cli/: 命令行接口(Click)

📊 项目状态

当前版本: v0.1.0
开发状态: ✅ 稳定 (Stable)
测试覆盖: 核心功能已测试

已实现功能

  • ✅ 完整的任务管理(CRUD)
  • ✅ 优先级和截止日期
  • ✅ 标签和项目组织
  • ✅ 工时追踪
  • ✅ Rich CLI 终端界面
  • ✅ Web 界面 (HTMX + PicoCSS)
  • ✅ 多后端支持 (SQLite / Notion / Microsoft To Do)
  • ✅ 后端切换和配置管理

路线图

查看完整的技术架构和未来规划:ARCHITECTURE.md

近期计划 (v0.2.0)

  • 🔄 数据导出/导入 (JSON/CSV)
  • 🔄 批量操作
  • 🔄 全文搜索和高级过滤

中期规划 (v0.3.0 - v0.4.0)

  • 💡 交互式任务编辑
  • 💡 看板和日历视图
  • 💡 深色模式
  • 🔮 Google Tasks / Todoist 集成

长期愿景 (v0.5.0+)

  • 🌟 AI 辅助(自动分类、优先级建议)
  • 🌟 协作功能(多用户、评论)
  • 🌟 实时同步和离线模式

🤝 贡献

欢迎贡献代码、报告问题或提出建议!

如何贡献

  1. Fork 本仓库
  2. 创建特性分支 (git checkout -b feature/amazing-feature)
  3. 提交改动 (git commit -m 'Add amazing feature')
  4. 推送到分支 (git push origin feature/amazing-feature)
  5. 开启 Pull Request

开发指南

# 克隆仓库
git clone https://github.com/yourusername/vibe-todo.git
cd vibe-todo

# 创建虚拟环境
python3 -m venv .venv
source .venv/bin/activate

# 安装开发依赖
uv pip install -e ".[dev,all]"

# 运行测试
pytest

# 代码检查
ruff check .

行为准则

请遵循友好、尊重、包容的开源社区准则。

📄 License

MIT License - 详见 LICENSE 文件

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

vibe_todo-0.1.2.tar.gz (37.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

vibe_todo-0.1.2-py3-none-any.whl (30.8 kB view details)

Uploaded Python 3

File details

Details for the file vibe_todo-0.1.2.tar.gz.

File metadata

  • Download URL: vibe_todo-0.1.2.tar.gz
  • Upload date:
  • Size: 37.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.18

File hashes

Hashes for vibe_todo-0.1.2.tar.gz
Algorithm Hash digest
SHA256 66e3b51219927ca5af8417d84c879e93341c42af63f09ccf99e722002ef5c9cb
MD5 f14fe8e45465632b533b4a0550a06fc5
BLAKE2b-256 a2ab44ced86824f9b79a9575d4771b32c19e0510e85c1f709376a84f12f2fc33

See more details on using hashes here.

File details

Details for the file vibe_todo-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: vibe_todo-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 30.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.18

File hashes

Hashes for vibe_todo-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 f6581aece52dd5cad298eded291dcb85fb5b645c20779a7c37398acab6b434b1
MD5 99b2109fe054ec2a0e5acc0b78f5e6b5
BLAKE2b-256 9b8480c69e31ad0cfe838bdd60f7b8682ca674fc2832ece41fee233ae597d1ca

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page