Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
@alaskaairux/orion-design-tokens
Advanced tools
Alaska Air Orion Design System token repository
Orion Design Tokens are abstract UI atomic values that make up the greater Orion Design System (ODS).
The goal of this project is to maintain these core values in such a way as to feed the UI of other engineering efforts, rather than be a manually communicated design dependency.
To use Design Tokens with your project, it's suggested to create a config.json
wherever makes sense for your build pipeline.
Referencing the example config.json
file, look for the "source"
key. Update the value to the path to where the npm packages are stored. Most likely you will use the following example.
"source": [ "./node_modules/@alaskaairux/orion-design-tokens/**/*.json" ]
The example config.json
file covers a lot of possible outputs from the Design Tokens. When installing this into a production project you simply need to cover the platforms you intend to use.
Update the buildPath key to reference the directory where you want the generated file(s) to be placed.
"buildPath": "./[project dir path]/[empty dir]/"
Update the destination key if you prefer a different name other than _TokenVariables.scss
Your config.json
file would most likely look like the following:
{
"source": [ "./node_modules/@alaskaairux/orion-design-tokens/**/*.json" ],
"platforms": {
"scss": {
"transformGroup": "scss",
"buildPath": "./assets/src/sass/global/orion-design-tokens/",
"files": [
{
"destination": "_TokenVariables.scss",
"format": "scss/variables"
}
]
}
}
}
To run Style Dictionary, you simply need to require the dependency and call the function. This will work in any Node.js instance.
// Required dependency
const StyleDictionary = require('style-dictionary').extend('./[dir]/tokensConfig.json');
// Style Dictionary build function
StyleDictionary.buildAllPlatforms();
To run with Gulp, simply require the dependency and wrap the function in any Gulp task;
gulp.task('buildTokens', function() {
StyleDictionary.buildAllPlatforms();
});
If you are using Webpack and a build.js
or start.js
, simply require the dependency and call the function. The only requirement is that the Style Dictionary function must run before running Webpack.
If your project is not using a build.js
or start.js
configuration, another way to use Style Dictionary is to place the function call in a separate .js
file.
For example, in your project you could place the required dependency call and function in ./src/scripts/styleDictionary.js
.
To execute the file, you could concatenate calls in your package.json
build step, for example;
"scripts": {
"build": "node scripts/styleDictionary.js && webpack"
},
For example, see ./example/scripts/styleDictionary.js
. To run, use the following command:
$ npm run buildTokens
This 3rd option is a combination of the two previous options. In your project you could place the required dependency call and function in ./src/scripts/styleDictionary.js
. Then in your Webpack config file, require the Webpack Shell Plugin.
const WebpackShellPlugin = require('webpack-shell-plugin');
Then further down in the same file, add the following plugin option:
module.exports = {
...
plugins: [
new WebpackShellPlugin({
onBuildStart:['node scripts/styleDictionary.js']
})
],
...
}
This plugin will execute the necessary Style Dictionary command prior to executing Webpack.
If preferred, you can bypass the config.json
dependency and extend the configuration directly within the extend()
function of your build pipeline.
const StyleDictionary = require('style-dictionary').extend({
"source": [ "./node_modules/@alaskaairux/orion-design-tokens/**/*.json" ],
platforms: {
scss: {
transformGroup: 'scss',
"buildPath": "./assets/src/sass/global/orion-design-tokens/",
files: [{
destination: '_TokenVariables.scss',
format: 'scss/variables'
}]
}
}
});
StyleDictionary.buildAllPlatforms();
For processing of .json
files to a usable Sass/CSS resources, the Orion Design Tokens project uses Style Dictionary. Data formatting and build process are engineered to Style Dictionary's opinions.
For more information, see Style Dictionary's documentation.
Dependency is installed with this package
Located in the npm version of the Orion Design Tokens is a ./tokens
directory.
└── tokens
├── TokenProperties.css
├── _TokenProperties.scss
└── _TokenVariables.scss
file | type | syntax |
---|---|---|
TokenProperties.css | CSS Custom Properties | CSS |
_TokenProperties.scss | CSS Custom Properties | SCSS |
_TokenVariables.scss | Sass variables | SCSS |
To install in Sass file:
@import "~@alaskaairux/orion-design-tokens/tokens/TokenVariables";
or
@import "~@alaskaairux/orion-design-tokens/tokens/TokenProperties";
To install CSS file:
With React or similar framework, the CSS file can be imported directly from the npm:
import "@alaskaairux/orion-design-tokens/tokens/TokenProperties.css";
For other frameworks, it's suggested that the CSS file be copied from the npm into the scope of the project with a build scenario.
Style Dictionary is able to output variable files in either Sass or CSS Custom Properties (variables) format. The example pipeline and the style.scss
file has references to both Sass and CSS variables.
Important: CSS variables need to have their references available to them in the final output CSS. Whereas Sass will convert these values to static values in the output CSS.
The example build pipeline addresses this by concatenating the CSS variables with the final CSS output file.
Style Dictionary fully supports native platforms and is able to output resources that are usable in both iOS and Android native development.
CSS Custom Properties are new to CSS and thus do not have good legacy browser support. The term polyfill is used loosely in this scenario in that legacy browser support is best addressed in a PostCSS build pipeline.
In the example, the processed Sass is put through a PostCSS process that takes the variable value and creates a static property alongside the dynamic one. You have the option to preserve the custom property or remove it from the final output CSS. It is recommended that you preserve the dynamic value for browsers that support this convention.
All notable changes to this project will be documented in this file. Dates are displayed in UTC.
16 April 2019
20fb8e6
8ff53c7
531bad9
c8e72ad
2756c1e
Generated by auto-changelog
.
FAQs
Alaska Air Orion Design System token repository
We found that @alaskaairux/orion-design-tokens demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 2 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.