Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/akoenig/imacss
An application and library that transforms image files to data URIs and embeds them into a single CSS file.
https://github.com/akoenig/imacss
Last synced: 16 days ago
JSON representation
An application and library that transforms image files to data URIs and embeds them into a single CSS file.
- Host: GitHub
- URL: https://github.com/akoenig/imacss
- Owner: akoenig
- License: mit
- Created: 2014-02-11T10:05:56.000Z (almost 11 years ago)
- Default Branch: master
- Last Pushed: 2015-06-15T08:07:41.000Z (over 9 years ago)
- Last Synced: 2024-09-20T03:42:33.392Z (about 2 months ago)
- Language: JavaScript
- Homepage:
- Size: 276 KB
- Stars: 402
- Watchers: 26
- Forks: 33
- Open Issues: 2
-
Metadata Files:
- Readme: readme.md
- Changelog: changelog.md
- License: LICENSE
Awesome Lists containing this project
README
# imacss [![Build Status](https://travis-ci.org/akoenig/imacss.png?branch=master)](https://travis-ci.org/akoenig/imacss)
_pronunciation: imax_
An application and library that transforms image files to [data URIs (rfc2397)](https://www.ietf.org/rfc/rfc2397.txt) and embeds them into a single CSS file as background images.
Let's say you have a web-based frontend which embeds a lot of images (e.g. icons). This referencing produces HTTP requests for every single image. What if you would like to minimize it to just one request? That is something `imacss` can do for you.
## What?
Okay, enough words. Let's dive straight into a transformation example. If we assume that you have two SVGs, like `github.svg` and `quitter.svg`, `imacss` will generate this CSS code for you.
```css
.imacss.imacss-github {
background:url(...);
}.imacss.imacss-quitter {
background:url(...);
}
```You can refer to this images by using the respective CSS classes:
```html
...
```## CLI
`imacss` comes with a command-line interface which pipes the output to stdout by default (yeah, plain old text streams FTW!).
### Installation
Install with [npm](https://npmjs.org/package/imacss) globally.
npm install -g imacss
### Usage examples
Embed all SVGs in a particular directory and all its subdirectories (will pipe the output to stdout).
$ imacss "~/projects/webapp/images/**/*.svg"
Embed all SVGs in a particular directory and transfer them to a CSS file which will be saved in the CWD.
$ imacss "~/projects/webapp/images/*.svg" > images.svg.css
Embed all SVGs _and_ PNGs in a particular directory and transfer them to a CSS file which will be saved in the CWD.
$ imacss "~/projects/webapp/images/*.{svg,png}" > images.css
If you don't like the `imacss` selector namespace you are able to modify it as well.
$ imacss "~/projects/webapp/images/*.{svg,png}" foobar > images.css
will produce this selector structure in the CSS file:
```css
.foobar.foobar-github {...}
```**Important:** Please note that `imacss` does not embed `image/svg+xml` as `base64` strings. Instead it will use the raw `utf-8` representation.
## API
If you would like to use the `imacss` functionality within your application, there is an API for that.
### Install
Install with [npm](https://npmjs.org/package/imacss)
npm install --save imacss
### Methods
#### transform(glob[, namespace]);
Transforms the image files from the specified glob and returns a stream with the CSS selectors that can be piped to somewhere else.
**Arguments**
`glob`
String || [Vinyl](https://github.com/wearefractal/vinyl) file object
The path to the images which should be transformed. You can use any glob pattern you want or you're also able pass single [Vinyl](https://github.com/wearefractal/vinyl) file objects.
`namespace` (optional; default=imacss)
String || Function
A string containing the css class namespace prefix, or a function to generate the entire CSS ruleset.
The CSS selector namespace.
### Usage example
```javascript
var imacss = require('imacss');imacss
.transform('/path/to/your/images/*.png')
.on('error', function onError (err) {
console.error('Transforming images failed: ' + err);
})
.pipe(process.stdout);
```#### Passing a function to customize the resulting CSS rule set
```javascript
var imacss = require('imacss');function generateCss(image) {
return '.image-' + image.slug + ' { ' + 'background-image:' + 'url(\'' + image.datauri + '\'); }';
}imacss
.transform('/path/to/your/images/*.png', generateCss)
.on('error', function (err) {
console.error('Transforming images failed: ' + err);
})
.pipe(process.stdout);
```## Author
Copyright 2014 - 2015, [André König](http://andrekoenig.info) ([email protected])