Skip to main content

Google's original 2014 Material Design color palettes as a Python library

Project description

material-color-palette

Google's original 2014 Material Design color palettes as a Python library package.

Because I wanted to use the palettes in some of my projects, but didn't want to copy-paste values, and couldn't find an existing implementation that was simple and complete.

Fully type-hinted and with a test suite.

Installation

Install from PyPI, e.g.:

pip install material-color-palette

Usage

>>> from material_color_palette import Color
>>> MY_COLOR = Color("red", 700)
>>> MY_COLOR
Color(name='red', shade=700, rgb=(211, 47, 47))

# Use RGB triplet representation in e.g. pygame/pygame-ce:
>>> MY_COLOR.rgb
(211, 47, 47)

# Use hex string representation in e.g. Matplotlib:
>>> MY_COLOR.hex
'#d32f2f'

# r, g, b properties should cover any other need:
>>> f"r={MY_COLOR.r/255}, g={MY_COLOR.g/255}, b={MY_COLOR.b/255}, a=1.0"
'r=0.8274509803921568, g=0.1843137254901961, b=0.1843137254901961, a=1.0'

# Accent colours use the original notation, so shade value is a string  
>>> Color("pink", "a100")

# You can use strings for non-accented colours too, if you want to be consistent
>>> Color("teal", "100")

# Useful, contextual error messages:
>>> Color("lime_green") 
Traceback (most recent call last):
...
ValueError: 'lime_green' isn't a valid Material color name. Allowed values: 'amber',
'black', 'blue', 'blue gray', 'blue_gray', 'brown', 'cyan', 'deep orange', 'deep purple',
'deep_orange', 'deep_purple', 'gray', 'green', 'indigo', 'light blue', 'light green',
'light_blue', 'light_green', 'lime', 'orange', 'pink', 'purple', 'red', 'teal', 'white',
'yellow'.

>>> Color("lime")
Traceback (most recent call last):
...
ValueError: Shade must be specified for Material color 'lime'.

>>> Color("yellow", 950)
Traceback (most recent call last):
...
ValueError: 950 isn't a valid shade for Material color 'yellow'. Allowed values: 50,
100, 200, 300, 400, 500, 600, 700, 800, 900, 'a100', 'a200', 'a400', 'a700'.


>>> Color("gray", "a200")
Traceback (most recent call last):
...
ValueError: 'a200' isn't a valid shade for Material color 'gray'. Allowed values: 50,
100, 200, 300, 400, 500, 600, 700, 800, 900.

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

material_color_palette-1.0.0b1.tar.gz (20.2 kB view details)

Uploaded Source

Built Distribution

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

material_color_palette-1.0.0b1-py3-none-any.whl (6.5 kB view details)

Uploaded Python 3

File details

Details for the file material_color_palette-1.0.0b1.tar.gz.

File metadata

File hashes

Hashes for material_color_palette-1.0.0b1.tar.gz
Algorithm Hash digest
SHA256 097ff59d7d11cff9d67ceff9b6b2444bc0c723536c64cf19afdd66afa331e13c
MD5 bae19c6bf305725068d31a64f23f4955
BLAKE2b-256 8947cf20227e6e5ddcdcc56079eca95999fd8376161ffef6dae114d2e31f45cc

See more details on using hashes here.

File details

Details for the file material_color_palette-1.0.0b1-py3-none-any.whl.

File metadata

File hashes

Hashes for material_color_palette-1.0.0b1-py3-none-any.whl
Algorithm Hash digest
SHA256 9c46dbb3d2a3df3f52b63d8f16798e9e10c3db061019bf712871e558282d762b
MD5 69e3b04b844aee644a8e3ca625cf36d3
BLAKE2b-256 a9f42441b2e63360facc0a028cbc633504bfa708b58a7c9ed9cabc806340579f

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