The tool can be executed with this command:
bunx svg-color-linter --config color-config.yml file1.svg file2.svg
It will fetch all the colors of a YAML file which must have the following structure:
colors:
  - "#FFEBEE"
  - "#FFCDD2"
  - "#EF9A9A"
  - "#E57373"
  - "#EF5350"
  - "#F44336"It also supports glob file patterns to check multiple files matching the pattern like this:
bunx svg-color-linter --config color-config.yml ./images/**/*.svg ./another-dir/*.svg test.svg
You can exclude specific files or patterns from the analysis by adding an exclude key in the color-config.yml file. The exclude key should contain a list of file patterns to be ignored. For example:
colors:
  - "#FFEBEE"
  - "#FFCDD2"
  - "#EF9A9A"
  - "#E57373"
  - "#EF5350"
  - "#F44336"
exclude:
  - "icons/icon1.svg"
  - "icons/icon2.svg"
  - ...The tool can be imported as module into existing JavaScript or TypeScript code. Therefor it is necessary to install it via package manager:
npm install svg-color-linter
The module can be imported like this:
import { isColorInPalette, getSuggestions } from 'svg-color-linter';
isColorInPalette('#FFFFFF', ['#EEEEEE', '#121212']);
// false
getSuggestions('#C0CA35', ['#EEEEEE', '#121212']);
// [
//   { hex: '#C0CA33', distance: 0.160467661071053 },
//   { hex: '#CDDC39', distance: 4.307076277707079 },
//   { hex: '#D4E157', distance: 5.606714639567858 },
//   { hex: '#AFB42B', distance: 5.713845679863578 },
//   { hex: '#DCE775', distance: 8.065940911169271 }
// ]