Provides various utilities for working with color contrast.
The primary purpose is to facilitate easy generation of accessible (minimum 3.0 contrast ratio) hex color pairs. A variation of these tools restricts the generated colors to TailwindCSS's default palette.
I've created a demo page to show how color pairs can be generated by this package.
You can install the package via composer:
composer require breadthe/php-contrast
Import the class.
use Breadthe\PhpContrast\HexColor; // factory
use Breadthe\PhpContrast\HexColorPair; // hex pair utilities
use Breadthe\PhpContrast\TailwindColor; // Tailwind color pair utilities
$hexColorPair = HexColorPair::make(HexColor::make('000000'), HexColor::make('ffffff'));
$hexColorPair->ratio; // 21
$hexColorPair->fg; // '#000000'
$hexColorPair->bg; // '#ffffff'
$hexColorPair = HexColorPair::random();
$hexColorPair->ratio; // 3.8
$hexColorPair->fg->hex; // '#36097e'
$hexColorPair->fg->name; // null
$hexColorPair->bg->hex; // '#ed4847'
$hexColorPair->bg->name; // null
Get a random color pair (with the resulting ratio), with minimum specified contrast ratio (but no less than 3:1)
minContrast()
, make sure to use getRandom()
instead of random()
.
$hexColorPair = HexColorPair::minContrast(4.5)->getRandom();
$hexColorPair->ratio; // 7.6
$hexColorPair->fg->hex; // '#0c402f'
$hexColorPair->fg->name; // null
$hexColorPair->bg->hex; // '#badd73'
$hexColorPair->bg->name; // null
Get a random accessible sibling for the given color, with minimum specified contrast ratio (but no less than 3:1)
// Minimum 3:1 contrast ratio
HexColorPair::sibling('000000')->hex; // '#ffffff'
// Minimum specified contrast ratio (no less than 3:1)
HexColorPair::minContrast(4.5)->getSibling('000000')->hex; // '#ffffff'
$twColor = TailwindColor::random();
$twColor->hex; // '#e2e8f0'
$twColor->name; // 'gray-300'
$twColorpair = TailwindColor::randomPair();
$twColorpair->ratio; // 3.3
$twColorpair->fg->hex; // '#63b3ed'
$twColorpair->fg->name; // 'blue-400'
$twColorpair->bg->hex; // '#4a5568'
$twColorpair->bg->name; // 'green-700'
Generate a pair of random accessible TailwindCSS colors, with minimum specified contrast ratio (but no less than 3:1)
minContrast()
, make sure to use getRandomPair()
instead of randomPair()
.
$twColorpair = TailwindColor::minContrast(4.5)->getRandomPair();
$twColorpair->ratio; // 7.0
$twColorpair->fg->hex; // '#faf5ff'
$twColorpair->fg->name; // 'purple-100'
$twColorpair->bg->hex; // '#9b2c2c'
$twColorpair->bg->name; // 'red-800'
You may extend the default Tailwind colors with your own custom palette. Here's an example of how to import a custom palette from a JSON file.
{
"background": "#FFFFFF",
"headline": "#1f1235",
"sub-headline": "#1b1425",
"button": "#ff6e6c",
"button-text": "#1f1235"
}
$customPalette = json_decode(file_get_contents('custom-palette.json'), true);
$colors = TailwindColor::merge($customPalette)->getColors();
composer test
Please see CHANGELOG for more information what has changed recently.
Please see CONTRIBUTING for details.
If you discover any security related issues, please email [email protected] instead of using the issue tracker.
The MIT License (MIT). Please see License File for more information.
This package was generated using the PHP Package Boilerplate.