Accoutrement Changelog
4.0.5 - 11/07/24
- 🐛 BUGFIX: Address Sass deprecation warnings
- 🏠 INTERNAL: Upgrade dev dependencies
4.0.4 - 12/14/22
- 🏠 INTERNAL: Remove documentation from npm package
- 🏠 INTERNAL: Upgrade dev dependencies
4.0.3 - 07/20/22
- BUGFIX: Fixed a bug with
tokens.get()that didn’t allow per-property inline functional adjustments – #117
4.0.2 - 07/18/22
- BUGFIX: Fixed a bug with
tokens.get()memorization – #112
- INTERNAL: Upgrade dev dependencies.
- Tokens:
- NEW: Add $ignore-cacheparameter totokens.get()function, in order to override the cached value of a token.
 
- NEW: Add 
- Sass Utilities:
- NEW: Removed unnecessary string length checks in the
split()function.
 
- NEW: Removed unnecessary string length checks in the
4.0.1 - 03/28/22
- INTERNAL: Upgrade dev dependencies.
- DOCS: Update modules list – #111
4.0.0 - 03/02/22
This is a major update, moving over to Sass modules, and removing some features that no longer seem necessary.
In addition to fixing a bug with the handling of
non-alias # symbols, and implementing deep map merges
where appropriate, we also added some functionality around
compiling maps for export, and working with different
color palettes.
- 
BREAKING: Requires Sass modules, and other recent features of Dart Sass. Legacy versions of Sass (Node & Ruby) are no longer supported. 
- 
BREAKING: The old “init” module, which provided lightweight browser normalization, is no longer included. We now recommend using CSS Remedy. (Note: If making the switch from Accoutrement/Init to CSS Remedy, you may need to reset the marginandpaddingof block elements to remove unwanted vertical space. And SVGs and other media may stack instead of displaying inline since CSS Remedy sets these todisplay: blockby default.)
- 
BREAKING: The old “core” module has been broken into individual modules for utilities (extending several Sass modules), tokens (the map syntax parser), variables (converting Sass variables & maps to CSS custom properties), and ratios (for typographic scales and layout aspect ratios). 
- 
BREAKING: Map multi-merge()utility and alladd-*functions for adding one or more token maps (e.g.add-sizes(),add-colors(), etc) now perform a deep merge of the token maps. Previously a shallow merge was performed, which could result in removing nested values from maps.
- 
INTERNAL: Limit files included in npm package. 
- 
INTERNAL: Remove documentation static-site from Accoutrement repository. 
- 
INTERNAL: Switch from Travis CI to GitHub Actions for CI. 
- 
INTERNAL: Upgrade dev dependencies. 
- 
- NEW: compile-*functions provide an export option for respective token maps (see:compile-changes(),compile-easing(), andcompile-times()).
- NEW: Named default easings are now available as
individual variables,
(without the _prefix that is applied in token maps).
 
- NEW: 
- 
- NEW: compile-colors()function provides an export option for color token maps.
- NEW: with-colors()mixin allows the overriding of the global color palette for a section of contents.
 
- NEW: 
- 
- NEW: These functions are now available directly, as well as being registered in the map syntax.
- NEW: multi-merge()function for merging multiple maps into a single map.
- NEW: replace()function for replacing a substring inside a larger string, or replacing the entirety of a string.
- NEW: interpolate()function returns a string with interpolated values replacing%splaceholders in a format string.
- NEW: split()function for splitting a string into a list of strings, using the same logic as JavaScript’ssplit()method.
- NEW: trim()function trims whitespace from the start and end of a string.
 
- 
- NEW: ident()function adds--and an optional prefix to any string, in order to generate a custom property identifier.
- NEW: custom-props()mixin generates custom properties for every key/value pair in a map.
 
