Converts a simple list of color definitions to asset catalogs for Xcode and resource XML for Android
Find a file
2020-12-30 23:56:10 +01:00
.github/workflows Upload workflow to create new formula version 2020-12-30 23:56:10 +01:00
.swiftpm/xcode Add initial code 2020-12-30 10:54:13 +01:00
Sources Use own bundle ID instead of "xcode" as author 2020-12-30 16:05:18 +01:00
Tests/MakeColorsTests SwiftLint 2020-12-30 13:35:21 +01: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 Configure + run SwiftFormat 2020-12-30 12:53:40 +01: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 Add initial code 2020-12-30 10:54:13 +01:00
Package.swift Configure + run SwiftFormat 2020-12-30 12:53:40 +01:00
README.md Update README.md 2020-12-30 15:50:49 +01:00

MakeColors

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

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:

Color/Color1 #fff
Color/Color2 #abcdeff0
Color/Color3 rgb(12, 13, 53)
Color/Color4 rgba(250, 250, 250, 128)

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

ColorAlias @Color/Color1

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.

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.

HTML preview (--html)

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

Future work

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