@adaptive-web/adaptive-ui
v0.11.0
Published
A collection of design utilities supporting basic styling and Adaptive UI
Downloads
764
Readme
Adaptive UI
Adaptive UI is a library for building highly-consistent design systems based around your visual decisions. This represents an evolution of many token implementations that provide end-result values without the means to track how they were derived or easily adjust them.
This started as a core feature of FAST and is incorporated into the Fluent UI Web Components and other design systems. To better support and accelerate development it has been factored out to the Adaptive Web Community.
Installation
npm install @adaptive-web/adaptive-ui
Getting started
The most common way to use this library is through the DesignToken
s.
For example, in a FAST style sheet:
css`
:host {
background: ${neutralFillRest};
}
`
This will evaluate the neutralFillRest
recipe when the component loads and apply the correct color appropriate for the current context within design.
Most of the color recipes are contextually aware of where they're used so they produce accessible colors based on the configuration of the design, for instance between light mode and dark mode, or when personalization is applied, like a blue tint to the neutral colors or orange accent color.
To tint the neutral palette, and thus all color recipes derived from it:
neutralBaseColor.withDefault("#73818C");
See more about the adaptive color system.
Next Steps
The fixed design tokens (neutralFillRest
) will evolve into a more configurable definition aligning with industry standards in design tokens. Styling will be inverted, applying styling options to components rather than components getting values from known tokens.
The layer system for setting content area background colors and improved handling of light and dark mode is evolving and will be added soon.
The latest version of adaptive density, currently in RFC and PR, will come here soon as well.
The color system is being updated to support opacity in colors, which will enable at least the neutral palette to overlay images or background blur effects like in Windows 11.