datauri

A simple Data URI scheme module and client for Node.js and io.js

datauri

A simple Data URI scheme module and client for Node.js and io.js. To install datauri, just run:

npm install -g datauri (it may require Root privileges)

To print a data-uri scheme from a file

$ datauri brand.png

You can generate or update an output css file with data-uri background:

$ datauri brand.png asset/background.css

If you want to define a Class Name, just type:

$ datauri brand.png asset/background.css MyNewClass
var Datauri = require('datauri'),
    dUri    = Datauri('test/myfile.png');
 
console.log(dUri); //=> "..." 
var Datauri = require('datauri'),
    dUri    = new Datauri('test/myfile.png');
 
console.log(dUri.content); //=> "..." 
console.log(dUri.mimetype); //=> "image/png" 
console.log(dUri.base64); //=> "iVBORw0KGgoAAAANSUhEUgAA..." 
console.log(dUri.getCss()); //=> "\n.case {\n    background: url('..." 
console.log(dUri.getCss("myClass")); //=> "\n.myClass {\n    background: url('..." 
var Datauri = require('datauri'),
    dUri    = new Datauri();
 
dUri.on('encoded', function (content) {
    console.log(content); //=> "..."; 
});
 
dUri.on('error', function (content) {
    console.log('Fail!');
});
 
dUri.encode('test/myfile.png');
dUri.on('encoded', function (content) {
 
        console.log(content); //=> "..." 
 
        console.log(this.mimetype); //=> "image/png" 
        console.log(this.base64); //=> "iVBORw0KGgoAAAANSUhEUgAA..." 
        console.log(this.getCss()); //=> "\n.case {\n    background: url('..." 
        console.log(this.getCss("myClass")); //=> "\n.myClass {\n    background: url('..." 
    })
    .on('error', function (content) {
        console.log('Fail!');
    })
    .encode('test/myfile.png');
var DataURI = require('datauri');
 
DataURI('test/myfile.png', function (errcontent) {
    if (err) {
        throw err;
    }
 
    console.log(content); //=> "..." 
 
    console.log(this.mimetype); //=> "image/png" 
    console.log(this.base64); //=> "iVBORw0KGgoAAAANSUhEUgAA..." 
    console.log(this.getCss()); //=> "\n.case {\n    background: url('..." 
    console.log(this.getCss("myClass")); //=> "\n.myClass {\n    background: url('..." 
});
 

Promises /A+ standard

var DataURI = require('datauri').promises;
 
DataURI('test/myfile.png').then(function (content) {
    console.log(content); //=> "..." 
},
function (err) {
    throw err;
});
 
var Datauri = require('datauri'),
    dUri    = new Datauri();
 
dUri.format('.png', 'xkcd');
 
console.log(dUri.content); //=> "" 
console.log(dUri.mimetype); //=> "image/png" 
console.log(dUri.base64); //=> "eGtjZA==" 
console.log(dUri.getCss("myClassName")); //=> "\n.myClassName {\n    background: url('..." 
 

If you already have your file as a Buffer, use this. It's much faster than passing a string.

var Datauri = require('datauri'),
    dUri    = new Datauri();
 
//... 
var buffer = fs.readFileSync('./hello');
//... 
 
dUri.format('.png', buffer);
 
console.log(dUri.content); //=> "" 
console.log(dUri.mimetype); //=> "image/png" 
console.log(dUri.base64); //=> "eGtjZA==" 
console.log(dUri.getCss("myClassName")); //=> "\n.myClassName {\n    background: url('..." 
 

There are a bunch of grunt plugins running on top of datauri module.

The only essential library to develop datauri is jshint.

$ make install
$ make test

If you'd like to test the full process including npm installer, just run:

$ make fulltest
  • 0.6 - io.js support
  • 0.5 - Format data uri from a string
  • 0.4 - Promises support
  • 0.3 - API Rewritten from the top to the bottom + full async compatibility
  • 0.2 - Splitted in submodules mimer and templayed
  • 0.1 - First release

MIT License (c) Helder Santana