mirror of
https://github.com/KevinMidboe/inline-html.git
synced 2025-10-29 17:40:29 +00:00
44 lines
1.1 KiB
JavaScript
44 lines
1.1 KiB
JavaScript
var cheerio = require('cheerio');
|
|
var inlineUrl = require('./inline-css-url');
|
|
var string = require('string');
|
|
|
|
var prefix = 'element {';
|
|
var suffix = '}';
|
|
var wrap = function (value) {
|
|
return prefix + value + suffix;
|
|
};
|
|
var unwrap = function (value) {
|
|
var regexp = new RegExp('^' + prefix + '\\s*(.*)\\s*' + suffix + '$');
|
|
return value.replace(regexp, '$1');
|
|
};
|
|
var inline = function (html, filename) {
|
|
var files = [];
|
|
var $ = cheerio.load(html, {decodeEntities: false});
|
|
// style elements
|
|
var styles = $('style');
|
|
styles.each(function (index, element) {
|
|
var css = $(element).html();
|
|
var result = inlineUrl(css, filename);
|
|
files.push(result.files);
|
|
$(element).html(result.css);
|
|
});
|
|
|
|
// style attributes
|
|
var attributes = $('*').filter('[style]');
|
|
attributes.each(function (index, element) {
|
|
var css = $(element).attr('style');
|
|
css = wrap(css);
|
|
var result = inlineUrl(css, filename);
|
|
files.push(result.files);
|
|
css = string(result.css).collapseWhitespace().toString();
|
|
css = unwrap(css);
|
|
$(element).attr('style', css);
|
|
});
|
|
|
|
return {
|
|
html: $.html(),
|
|
files: files
|
|
};
|
|
};
|
|
|
|
module.exports = inline; |