Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/alexsedeke/postcss-export-vars
PostCSS plugin to export variables as JSON or JS constants for additional usage.
https://github.com/alexsedeke/postcss-export-vars
json postcss
Last synced: 3 months ago
JSON representation
PostCSS plugin to export variables as JSON or JS constants for additional usage.
- Host: GitHub
- URL: https://github.com/alexsedeke/postcss-export-vars
- Owner: alexsedeke
- License: mit
- Created: 2016-04-13T10:41:25.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2016-05-03T12:21:25.000Z (over 8 years ago)
- Last Synced: 2024-10-31T16:58:23.522Z (3 months ago)
- Topics: json, postcss
- Language: JavaScript
- Size: 8.79 KB
- Stars: 20
- Watchers: 0
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# PostCSS Export Vars [![Build Status][ci-img]][ci]
[PostCSS] plugin to export variables definitions as JSON or JS constants.
It detect "custom variables" and SASS style variables and export them to JSON or JS file.
Variable that will refer to other variables are also dissolved and only the value is adopted.This plugin was created for a project, witch should use defined css colors also for highcharts.
All suggestions are welcome![PostCSS]: https://github.com/postcss/postcss
[ci-img]: https://travis-ci.org/nahody/postcss-export-vars.svg
[ci]: https://travis-ci.org/nahody/postcss-export-vars## Options
All options are mandatory.**file**
Export file name. Extension is not required and will be set automatically.
Default file name is ```postcss_vars```**type**
Export format. Default is JSON. Possible values are ```json``` and ```js```.**match**
The match option is an array of string the property name / variable must contain to limit the result for a specific group of variables.
When option is missing or an empty array, all properties / variables are taken.```json
{
file: 'my-vars',
type: 'js',
match: ['-color', 'font']
}
```## Example
**CSS Source:**
```css
:root {
--var-color1: rgb(255, 255, 200);
--var-padding: 10px;
--var-padding-sub: var(--var-padding);
}$var-color2: rgb(30, 100, 255);
$var-margin: 20px;
```**JSON Result:**
```JSON
{
"varColor1": "rgb(255, 255, 200)",
"varPadding": "10px",
"varPadding-sub": "10px",
"varColor2": "rgb(30, 100, 255)",
"varMargin": "20px"
}
```**JavaScript Result:**
```JS
const varColor1 = 'rgb(255, 255, 200)';
const varPadding = '10px';
const varPadding-sub = '10px';
const varColor2 = 'rgb(30, 100, 255)';
const varMargin = '20px';
```## Usage
```js
postcss([ require('postcss-export-vars') ])
```See [PostCSS] docs for examples for your environment.
## Notice
The plugin DO NOT tranform your PostCSS. It collects all definition and converts them to the required format. Therefore, the export to a file must be made and can not stream as PostCSS be returned.