Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/lagden/postcss-inline-base64

PostCSS plugin used to replace value inside of url function to base64
https://github.com/lagden/postcss-inline-base64

base64 font-face image inline plugin postcss src svg url

Last synced: about 1 month ago
JSON representation

PostCSS plugin used to replace value inside of url function to base64

Awesome Lists containing this project

README

        

# PostCSS Inline Base64

[![Node.js CI][ci-img]][ci]
[![Coverage Status][cover-img]][cover]
[![Snyk badge][snyk-img]][snyk]

[PostCSS](https://github.com/postcss/postcss) plugin used to replace value inside of url function to base64

[PostCSS]: https://github.com/postcss/postcss
[ci-img]: https://github.com/lagden/postcss-inline-base64/actions/workflows/nodejs.yml/badge.svg
[ci]: https://github.com/lagden/postcss-inline-base64/actions/workflows/nodejs.yml
[cover-img]: https://codecov.io/gh/lagden/postcss-inline-base64/branch/master/graph/badge.svg
[cover]: https://codecov.io/gh/lagden/postcss-inline-base64
[snyk-img]: https://snyk.io/test/github/lagden/postcss-inline-base64/badge.svg
[snyk]: https://snyk.io/test/github/lagden/postcss-inline-base64

## Usage

See the [example](#example) below

```js
import postcssInlineBase64 from 'postcss-inline-base64'

postcss([
postcssInlineBase64(options),
])
```

If you are using `CommonJS module`:

```js
postcss([
require('postcss-inline-base64')(options),
])
```

### Options

Name | Type | Default | Description
----------- | ------- | -------------- | ------------
baseDir | string | process.cwd() | Path to load files

## Example

Use the syntax below inside `url()` function:

```
Variations:

- b64---{file}---
- b64---'{file}'---
- b64---"{file}"---
- 'b64---{file}---'
- "b64---{file}---"
```

### input

```css
:root {
--image: 'b64---./example.gif---';
}

@font-face {
font-family: 'example';
src: url('b64---./example.woff---') format('woff'), url('b64---./example.woff2---') format('woff2');
font-weight: normal;
font-style: normal;
}

body {
background-color: gray;
background-image: url(var(--image));
}

.notfound {
background-image: url('b64---https://file.not/found.png---');
}

.ignore {
background-image: url('https://cdn.lagden.in/mask.png');
}
```

### output

```css
:root {
--image: 'data:image/png;charset=utf-8;base64,iVBORw0K...SuQmCC';
}

@font-face {
font-family: 'example';
src: url('data:font/woff;charset=utf-8;base64,d09...eLAAAA==') format('woff'), url('data:font/woff2;charset=utf-8;base64,d09...eLAAAA==') format('woff2');
font-weight: normal;
font-style: normal;
}

body {
background-color: gray;
background-image: url(var(--image));
}

.notfound {
background-image: url('https://file.not/found.png');
}

.ignore {
background-image: url('https://cdn.lagden.in/mask.png');
}
```

---

See [PostCSS](https://github.com/postcss/postcss/tree/master/docs) docs for examples for your environment.

## Donate ❤️

- BTC: bc1q7famhuj5f25n6qvlm3sssnymk2qpxrfwpyq7g4
- PIX: [email protected]

## License

MIT © [Thiago Lagden](https://github.com/lagden)