Skip to content

Latest commit

 

History

History
137 lines (96 loc) · 5.09 KB

CHANGELOG.md

File metadata and controls

137 lines (96 loc) · 5.09 KB

Change Log

All notable changes to this project will be documented in this file.

The format is based on Keep a Changelog and this project adheres to Semantic Versioning.

  • Correctly handle number types

⚠️ Breaking changes

  • Due to how imports are resolved, my-aliases will now point to ./node_modules/my-aliases instead of ./my-aliases. Local imports should include the relative path (./, ../)

Theo v6 is a complete re-write that allowed us to fix some long standing issues and separate the core engine from the Gulp plugin.

  • Handlebars support for registerFormat() (@kaelig)
  • Formats can now receive additional options
  • Added new formats
  • CLI support (@nickbalestra @tomger)
  • Array support for "props" (as long as each prop has a "name" key) which will preserve prop order in the final output
  • Bug fixes and documentation for several existing formats (@corygibbons @dennisreimann @micahwood @didoo)

Big thanks to @kaelig for helping kickstart this release and to all the alpha/beta testers who reported issues and fixed bugs!

⚠️ Breaking changes

  • Aliases are only available to files that directly import them – see #101
  • The Gulp plugin is in a separate gulp-theo package
  • Renamed the .meta key to meta
  • Removed the includeRawValue option in favor of always adding an originalValue key in each transformed prop

Migration guide

If you would like to keep using Theo as a Gulp plugin with Theo v6, here is what a typical update would look like:

<= 5.0.0

npm install theo --save-dev
const gulp = require("gulp");
const theo = require("theo");

// Transform design/props.yml to dist/props.scss
gulp
  .src("design/props.yml")
  .pipe(theo.plugins.transform("web"))
  .pipe(theo.plugins.format("scss"))
  .pipe(gulp.dest("dist"));

>= 6.0.0

The Gulp plugin is in a separate gulp-theo package:

npm install gulp-theo --save-dev
const gulp = require("gulp");
const theo = require("gulp-theo");

// Transform design/props.yml to dist/props.scss
gulp
  .src("design/props.yml")
  .pipe(
    theo.plugin({
      transform: { type: "web" },
      format: { type: "scss" }
    })
  )
  .pipe(gulp.dest("dist"));

Theo v5.0.0 comes with a ton of improvements and drops support for Node.js < 6.

A massive thanks to the contributors who made this release possible, especially to @micahgodbolt.

View all pull requests merged in v5.0.0

  • Support for *.yaml files (#60)
  • Support for JSON5 syntax (an improvement on JSON)
  • Improved styleguide theme (#56)
  • Aliases can reference other aliases (#69)
  • Users may now pre-process the input with custom functions (#71)
  • Improved test results and moved test suite to Jest
  • JavaScript is now linted using our internal standards
  • Removed React from devDependencies
  • Added an EditorConfig file
  • Inline comments in the output of popular formats (e.g. scss) (fixes #58)
  • Breaking change: removed the color/hex8 transform. Instead, use color/hex8argb in Android, and color/hex8rgba in, for example, CSS level 4 values
  • Breaking change: Node.js 6 and up is required
  • Various tweaks and fixes

⚠️ Breaking changes

Dropped support for Node.js v4

Theo v5 is now compatible with Node.js v6.3 and up, dropping support for Node.js v4.

Error handling

Pointing to a non-existing alias now throws an error instead of failing silently.

Kebab case

Lodash's implementation of kebabCase was dropped because it separated numbers as words:

  • Lodash: A1 -> a-1
  • Theo: A1 -> a1

4.x.x

See https://github.com/salesforce-ux/theo/releases