HEX
Server: Apache/2.4.52 (Ubuntu)
System: Linux spn-python 5.15.0-89-generic #99-Ubuntu SMP Mon Oct 30 20:42:41 UTC 2023 x86_64
User: arjun (1000)
PHP: 8.1.2-1ubuntu2.20
Disabled: NONE
Upload Files
File: //home/arjun/projects/buyercall/node_modules/postcss-simple-vars/README.md
# PostCSS Simple Variables [![Build Status][ci-img]][ci]

<img align="right" width="95" height="95"
     title="Philosopher’s stone, logo of PostCSS"
     src="http://postcss.github.io/postcss/logo.svg">

[PostCSS] plugin for Sass-like variables.

You can use variables inside values, selectors and at-rule’s parameters.

```pcss
$dir:    top;
$blue:   #056ef0;
$column: 200px;

.menu_link {
    background: $blue;
    width: $column;
}
.menu {
    width: calc(4 * $column);
    margin-$(dir): 10px;
}
```

```css
.menu_link {
    background: #056ef0;
    width: 200px;
}
.menu {
    width: calc(4 * 200px);
    margin-top: 10px;
}
```

If you want be closer to W3C spec,
you should use [postcss-custom-properties] and [postcss-at-rules-variables] plugins.

Also you should look at [postcss-map] for big complicated configs.

[postcss-at-rules-variables]: https://github.com/GitScrum/postcss-at-rules-variables
[postcss-custom-properties]:  https://github.com/postcss/postcss-custom-properties
[postcss-map]:                https://github.com/pascalduez/postcss-map
[PostCSS]:                    https://github.com/postcss/postcss
[ci-img]:                     https://travis-ci.org/postcss/postcss-simple-vars.svg
[ci]:                         https://travis-ci.org/postcss/postcss-simple-vars

## Interpolation

There is special syntax if you want to use variable inside CSS words:

```pcss
$prefix: my-company-widget

$prefix { }
$(prefix)_button { }
```

## Comments

You could use variables in comments too (for example, to generate special
[mdcss] comments). But syntax for comment variables is different to separate
them from PreCSS code examples:

```pcss
$width: 100px;
/* $width: <<$(width)>> */
```

compiles to:

```css
/* $width: 100px */
```

[mdcss]: https://github.com/jonathantneal/mdcss

## Escaping

If you want to escape `$` in `content` property, use Unicode escape syntax.

```css
.foo::before {
    content: "\0024x";
}
```

## Usage

```js
postcss([ require('postcss-simple-vars') ])
```

See [PostCSS] docs for examples for your environment.

## Options

Call plugin function to set options:

```js
.pipe(postcss([ require('postcss-simple-vars')({ silent: true }) ]))
```

### `variables`

Set default variables. It is useful to store colors or other constants
in common file:

```js
// config/colors.js

module.exports = {
    blue: '#056ef0'
}

// gulpfile.js

var colors = require('./config/colors');
var vars   = require('postcss-simple-vars')

gulp.task('css', function () {
     return gulp.src('./src/*.css')
        .pipe(postcss([ vars({ variables: colors }) ]))
        .pipe(gulp.dest('./dest'));
});
```

You can set a function returning object, if you want to update default
variables in webpack hot reload:

```js
postcss([
    vars({
        variables: function () {
            return require('./config/colors');
        }
    })
])
```

### `onVariables`

Callback invoked once all variables in css are known. The callback receives
an object representing the known variables, including those explicitly-declared
by the [`variables`](#variables) option.

```js
postcss([
    vars({
        onVariables: function (variables) {
            console.log('CSS Variables');
            console.log(JSON.stringify(variables, null, 2));
        }
    })
])
```

### `unknown`

Callback on unknown variable name. It receives node instance, variable name
and PostCSS Result object.

```js
postcss([
    vars({
        unknown: function (node, name, result) {
            node.warn(result, 'Unknown variable ' + name);
        }
    })
])
```

### `silent`

Left unknown variables in CSS and do not throw an error. Default is `false`.

### `only`

Set value only for variables from this object.
Other variables will not be changed. It is useful for PostCSS plugin developers.

### `keep`

Keep variables as is and not delete them. Default is `false`.

## Messages

This plugin passes `result.messages` for each variable:

```js
postcss([vars]).process('$one: 1; $two: 2').then(function (result) {
    console.log(result.messages)
})
```

will output:

```js
[
    {
        plugin: 'postcss-simple-vars',
        type: 'variable',
        name: 'one'
        value: '1'
    },
    {
        plugin: 'postcss-simple-vars',
        type: 'variable',
        name: 'two'
        value: '2'
    }
]
```

You can get access to this variables in `result.messages` also
in any plugin goes after `postcss-simple-vars`.