0.1.0 • Published 9 years ago

ie-base64-protector v0.1.0

Weekly downloads
2
License
ISC
Repository
github
Last release
9 years ago

IE base64 protector

Build Status

This task duplicates styles in a stylesheet, appends a custom selector and adds an ignore comment flag for grunt-image-embed.

Created by Dean James (https://github.com/xurion)

Getting Started

Install this plugin with the command:

npm install https://github.com/xurion/ie-base64-protector/tarball/0.3.4

Next, add this line to your project's grunt file:

grunt.loadNpmTasks("ie-base64-protector");

Lastly, add configuration settings to your grunt.js file (see below).

Documentation

This task has an object of files with key and value defined as prefix selector and file respectively. The file defined is edited directly and will be made to output to a destination later. It is recommended to use grunt copy or cssmin before running protector against a file.

An example configuration looks like this:

grunt.initConfig({
    'ieBase64Protector': {
        files: {
            '.lt-ie8': 'dist/css/demo.css'
        }
    }
});

Example

If you have a stylesheet with the following CSS:

body {
    background: url(image.gif);
}

Running protector against this file (with the above example options) will change it to the following:

body {
    background: url(image.gif);
}
.lt-ie8 body {
    background: url(image.gif); /*ImageEmbed:skip*/
}

Running grunt-image-embed against this file will now base64 encode the image, and leave the IE protected image:

body {
    background: url(...zJaWlgAAAAAAAAAAAAA==);
}
.lt-ie8 body {
    background: url(image.gif); /*ImageEmbed:skip*/
}

Note: You have to have a mechanism to add the correct class to the html tag. This is what I use:

<!--[if lt IE 7]><html class="lt-ie9 lt-ie8 lt-ie7" lang="en"><![endif]-->
<!--[if IE 7]><html class="lt-ie9 lt-ie8" lang="en"><![endif]-->
<!--[if IE 8]><html class="lt-ie9" lang="en"><![endif]-->
<!--[if gt IE 8]><!--><html><!--<![endif]-->

License

Licensed under the MIT License.