Skip to main content

Git repo manager get status of multiple git repos in one place

Project description

Gitter

PyPI version Python versions Build Tests Coverage License

A terminal dashboard for monitoring multiple Git repositories. Built with Python and Textual.

Gitter dashboard

Gitter shows the status, current release, and upcoming issues for all your configured repos at a glance — and lets you stage files and write commits without leaving the terminal.


Features

  • Multi-repo dashboard — see branch status, release version, and next-release issues for all projects in one view
  • Release notes — commits are parsed into tagged releases and issues, displayed as a Markdown panel
  • Git commit modal — type/issue/summary fields auto-filled from the branch name, with a staging view for reviewing changes before committing
  • Stage/unstage files — double-click files to stage or unstage; one-click stage all / unstage all
  • CLI interfacestatus and issues commands with Rich-formatted tables for use in scripts or pipelines
  • Auto-refresh — repos are polled every 90 seconds in the background

Requirements

  • Python 3.9+
  • Git installed and available on PATH

Installation

From PyPI (recommended)

python -m venv .venv
source .venv/bin/activate       # Windows: .venv\Scripts\activate
pip install gitterapp
  • Note: the PyPI package adds gitter and gitterapp to your PATH, so you can run it from either.

From Source:

git clone https://github.com/bobbyskinnerart/Gitter.git
cd Gitter
python -m venv .venv
source .venv/bin/activate       # Windows: .venv\Scripts\activate
pip install -r requirements.txt

Usage

TUI (interactive dashboard)

python main.py tui

CLI commands

python main.py status                   # Table of all projects with status and release info
python main.py issues                   # All issues grouped by project and release
python main.py issues -p <project>      # Filter by project name
python main.py issues -r <release>      # Filter by release tag
python main.py version                  # Print version

Key bindings (TUI)

Key Action
Ctrl+K Commit selected project
Ctrl+A Add project
Ctrl+E Edit selected project
Ctrl+D Delete selected project
Ctrl+R Toggle release notes panel
Ctrl+L Toggle log panel
Ctrl+Q Quit

Double-click a project row to edit it.

Configuration

Projects are stored in ~/.gitter as JSON. Add a repo via Ctrl+A in the TUI or by editing the file directly.

Each project entry supports:

Field Description
name Display name
directory Absolute path to the git repo
tagBranch Branch where release tags live (e.g. main)
issuePrefixes Issue prefixes to detect in commit messages (e.g. GIT, PROJ)
prPatterns PR number patterns (regex)
groups Optional grouping labels
favorite Mark as favorite

License

MIT — see LICENSE.md for details.

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

gitterapp-0.1.32.tar.gz (41.5 kB view details)

Uploaded Source

Built Distribution

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

gitterapp-0.1.32-py3-none-any.whl (51.6 kB view details)

Uploaded Python 3

File details

Details for the file gitterapp-0.1.32.tar.gz.

File metadata

  • Download URL: gitterapp-0.1.32.tar.gz
  • Upload date:
  • Size: 41.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for gitterapp-0.1.32.tar.gz
Algorithm Hash digest
SHA256 9dd4e34511d68d567e64d9ba7f58a47a3d3292fb9b29bb75e1b5ad2eab085b5f
MD5 32ef5ed238219683e849ac2d9403b291
BLAKE2b-256 941d762e79da6cf9280ef0dbf1baff6827f462c4980f50e1f1dbd5bcf943fdd6

See more details on using hashes here.

Provenance

The following attestation bundles were made for gitterapp-0.1.32.tar.gz:

Publisher: publish.yml on bobbyski/Gitter

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

File details

Details for the file gitterapp-0.1.32-py3-none-any.whl.

File metadata

  • Download URL: gitterapp-0.1.32-py3-none-any.whl
  • Upload date:
  • Size: 51.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for gitterapp-0.1.32-py3-none-any.whl
Algorithm Hash digest
SHA256 0cc5badf51bd289b3ccdfe342ca668e30256c243a44015ac72641d8866750a51
MD5 a5f825608ac67d990952366b3f1b5306
BLAKE2b-256 e4b5cf9511d8376d73bad7b135c45754be2915721dca6a69c469999e927c1bfa

See more details on using hashes here.

Provenance

The following attestation bundles were made for gitterapp-0.1.32-py3-none-any.whl:

Publisher: publish.yml on bobbyski/Gitter

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