- NEW: 
- 
- NEW: A module just for the custom map syntax parser & function registration.
- NEW: map-compile()andmap-compile-with()functions for compiling tokens in Accoutrement maps and formatting them for static exports.
- BREAKING: The $functionsmap no longer accepts alias references or any other aspects of the token syntax.
- BREAKING: Ratios are no longer first-class adjustments (like functions) in the token syntax.
- BREAKING:
tokens.$handle-missing-keysdefaults tonull, and no longer supports the legacysilentoption.
- BREAKING: get-token()is renamedget(), and only accepts bare token names (no#prefix), including theouter->innernested token syntax.
- NEW: The new compile()function provides direct access to parse & resolve an arbitrary token value (including aliases with#prefix), rather than calling a specific token by name.
- NEW: All the built-in Sass module functions are registered by default,
as <module-name>.<function-name>.
- NEW: has-token()function checks a map to see if the given token is defined, and supports theouter->innernested token syntax.
- NEW: plus()function adds two values together in Accoutrement maps.
- NEW: minus()function subtracts one value from another in Accoutrement maps.
- NEW: times()function multiplies two values together in Accoutrement maps.
- NEW: divide()function divides two values in Accoutrement maps.
- NEW: modulo()function divides two values in Accoutrement maps and returns the remainder.
 
- 
Type: - NEW: compile-fonts()function provides an export option for font token maps.
- NEW: The default value for $contentin pseudo element mixins is an empty string.
 
- NEW: 
- 
- NEW:
compile-ratios()function provides an export option for ratio token maps.
- NEW: Built-in named ratios are now available as
individual variables, (without the _prefix that is applied in token maps).
- NEW: is-ratio()function can be used to type-check ratios, including ratio tokens.
 
- NEW:
- 
- NEW:
compile-sizes()function provides an export option for size token maps.
- NEW: scale()function applies a modular scale to any value, allowing you to move up or down the scale any number of steps.
 
- NEW:
- 
- BREAKING: Removed global-box-sizing.
- BREAKING: Removed clearfix.
- BREAKING: Removed fluid-ratio.
- BREAKING: Removed position. Can achieve the majority of functionality in CSS using Inset.
 
- BREAKING: Removed 
3.0.1 - 03/01/21
- INTERNAL: Upgrade dev dependencies.
- DOCS: Fix changelog typo.
3.0.0 - 02/22/21
- BREAKING: Change to get-token()return value when the key path cannot be resolved, and$handle-missing-keysis unset orsilent: Maps along the missing key path are no longer interpolated into the returned string. This is part of the fix for #49. Use$handle-missing-keysfor more precise missing subkey behavior. (Thanks to John Crim @johncrim)
- NEW/BREAKING: Font maps accept displaykey, which can be used to setfont-displayproperty for importing web-fonts. (thanks to André Schließer @schliesser)
- BUGFIX (#49): Using get-token()to resolve a missing key no longer errors when using dart-sass and$handle-missing-keysis unset orsilent. Instead, the unresolved path is returned. (Thanks to John Crim @johncrim)
- BUGFIX (#61): Using get-token()to obtain a 2nd level or deeper submap no longer causes a fatal error when using dart-sass and$handle-missing-keysisnull,warn, orerror. (Thanks to John Crim @johncrim)
- INTERNAL: Run unit tests with dart-sass (in addition to node-sass, which was used prior). (Thanks to John Crim @johncrim)
- INTERNAL: Upgrade dev dependencies.
- DOCS (#53): Use htmlrather than:rootfor examples.
- DOCS: Wrong parameter name in contrast-ratio()function docs.
2.2.0 - 09/08/20
- NEW: (#41) Global $handle-missing-keysallows you to control exactly what should happen when a key look-up fails. The defaultsilentprovides backwards-compatible silent-failure. Other options include:- null:- get-token()will return- null, similar to Sass- map.get()
- warn:- get-token()will return- null, and also throw a warning
- error:- get-token()will throw an error if the value is not found
 
- NEW: \\(an escaped backslash) can be used to ignore (\\#not-an-alias) or end (#alias\\not-part-of-alias) a#reference
- INTERNAL: (#41) Major performance improvements to the token look-up algorithm
Huge thanks to James Camilleri (@jcamilleri13) for all the improvements here.
2.1.4 - 06/30/20
- DOCS (#54): Fix broken links in docs
- INTERNAL: Upgrade dev dependencies.
2.1.3 - 01/06/20
- Core:
- BUGFIX (#46): Fixes register-function()usage with Sass module syntax
 
- BUGFIX (#46): Fixes 
2.1.2 - 08/26/19
- Upgrade dev dependencies.
- Core:
- BUGFIX (#36): Fixes an issue with quote()in dart-sass.
- BUGFIX (#38): Fixes an issue with falsevalues in maps.
 
- BUGFIX (#36): Fixes an issue with 
2.1.1 - 01/04/19
- Core:
- BUGFIX (#31): Fixes an issue with longhand map memoization
 
2.1.0 - 12/20/18
- Plugin: Color
- NEW: contrast(),contrasted(),var-contrast(), andvar-contrasted()provide access to the lowest accessible contrast value, as well as than the (default) maximum contrast value. Pass a valid contrast ratio (0-21) or WCAG standard (aaa,aa,aa-large) to set a cutoff ratio, and return the minimum accessible color
- NEW: shades-of()generates a range of light and dark color-shades to help build accessible themes based on a few origin colors
- NEW: stripe-colors()function and mixin generate a color-stops or a full striped gradient background. This is useful for viewing the result fromshades-of()
 
- NEW: 
2.1.0-beta.1 - 12/13/18
- Plugin: Color
- NEW: var-contrast()andvar-contrasted()provide CSS variable parallels tocontrast()andcontrasted()
- NEW: User-defined contrast defaults
(contrast-lightandcontrast-dark) can be defined with or without the_private-color prefix
- NEW: Contrast-related functions and mixins provide a smart second light-or-dark default option when only one is defined (previously an error)
 
- NEW: 
2.0.0 - 12/05/18
The 2.0 release is primarily focused on
support for CSS Custom Properties (aka CSS Variables),
and access to nested-map tokens with #outside->inside syntax.
We’ve also added private tokens (_token),
and various tools for token-inspection.
All factory-default tokens (contrast-colors, named ratios, etc)
are now marked as private,
and will need to be called with a _ prefix.
See the full details below.
Thanks to Joel Schou (@joelschou) for extensive contributions, designing and testing several of these features.
- Core:
- BREAKING: Explicit value/adjustments maps require a '%value'key (used to be named'value'), in order to avoid possible conflicts or false-positives
- NEW (BREAKING alpha.1): all nested-map token references (using ->) must be absolute paths from the map root, rather than assuming the most closely related sibling or ancestor value
- BUGFIX (from alpha.1): Major improvements to compile time
when parsing ->syntax
 
- BREAKING: Explicit value/adjustments maps require a 
2.0.0-alpha.1 - 10/29/18
- Core:
- NEW: $adjust-query-overlap(max|min|false) allows you to control if and how media-queries are adjusted to avoid overlap between min/max queries (thanks to @joelschou)
- NEW: Support for integrating accoutrement tokens & CSS variables
with tokens--(),token--(),var-token(), and plugin-specific shortcuts
- BREAKING: Token names starting with _or-are considered “private” to Sass, and will not be output when auto-generating CSS (variables, font-names, etc.)
- BREAKING: Default ratio tokens are now prefixed with _(search/replace e.g.minor-third->_minor-third) to avoid CSS-variable output
- NEW: is-private-token()andis-alias-for()are now public functions, to help with token-inspection
- BREAKING: Support for nested-map tokens with ->syntax, both in#hash->referencesandget-token($source, 'function->calls')(thanks to @joelschou)
 
- NEW: 
- Plugin: Animate
- BREAKING: Default easing tokens are now prefixed with _(search/replace e.g.in-out-quad->_in-out-quad) to avoid CSS-variable output
- NEW: Support for easing CSS variables with
easing--(),ease--(), andvar-ease()
- NEW: Support for time CSS variables with
times--(),time--(), andvar-time()
- NEW: Support for change CSS variables with
changes--(),change--(), andvar-change()
 
- BREAKING: Default easing tokens are now prefixed with 
- Plugin: Color
- BREAKING: _contrast-lightand_contrast-darkcolors are used for mixingtint()andshade(), with optional$light/$darkoverride parameters (thanks to @joelschou)
- NEW: Default _contrast-lightand_contrast-darkprovided, set_contrast-light/darkin$colorsto override
- NEW: Support for CSS Variables with
colors--(),color--(), andvar-color()
 
- BREAKING: 
- Plugin: Layout
- BREAKING: Default ratio tokens are now prefixed with _, see core for details
 
- BREAKING: Default ratio tokens are now prefixed with 
- Plugin: Scale
- BREAKING: Default ratio tokens are now prefixed with _, see core for details
- NEW: Support for size CSS Variables with
sizes--(),size--(), andvar-size()
- NEW: Support for ratio variables with
ratios--(),ratio--(), andvar-ratio()
 
- BREAKING: Default ratio tokens are now prefixed with 
- Plugin: Type
- BREAKING: Non-map fonts are interpreted as font-stacks
- BREAKING: Normalized font-data uses proper name-quotation, and ignores missing or private names/stacks
- BREAKING: import-webfonts()no longer imports private fonts, but will import a direct alias of the private font
- NEW: import-webfonts()accepts$sourceparameter
- NEW: Support for CSS Variables with
fonts--(),font--(), andvar-font()
 
1.0.1 - 09/08/18
- Core:
- BUGFIX: Typos, including the cinemaratio spelling (thanks to @joelschou)
- BUGFIX: Improved consistency of nested-map parser (thanks to @joelschou)
 
- BUGFIX: Typos, including the 
1.0.0 - 08/08/18
- The stable 1.0 release is identical to -beta.3, see change details below
1.0.0-beta.3 - 08/03/18
- Plugin: Scale
- BUGFIX: size()function removes quotes from string (calc) sizes
 
- BUGFIX: 
1.0.0-beta.2 - 07/27/18
- Core:
- NEW: ratio()function accepts$sourceargument, for passing in a custom source map
- NEW: Improved error-handling and messages
- NEW: Added str-trimandstr-splitaliases in addition to the existingtrimandsplit
 
- NEW: 
- Plugin: Animate
- NEW: ease(),time(), andchange()functions all accept$sourceargument, for passing in a custom source map
 
- NEW: 
- Plugin: Layout
- NEW: break()function accepts$sourceargument, for passing in a custom source map
- NEW: break()function accepts$scaleboolean, to turn off access to the scale-plugin$sizesmap
- NEW: fluid-ratio()function and mixin both accept$sourceargument, for passing in a custom source map
 
- NEW: 
- Plugin: Scale
- BREAKING: negative()function andsquare()mixin both accept$doargument for on-the-fly adjustments – replacing the old$units…variable argument. Non-map$dovalues are converted to('convert-units': $do)before processing, to provide a shortcut for unit-conversions.negative('root', 'cm')will continue to work, butnegative('root', 'em', 10px)should be changed tonegative('root', 'em' 10px)(with all unit args in a single list)
- NEW: size()/negative()functions andsquare()mixin accept$sourceargument, for passing in a custom source map
 
- BREAKING: 
- Plugin: Type
- NEW: font()/font-family()functions andfont-family()/font-face()mixins accept$sourceargument, for passing in a custom font-source map
 
- NEW: 
1.0.0-beta.1 - 07/18/18
- NEW: Add _index.scssto simplify default “tools” import (core + plugins) in Eyeglass:@import 'accoutrement';
- Core:
- NEW: get-token()andratio()functions accept$doargument, for on-the-fly adjustments
- NEW: trim($string)utility now available in map-syntax, to trim white-space from the start and end of a string
- NEW: str-replace()utility now forces arguments tostring-type when appropriate, allowing e.g.calc(16px + 1vw) ('str-replace': 1vw 2vw)
 
- NEW: 
- Plugin: Animate
- NEW: change(),time(), andease()functions all accept$doarg for on-the-fly adjustments
 
- NEW: 
- Plugin: Color
- BREAKING: color()functions accept$doarg for on-the-fly adjustments – before existing$paletteargument
- BREAKING: $paletteargument renamed$sourcefor consistency across plugins
 
- BREAKING: 
- Plugin: Layout
- NEW: break()function accept$doarg for on-the-fly adjustments
 
- NEW: 
- Plugin: Scale
- BREAKING: size()function$units…variable argument has been replaced with$domap argument, for flexible on-the-fly adjustments. Non-map$dovalues are converted to('convert-units': $do)before processing, to provide a shortcut for unit-conversions.size('root', 'cm')will continue to work, butsize('root', 'em', 10px)should be changed tosize('root', 'em' 10px)(with all unit args in a single list)
 
- BREAKING: 
- Plugin: Type
- BREAKING: import-webfonts()mixin no longer accepts any arguments
- NEW: font()function provides access to parsed font-data
- NEW: 'trim'string helper strips whitespace from the start and end of a string
- NEW: Improved font-normalization handles more font-map edge-cases
- NEW: Font-stacks can be written as comma-delimited strings,
e.g. 'Helvetica Neue, Helvetica, Arial'or'Helvetica Neue, Helvetica, Arial'
 
- BREAKING: 
0.1.0 - 07/12/18
- BREAKING: All modules now use a shared map syntax,
with explicit #tagreferences and the option for explicit value/adjustment maps.
- NEW: Merges all existing Accoutrement plugins
- Core:
- BREAKING: Internal map-reference now uses #tagsyntax
- NEW: Generic map-syntax, access, and parsing tools are shared by all plugins, and can be used with un-specified data types
- NEW: Improved function-registration options
- NEW: Math, modular-scale, string, and list utilities combined from the individual plugins
 
- BREAKING: Internal map-reference now uses 
- Plugin: Animate:
- A totally new plugin!
 
- Plugin: Color:
- BREAKING: See tokens syntax changes
- BREAKING: Removed merge-colors()function
 
- Plugin: Layout:
- BREAKING: See tokens syntax changes
- BREAKING: Ratio functionality merged into Core,
using the shared $ratiosmap, andratio()function. The old$aspect-ratiosandaspect-ratio()have been removed.
 
- Plugin: Scale:
- BREAKING: See tokens syntax changes
- BREAKING: String interpolation has moved into the Core
using function syntax '%s and %s' ('%s': 'new1' 'new2')rather than list syntax'%s and %s' ('new1', 'new2')
- BREAKING: Math functions have moved into the core. The actual functions are now prefixed & private, but they are made available to Accoutrement maps under the additional aliases
- New: Ratios have moved into the core, with additional defaults
 
- Plugin: Type:
- BREAKING: See tokens syntax changes
- NEW: Allow space-separated string variants ('500 italic') for weight and style, in addition to lists (500 'italic')
- NEW: Automatically formats font-family stacks with proper commas & quotations for CSS output