Extract colors from images.
This addon provides a new Modifier which takes an image asset and returns its dominant (or average) color as a HEX value.

Installation
Install the addon via composer:
composer require aryehraber/statamic-color-extractor
Publish the config file:
php artisan vendor:publish --tag=color_extractor-config
Usage
Simply add the color modifier to an image asset to output the HEX color value:
{{ image | color }}
Example
---image: my-colorful-image.jpg--- <div style="border-color: {{ image | color }};"> <img src="{{ image }}" /></div> // OR {{ image }}<div style="border-color: {{ url | color }};"> <img src="{{ glide:id }}" /></div>{{ /image }}
By default, the underlying color extractor tries to find the most dominant color in the image, however, results can vary (see example screenshot below). Therefore, an average param can be passed in to instead find the average color found in the image:
{{ image | color:average }}
The default type can be changed to average instead via the config file, which opens up a dominant param:
{{ image | color:dominant }}
The contrast parameter will try to find a color from the image palette with the most contrast to the dominant color:
{{ image | color:contrast }}
Dominant vs. Average vs. Contrast
Example screenshot to demonstrate the difference between the color extraction strategies:

Manually Editing Colors
Whenever a color is extracted from an image, it's added to the asset's meta data. This means you can manually override it by adding the following fields to your assets.yaml blueprint:
title: Assetfields: # existing fields - handle: color_dominant field: display: Dominant Color type: color - handle: color_average field: display: Average Color type: color - handle: color_contrast field: display: Contrast Color type: color
Extract Command
By default, colors are extracted on-demand when the modifier is first used on an image. This can slow down page loads with many images.
To improve performance, pre-generate color data using the commands below.
Note: The command will skip assets that already have color data unless --force is used.
# Extract default color type for all assetsphp please color-extractor:extract # Extract all color types (dominant, average, contrast)php please color-extractor:extract --all # Filter by containerphp please color-extractor:extract --container=assets # Filter by container and folderphp please color-extractor:extract --container=assets --folder=products # Force re-extraction even if colors already existphp please color-extractor:extract --force
Auto Extract on Asset Upload
When auto_extract is enabled in the config file (see Installation), colors will automatically be extracted when new images are uploaded. This extracts all 3 color types (dominant, average, contrast) and is useful to ensure there's no slow down on first page load.
Credits
Inspiration: https://github.com/sylvainjule/kirby-colorextractor
Color Extractor: https://github.com/thephpleague/color-extractor