Skip to main content

Provide an overview of your assigned issues on GitHub, GitLab, Gitea and Microsoft Planner

Project description

ToDo Merger

Get a unified overview of all issues and tasks assigned to you across multiple platforms — in one local web dashboard.

Python 3.10+ License: GPL-3.0-only PyPI

Features

  • Multi-platform aggregation — pulls assigned issues, merge/pull requests, and tasks from GitHub, one or more GitLab instances, Gitea instances, and local Microsoft Planner exports, all into a single view
  • Graceful degradation — if an instance is unreachable (e.g. a company GitLab behind a VPN), the app keeps running and shows cached data for that instance with a warning banner; other services are unaffected. Connectivity is retried automatically on the next cache refresh
  • Personal prioritisation — pin, promote, or deprioritise any issue without touching the upstream tracker; rankings are stored locally
  • Todo list — mark individual issues as personal todos and filter the view to show only those
  • New issue highlighting — issues you haven't seen before are highlighted until you dismiss them
  • Private task creation — create new issues directly in a configured private repository (GitHub, GitLab, or Gitea) from within the dashboard
  • Configurable display — toggle which metadata columns are shown (labels, milestones, epics, assignees, due dates, refs, …)
  • Daemon mode — run as a background process with --daemon / stop
  • Fast cache — configurable cache timeout (default 10 minutes) avoids hammering the APIs on every page load; manual refresh available at any time

Installation

pipx (recommended)

pipx installs the app in an isolated environment and keeps it off your system Python.

pip3 install pipx          # install pipx if not already present
pipx install todo-merger   # install todo-merger

todo-merger will be available in ~/.local/bin (add to $PATH if needed).

To run without installing permanently:

pipx run todo-merger

To upgrade:

pipx upgrade todo-merger

Other methods

pip install todo-merger   # plain pip
uv tool install todo-merger  # uv

Usage

Please see todo-merger --help for the latest usage instructions. In general, the app is started with:

todo-merger [options] [command]

Open http://localhost:8636 in your browser after starting.

Important options:

Flag Description Default
-c, --config-file Path to the config file ~/.config/todo-merger/config.toml
-d, --daemon Run in the background, logging to a file
-v INFO logging
-vv DEBUG logging

Important Commands:

Command Description
stop Stop a running background instance

Configuration

On first start, todo-merger creates an empty config file at ~/.config/todo-merger/config.toml. Edit it to add your service credentials.

See DEFAULT_APP_CONFIG in _config.py for all available options and their defaults.

Multiple instances of the same platform are supported — just add more [services.*] sections with unique names.

Unavailable instances

If a service is currently unavailable (e.g. because company VPN is disconnected), todo-merger handles it gracefully:

  • App starts without connection — the unreachable instance is skipped and recorded as degraded; a warning banner is shown in the dashboard. Cached data from the last successful fetch is displayed.
  • Connection reestablished later — the next cache refresh (or manual reload) automatically retries the login and fetch for the degraded instance. If it succeeds, the warning disappears.
  • Connection drops mid-session — the failing instance falls back to its last cached data; all other services continue normally.

No configuration is needed for this behaviour — it is automatic.

License

The main license of this project is the GNU General Public License 3.0, no later version (GPL-3.0-only), Copyright Max Mehl.

Third-party components included under their respective licenses: Pico CSS (MIT), snippets from DB Systel (Apache-2.0).

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

todo_merger-1.4.1.tar.gz (748.4 kB view details)

Uploaded Source

Built Distribution

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

todo_merger-1.4.1-py3-none-any.whl (756.8 kB view details)

Uploaded Python 3

File details

Details for the file todo_merger-1.4.1.tar.gz.

File metadata

  • Download URL: todo_merger-1.4.1.tar.gz
  • Upload date:
  • Size: 748.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for todo_merger-1.4.1.tar.gz
Algorithm Hash digest
SHA256 7d3167b5eee1063ae6095f2db3db86dedf56282f7e77ecfee7be04ea1b08241c
MD5 5b4ec773c0042614f4d7c301ac3a8119
BLAKE2b-256 33c9227c18b22c2e009ea22f5eb6d58bfd1ccee05ef8995c2d54eaf0d0a75d06

See more details on using hashes here.

Provenance

The following attestation bundles were made for todo_merger-1.4.1.tar.gz:

Publisher: release.yaml on mxmehl/todo-merger

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file todo_merger-1.4.1-py3-none-any.whl.

File metadata

  • Download URL: todo_merger-1.4.1-py3-none-any.whl
  • Upload date:
  • Size: 756.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for todo_merger-1.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 5bd01ad594b2476a1a59087f5f4bcbfbb83280d6ff4808e8fd19e3065f247918
MD5 79bae9941d27533a9a90ec2e1baf8233
BLAKE2b-256 46b5ef81a65ed237d3cdce2a37143cbfe0cc28d306eff6e27f1c9bd3aa0cf51a

See more details on using hashes here.

Provenance

The following attestation bundles were made for todo_merger-1.4.1-py3-none-any.whl:

Publisher: release.yaml on mxmehl/todo-merger

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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