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

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.30.tar.gz (40.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.30-py3-none-any.whl (49.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: gitterapp-0.1.30.tar.gz
  • Upload date:
  • Size: 40.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.30.tar.gz
Algorithm Hash digest
SHA256 0e4f191fd1a5c665be13992959b5350b0d234bd0643ee825d530eaaaa26e2299
MD5 456210827be9b7d8c0076928f0025f4e
BLAKE2b-256 09d7f4177036870790c28ce4a29d82a58b838a615b4c70907dc1845701ebd4c9

See more details on using hashes here.

Provenance

The following attestation bundles were made for gitterapp-0.1.30.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.30-py3-none-any.whl.

File metadata

  • Download URL: gitterapp-0.1.30-py3-none-any.whl
  • Upload date:
  • Size: 49.4 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.30-py3-none-any.whl
Algorithm Hash digest
SHA256 9eb766f9a72fbf30b8001b29544182e21471f07d710c506fb28881021a0a8564
MD5 7f91c5363a30b6a313676799df8adbc5
BLAKE2b-256 8f1c60571d9dc81f85956d147e6532b6b4542aa66f8f8e79e3738f4c9d4c08be

See more details on using hashes here.

Provenance

The following attestation bundles were made for gitterapp-0.1.30-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