Converts a simple list of color definitions to asset catalogs for Xcode and resource XML for Android
Find a file
Sven 28a901e6ae
Merge pull request #4 from 5sw/figma
Import colors from Figma library
2022-10-08 13:14:23 +02:00
.github/workflows Remove setup-xcode, should not be needed any more 2022-10-08 13:09:40 +02:00
.swiftpm/xcode Add initial code 2020-12-30 10:54:13 +01:00
Docs Update asset catalog image 2021-01-02 22:22:35 +01:00
Example Add example file 2021-01-02 22:20:55 +01:00
Sources/MakeColors Let importer determine output file name. 2022-10-08 12:50:55 +02:00
Tests/MakeColorsTests Remove library target 2022-10-08 11:46:52 +02:00
.gitattributes Ignore github workflows on export 2020-12-30 20:47:24 +01:00
.gitignore Add initial code 2020-12-30 10:54:13 +01:00
.swift-version Update .swift-version 2022-10-08 12:59:18 +02:00
.swiftformat Configure + run SwiftFormat 2020-12-30 12:53:40 +01:00
.swiftlint.yml SwiftLint 2020-12-30 13:35:21 +01:00
LICENSE Add my full name to license 2020-12-30 10:55:42 +01:00
Makefile Create Makefile 2020-12-30 23:09:21 +01:00
Package.resolved Update argument parser 2022-10-08 11:47:32 +02:00
Package.swift Quick and dirty figma importer 2022-10-08 12:41:02 +02:00
README.md Update README.md 2021-01-02 22:35:45 +01:00

MakeColors

Converts a simple list of color definitions to asset catalogs for Xcode, resource XML for Android or an HTML preview.

Installation

Install via Homebrew:

brew tap 5sw/makecolors
brew install make-colors

If you dont use Homebrew you can also install directly from source. Clone the repository or download the release and run make install inside the working copy.

Usage

USAGE: make-colors <input> [--ios] [--android] [--html] [--prefix <prefix>] [--output <output>] [--dump]

ARGUMENTS:
  <input>                 The color list to process. 
        Use - to process the standard input.

OPTIONS:
  --ios/--android/--html  The formatter to use. (default: ios)
  --prefix <prefix>       Prefix for color names. 
  --output <output>       Output file to write. 
        Use - for standard output.
        Default is the input file name with the appropriate file extension. If
        the input is - the default is standard output.
        Note that asset catalogs cannot be written to standard output.
  --dump                  List read colors on console. 
  -h, --help              Show help information.

Input format

Each line in your input contains one color definition. That is a name followed by the actual color. We support RGB colors in a few formats similar to CSS:

Base/Green #8fd151
Base/PaleGreen #d0f9a9
Base/Red rgb(249, 39, 7)
TransparentRed rgba(255, 0, 0, 128)
Base/Yellow #ff0

Grayscale colors can be produced with the white(value) and white(value, alpha) syntax. A value of zero means black while a value of 255 is pure white.

Black white(0)
MediumGray white(128)
TransparentGray white(128, 128)

HSV colors can be specified as hsv(hue, saturation, value) or hsva(hue, saturation, value, alpha) syntax. Hue is specified as degrees with the ° or deg suffix.

HSV/Yellow hsv(60°, 255, 255)

Colors can also reference other colors by prefixing them with an @ sign:

Error @Base/Red
Warning @Base/Yellow
Good @Base/Green

Output format

Xcode Asset Catalogs (--ios)

The optional prefix followed by a / is added in front of the color name. Then for each part separate by / a new folder that provides namespace is inserted in the asset catalogs. Spaces are inserted between CamelCase words. Color references are inserted as copies of the original color.

For the given example input the generated asset catalog looks like this:

Android resource XML (--android)

The optional prefix, followed by a underscore is added in front of the name. Names are converted from CamelCase to snake_case and / is replaced by underscores as well. Color references the generated color resource also references the original color.

The generated XML for the example input looks like this:

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <color name="base_green">#8FD151</color>
    <color name="base_pale_green">#D0F9A9</color>
    <color name="base_red">#F92707</color>
    <color name="base_yellow">#FFFF00</color>
    <color name="transparent_red">#FF000080</color>
    <color name="error">@color/base_red</color>
    <color name="good">@color/base_green</color>
    <color name="warning">@color/base_yellow</color>
</resources>
</xml>

HTML preview (--html)

Generates a simple HTML table with the color names, values and a sample.

The generated HTML looks like this:

Future work

  • Calculate derived colors (blend, change hue/saturation/brightness/alpha)
  • Support for dark/light mode
  • Improved error reporting in the parser