Skip to main content

Library support for awesome command line interfaces

Project description

Prettypretty

Run Tests Publish to GitHub Pages

Prettypretty helps build awesome terminal user interfaces in Python. Notably, it incorporates a powerful and general color library. The resulting, near seemless integration of 1970s archaic but beloved ANSI escape codes for terminal styling with 2020s color science, notably via the Oklab perceptual color space, is unique to prettypretty and enables your application to easily adapt its visual styles to a user's current color theme, dark or light mode, and color preferences. So, what are you waiting for? Switch to prettypretty for all your terminal styling needs. Prettypretty is awesome!

[ Repository | Package | Documentation ]

Prettypretty Illustrated

The first screenshot illustrates prettypretty's support for maximizing text contrast by comparing against backgrounds in all 216 colors from the 6x6x6 RGB cube of 8-bit terminal colors.

Background color grid

The second screenshot illustrates the reverse challenge, with prettypretty picking the background color to maximize contrast for text in all 216 colors from the 6x6x6 RGB cube. If you compare with the previous screenshot, you may notice that prettypretty's contrast metric, APCA, is not symmetric. That just why it is more accurate than, say, the WCAG 2.0 formula.

Text color grid

The third screenshot illustrates prettypretty's support for finding the perceptually closest color out of several colors. That's just how prettypretty performs high-quality downsampling, in this case turning the 216 colors from the 6x6x6 RGB cube into 16 extended ANSI colors.

Downsampled colors, macOS Terminal

Since almost all terminals have robust support for theming just those 16 extended ANSI colors, prettypretty doesn't just use some hardcoded set of colors but has built-in support for color themes. You can of course configure and reconfigure the current colors as you please. But prettypretty can do one better: It can automatically query a terminal for the current theme colors. The fourth screenshot illustrates the impact. When running in iTerm2 instead of macOS Terminal, prettypretty makes good use of the brighter colors in one of iTerm's builtin themes and generates a substantially different grid!

Downsampled colors, iTerm2

To recap, prettypretty has robust support for:

  • Maximizing the label contrast for a given background color;
  • Maximizing the background contrast for a given text color;
  • Finding the closest color out of several;
  • Using that search to perform high-quality downsampling;
  • Theming the sixteen extended ANSI colors;
  • Automatically determining the current terminal theme.

More is yet to come...


Copyright 2024 Robert Grimm. The code in this repository has been released as open source under the 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

prettypretty-0.8.0.tar.gz (2.3 MB view hashes)

Uploaded Source

Built Distribution

prettypretty-0.8.0-py3-none-any.whl (59.1 kB view hashes)

Uploaded Python 3

Supported by

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