[deploy] fix bug 55493
This commit is contained in:
parent
65fc046284
commit
c489b65bf2
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -3,6 +3,7 @@ Thumbs.db
|
|||
.DS_Store
|
||||
/deploy
|
||||
build/node_modules
|
||||
build/plugins/**/node_modules/
|
||||
build/sprites/node_modules/
|
||||
vendor/framework7-react/
|
||||
apps/documenteditor/embed/resources/less/node_modules
|
||||
|
|
|
@ -106,7 +106,7 @@ module.exports = function(grunt) {
|
|||
grunt.loadNpmTasks('grunt-json-minify');
|
||||
grunt.loadNpmTasks('grunt-text-replace');
|
||||
// grunt.loadNpmTasks('grunt-mocha');
|
||||
// grunt.loadNpmTasks('grunt-inline');
|
||||
grunt.loadNpmTasks('grunt-inline');
|
||||
grunt.loadNpmTasks('grunt-svgmin');
|
||||
grunt.loadNpmTasks('grunt-exec');
|
||||
|
||||
|
@ -396,9 +396,9 @@ module.exports = function(grunt) {
|
|||
localization: {
|
||||
files: packageFile['main']['copy']['localization']
|
||||
},
|
||||
help: {
|
||||
files: packageFile['main']['copy']['help']
|
||||
},
|
||||
// help: {
|
||||
// files: packageFile['main']['copy']['help']
|
||||
// },
|
||||
indexhtml: {
|
||||
files: packageFile['main']['copy']['indexhtml']
|
||||
}
|
||||
|
@ -660,7 +660,7 @@ module.exports = function(grunt) {
|
|||
grunt.registerTask('deploy-common-embed', ['common-embed-init', 'clean', 'copy']);
|
||||
|
||||
grunt.registerTask('deploy-app-main', ['prebuild-icons-sprite', 'main-app-init', 'clean:prebuild', 'imagemin', 'less',
|
||||
'requirejs', 'concat', 'copy', 'svgmin', /*'inline',*/ 'json-minify',
|
||||
'requirejs', 'concat', 'copy', 'svgmin', 'inline', 'json-minify',
|
||||
'replace:writeVersion', 'replace:prepareHelp', 'clean:postbuild']);
|
||||
|
||||
grunt.registerTask('deploy-app-mobile', ['mobile-app-init', 'clean:deploy', /*'cssmin',*/ /*'copy:template-backup',*/
|
||||
|
|
|
@ -4,7 +4,7 @@
|
|||
"homepage": "http://www.onlyoffice.com",
|
||||
"private": true,
|
||||
"dependencies": {
|
||||
"grunt": "^1.0.0",
|
||||
"grunt": "^1.4.1",
|
||||
"grunt-contrib-clean": "^2.0.0",
|
||||
"grunt-contrib-concat": "^2.0.0",
|
||||
"grunt-contrib-copy": "^1.0.0",
|
||||
|
@ -15,6 +15,7 @@
|
|||
"grunt-contrib-requirejs": "^1.0.0",
|
||||
"grunt-contrib-uglify": "^5.0.1",
|
||||
"grunt-exec": "^3.0.0",
|
||||
"grunt-inline": "file:plugins/grunt-inline",
|
||||
"grunt-json-minify": "^1.1.0",
|
||||
"grunt-spritesmith": "^6.9.0",
|
||||
"grunt-svgmin": "^6.0.1",
|
||||
|
|
50
build/plugins/grunt-inline/Gruntfile.js
Normal file
50
build/plugins/grunt-inline/Gruntfile.js
Normal file
|
@ -0,0 +1,50 @@
|
|||
'use strict';
|
||||
|
||||
module.exports = function(grunt) {
|
||||
grunt.initConfig({
|
||||
inline: {
|
||||
dist: {
|
||||
src: ['test/dist/*.html'],
|
||||
dest: ['tmp/']
|
||||
}
|
||||
},
|
||||
|
||||
clean: {
|
||||
tests: ['tmp/']
|
||||
},
|
||||
|
||||
htmlmin: {
|
||||
dist: {
|
||||
options: {
|
||||
removeComments: true,
|
||||
collapseWhitespace: true
|
||||
},
|
||||
files: {
|
||||
'tmp/css.min.html': 'tmp/css.html',
|
||||
'tmp/img.min.html': 'tmp/img.html',
|
||||
'tmp/html.min.html': 'tmp/html.html',
|
||||
'tmp/script.min.html': 'tmp/script.html',
|
||||
'tmp/css_greedy.min.html': 'tmp/css_greedy.html',
|
||||
'tmp/img_greedy.min.html': 'tmp/img_greedy.html',
|
||||
'tmp/html_greedy.min.html': 'tmp/html_greedy.html',
|
||||
'tmp/script_greedy.min.html': 'tmp/script_greedy.html'
|
||||
}
|
||||
}
|
||||
},
|
||||
|
||||
// Unit tests
|
||||
nodeunit: {
|
||||
tests: ['test/*_test.js']
|
||||
}
|
||||
});
|
||||
|
||||
grunt.loadTasks('tasks');
|
||||
|
||||
grunt.loadNpmTasks('grunt-contrib-clean');
|
||||
grunt.loadNpmTasks('grunt-contrib-htmlmin');
|
||||
grunt.loadNpmTasks('grunt-contrib-nodeunit');
|
||||
|
||||
grunt.registerTask('test', ['clean', 'inline', 'htmlmin', 'nodeunit']);
|
||||
// By default, run all tests
|
||||
grunt.registerTask('default', ['test']);
|
||||
};
|
22
build/plugins/grunt-inline/LICENSE-MIT
Normal file
22
build/plugins/grunt-inline/LICENSE-MIT
Normal file
|
@ -0,0 +1,22 @@
|
|||
Copyright (c) 2014 陈映平, contributors
|
||||
|
||||
Permission is hereby granted, free of charge, to any person
|
||||
obtaining a copy of this software and associated documentation
|
||||
files (the "Software"), to deal in the Software without
|
||||
restriction, including without limitation the rights to use,
|
||||
copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the
|
||||
Software is furnished to do so, subject to the following
|
||||
conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be
|
||||
included in all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
|
||||
OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
|
||||
HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
||||
WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
||||
OTHER DEALINGS IN THE SOFTWARE.
|
274
build/plugins/grunt-inline/README.md
Normal file
274
build/plugins/grunt-inline/README.md
Normal file
|
@ -0,0 +1,274 @@
|
|||
# grunt-inline[![build status](https://secure.travis-ci.org/miniflycn/grunt-inline.png)](http://travis-ci.org/miniflycn/grunt-inline)
|
||||
|
||||
Brings externally referenced resources, such as js, css and images, into
|
||||
a single file.
|
||||
|
||||
For exmample:
|
||||
|
||||
```html
|
||||
<link href="css/style.css?__inline=true" rel="stylesheet" />
|
||||
```
|
||||
|
||||
is replaced with
|
||||
|
||||
```html
|
||||
<style>
|
||||
/* contents of css/style.css */
|
||||
</style>
|
||||
```
|
||||
|
||||
JavaScript references are brought inline, and images in the html
|
||||
and css blocks are converted to base-64 data: urls.
|
||||
|
||||
By default, only urls marked with `__inline` are converted, however this
|
||||
behavior can be overrided via the `tag:` option.
|
||||
|
||||
|
||||
## Getting Started
|
||||
|
||||
This plugin requires Grunt `~0.4.1`
|
||||
|
||||
If you haven't used [Grunt](http://gruntjs.com/) before, be sure to check out the [Getting Started](http://gruntjs.com/getting-started) guide, as it explains how to create a [Gruntfile](http://gruntjs.com/sample-gruntfile) as well as install and use Grunt plugins. Once you're familiar with that process, you may install this plugin with this command:
|
||||
|
||||
```bash
|
||||
npm install grunt-inline --save-dev
|
||||
```
|
||||
|
||||
Once the plugin has been installed, it may be enabled inside your Gruntfile with this line of JavaScript:
|
||||
|
||||
```bash
|
||||
grunt.loadNpmTasks('grunt-inline');
|
||||
```
|
||||
|
||||
## The "grunt-inline" task
|
||||
|
||||
### Overview
|
||||
|
||||
In your project's Gruntfile, add a section named `inline` to the data object passed into `grunt.initConfig()`.
|
||||
|
||||
```javascript
|
||||
grunt.initConfig({
|
||||
inline: {
|
||||
dist: {
|
||||
src: 'src/index.html',
|
||||
dest: 'dist/index.html'
|
||||
}
|
||||
}
|
||||
});
|
||||
```
|
||||
|
||||
### Options
|
||||
|
||||
#### dest
|
||||
|
||||
If dest is assigned, the the source file will be copied to the destination path. eg:
|
||||
`src/index.html` will be processed and then copied to `dist/index.html`
|
||||
|
||||
```javascript
|
||||
grunt.initConfig({
|
||||
inline: {
|
||||
dist: {
|
||||
src: 'src/index.html',
|
||||
dest: 'dist/index.html'
|
||||
}
|
||||
}
|
||||
});
|
||||
```
|
||||
|
||||
### cssmin
|
||||
|
||||
If cssmin is assigned true, `.css` will be minified before inlined.
|
||||
|
||||
```javascript
|
||||
grunt.initConfig({
|
||||
inline: {
|
||||
dist: {
|
||||
options:{
|
||||
cssmin: true
|
||||
},
|
||||
src: 'src/index.html',
|
||||
dest: 'dist/index.html'
|
||||
}
|
||||
}
|
||||
});
|
||||
```
|
||||
|
||||
### tag (defaults to ```__inline```)
|
||||
|
||||
Only URLs that contain the value for ```tag``` will be inlined.
|
||||
Specify ```tag: ''``` to include all urls.
|
||||
|
||||
```javascript
|
||||
grunt.initConfig({
|
||||
inline: {
|
||||
dist: {
|
||||
options:{
|
||||
tag: ''
|
||||
},
|
||||
src: 'src/index.html',
|
||||
dest: 'dist/index.html']
|
||||
}
|
||||
}
|
||||
});
|
||||
```
|
||||
|
||||
|
||||
### inlineTagAttributes
|
||||
|
||||
Ability to add attributes string to inline tag.
|
||||
|
||||
```javascript
|
||||
grunt.initConfig({
|
||||
inline: {
|
||||
dist: {
|
||||
options:{
|
||||
inlineTagAttributes: {
|
||||
js: 'data-inlined="true"', // Adds <script data-inlined="true">...</script>
|
||||
css: 'data-inlined="true"' // Adds <style data-inlined="true">...</style>
|
||||
},
|
||||
src: 'src/index.html',
|
||||
dest: 'dist/index.html'
|
||||
}
|
||||
}
|
||||
}
|
||||
});
|
||||
```
|
||||
|
||||
### uglify
|
||||
|
||||
If uglify is assigned true, `.js` file will be minified before inlined.
|
||||
|
||||
```javascript
|
||||
grunt.initConfig({
|
||||
inline: {
|
||||
dist: {
|
||||
options:{
|
||||
uglify: true
|
||||
},
|
||||
src: 'src/index.html',
|
||||
dest: 'dist/index.html'
|
||||
}
|
||||
}
|
||||
});
|
||||
```
|
||||
|
||||
### exts
|
||||
|
||||
Setting an exts array allows multiple file extensions to be processed as
|
||||
html.
|
||||
|
||||
```javascript
|
||||
grunt.initConfig({
|
||||
inline: {
|
||||
dist: {
|
||||
options:{
|
||||
exts: ['jade'],
|
||||
uglify: true
|
||||
},
|
||||
src: 'src/index.jade',
|
||||
dest: 'dist/index.jade'
|
||||
}
|
||||
}
|
||||
});
|
||||
```
|
||||
|
||||
### Usage Examples
|
||||
|
||||
> config
|
||||
|
||||
```javascript
|
||||
grunt.initConfig({
|
||||
inline: {
|
||||
dist: {
|
||||
src: 'src/index.html'
|
||||
}
|
||||
}
|
||||
});
|
||||
```
|
||||
|
||||
>src/index.html
|
||||
|
||||
```html
|
||||
<html>
|
||||
<head>
|
||||
<title>demo</title>
|
||||
<link href="css/style.css?__inline=true" rel="stylesheet" />
|
||||
</head>
|
||||
<body>
|
||||
<img src="img/icon.png?__inline=true" />
|
||||
|
||||
<script src="js/erport.js?__inline=true"></script>
|
||||
</body>
|
||||
</html>
|
||||
```
|
||||
|
||||
after `grunt inline` was run, it will be something like
|
||||
|
||||
```html
|
||||
<html>
|
||||
<head>
|
||||
<title>demo</title>
|
||||
<style>
|
||||
.container{
|
||||
padding: 0;
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
<! -- base64, a terrible mass you know…so just show a little bit ...-->
|
||||
<img src="idata:image/png;base64..." />
|
||||
|
||||
<script>
|
||||
var Report = (function(){
|
||||
return {
|
||||
init: function(){
|
||||
}
|
||||
};
|
||||
})();
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
||||
```
|
||||
|
||||
#### inline tag
|
||||
|
||||
Suppose there is an `<inline>` tag in `index.html` like bellow
|
||||
|
||||
```html
|
||||
<!-- inline tag -->
|
||||
<inline src="test.html" />
|
||||
```
|
||||
|
||||
The content of `test.html` is
|
||||
|
||||
```html
|
||||
<p>I'm inline html</p>
|
||||
<span>hello world!</span>
|
||||
```
|
||||
|
||||
Then, after the `inline` task is run, the original content in `index.html` will be replaced with
|
||||
|
||||
```html
|
||||
<p>I'm inline html</p>
|
||||
<span>hello world!</span>
|
||||
```
|
||||
|
||||
## Contributing
|
||||
|
||||
In lieu of a formal styleguide, take care to maintain the existing coding style. Add unit tests for any new or changed functionality. Lint and test your code using [Grunt](http://gruntjs.com/).
|
||||
|
||||
## Release History
|
||||
* 2019-12-20 v0.3.7 document optimized: markdown style problems of README
|
||||
* 2015-01-09 v0.3.3 bug fix: when processing files of a folder and then copy the processed content to another destination, the original files are changed unexpectedly, as mentioned in this issue [Support file globbing for input and output](https://github.com/chyingp/grunt-inline/issues/35)
|
||||
* 2014-06-16 v0.3.1 bug fix: protocol-relative urls in css are messed up
|
||||
* 2014-06-15 v0.3.1 bug fix: when options.tag is '', then all img tags, whose src attribute has already been inlined will be matched.
|
||||
* 2014-05-19 v0.3.0 support for new options.exts
|
||||
* 2014-05-19 v0.2.9 bug fix: options.tag is assigned '', bug image url in css are not converted to base64 formate
|
||||
* 2014-03-06 v0.2.6 bug fix: script tags like <script src="index.js?__inline">\n</script> were not inlined
|
||||
* 2014-01-31 v0.2.3 radded tag option, encode url(..) images.
|
||||
* 2013-10-31 v0.2.2 bug fix: img urls like 'background: url(http://www.example.com/img/bg.png)' will be transformed to 'background: url(url(http://www.example.com/img/bg.png))'
|
||||
* 2013-10-30 v0.2.1 bug fix: when processing relative file path of img url in css stylesheet, forgot to transform "\" to "/" for windows users
|
||||
* 2013-10-30 v0.2.0 new feature: Support for minifing js、css when they ar inlined into html.
|
||||
* 2013-08-30 v0.1.9 bug fix: stylesheets ended with ">" cannot be inlined
|
||||
* 2013-09-02 v0.1.9 add feature: add options.dest to assign a destination path where the source file will be copied
|
||||
* 2013-09-02 v0.1.8 add feature: support for `<inline>` tag
|
40
build/plugins/grunt-inline/package.json
Normal file
40
build/plugins/grunt-inline/package.json
Normal file
|
@ -0,0 +1,40 @@
|
|||
{
|
||||
"author": {
|
||||
"name": "程序猿小卡",
|
||||
"email": "chyingp@gmail.com",
|
||||
"url": "https://github.com/chyingp"
|
||||
},
|
||||
"name": "grunt-inline",
|
||||
"description": "Inlines img, script and link tags into the same file.",
|
||||
"version": "0.3.7",
|
||||
"keywords": [
|
||||
"gruntplugin",
|
||||
"inline",
|
||||
"js",
|
||||
"css"
|
||||
],
|
||||
"main": "inline",
|
||||
"repository": {
|
||||
"type": "git",
|
||||
"url": "https://github.com/chyingp/grunt-inline.git"
|
||||
},
|
||||
"engines": {
|
||||
"node": ">=0.8.0"
|
||||
},
|
||||
"devDependencies": {
|
||||
"grunt-contrib-nodeunit": "^4.0.0",
|
||||
"grunt-contrib-clean": "^2.0.0",
|
||||
"grunt-contrib-htmlmin": "^3.1.0",
|
||||
"grunt": "^1.4.0"
|
||||
},
|
||||
"dependencies": {
|
||||
"uglify-js": "^3.15.1",
|
||||
"datauri": "^4.1.0",
|
||||
"clean-css": "^5.2.4"
|
||||
},
|
||||
"scripts": {
|
||||
"test": "grunt test"
|
||||
},
|
||||
"_id": "grunt-inline@0.1.0",
|
||||
"_from": "grunt-inline@~0.1.0"
|
||||
}
|
256
build/plugins/grunt-inline/tasks/inline.js
Normal file
256
build/plugins/grunt-inline/tasks/inline.js
Normal file
|
@ -0,0 +1,256 @@
|
|||
/*
|
||||
* grunt-inline
|
||||
* https://github.com/chyingp/grunt-inline
|
||||
*
|
||||
* Copyright (c) 2015 Auguest G. casper & IMWEB TEAM
|
||||
*/
|
||||
|
||||
'use strict';
|
||||
|
||||
module.exports = function(grunt) {
|
||||
|
||||
var path = require('path');
|
||||
var datauri = require('datauri');
|
||||
var UglifyJS = require("uglify-js");
|
||||
var CleanCSS = require('clean-css');
|
||||
|
||||
grunt.registerMultiTask('inline', "Replaces <link>, <script> and <img> tags to their inline contents", function() {
|
||||
|
||||
var options = this.options({tag: '__inline'}),
|
||||
uglify = !!options.uglify,
|
||||
cssmin = !!options.cssmin,
|
||||
relativeTo = this.options().relativeTo,
|
||||
exts = options.exts,
|
||||
dest = this.data.dest,
|
||||
isExpandedPair;
|
||||
|
||||
this.files.forEach(function(filePair){
|
||||
|
||||
isExpandedPair = filePair.orig.expand || false;
|
||||
|
||||
filePair.src.forEach(function(filepath){
|
||||
|
||||
var fileType = path.extname(filepath).replace(/^\./, '');
|
||||
var fileContent = grunt.file.read(filepath);
|
||||
var destFilepath = '';
|
||||
|
||||
grunt.log.write('Processing ' + filepath + '...')
|
||||
|
||||
if(fileType==='html' || (exts && exts.indexOf(fileType) > -1)){
|
||||
fileContent = html(filepath, fileContent, relativeTo, options);
|
||||
}else if(fileType==='css'){
|
||||
fileContent = css(filepath, fileContent, relativeTo, options);
|
||||
}
|
||||
|
||||
if(detectDestType(filePair.dest) === 'directory') {
|
||||
destFilepath = (isExpandedPair) ? filePair.dest : unixifyPath(path.join(filePair.dest, filepath));
|
||||
}else{
|
||||
destFilepath = filePair.dest || filepath;
|
||||
}
|
||||
|
||||
grunt.file.write(destFilepath, fileContent);
|
||||
grunt.log.ok()
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
function isRemotePath( url ){
|
||||
return url.match(/^'?https?:\/\//) || url.match(/^\/\//);
|
||||
}
|
||||
|
||||
function isBase64Path( url ){
|
||||
return url.match(/^'?data.*base64/);
|
||||
}
|
||||
|
||||
// code from grunt-contrib-copy, with a little modification
|
||||
function detectDestType(dest) {
|
||||
if (grunt.util._.endsWith(dest, '/')) {
|
||||
return 'directory';
|
||||
} else {
|
||||
return 'file';
|
||||
}
|
||||
}
|
||||
|
||||
function unixifyPath(filepath) {
|
||||
if (process.platform === 'win32') {
|
||||
return filepath.replace(/\\/g, '/');
|
||||
} else {
|
||||
return filepath;
|
||||
}
|
||||
}
|
||||
|
||||
// from grunt-text-replace.js in grunt-text-replace
|
||||
function getPathToDestination(pathToSource, pathToDestinationFile) {
|
||||
var isDestinationDirectory = (/\/$/).test(pathToDestinationFile);
|
||||
var fileName = path.basename(pathToSource);
|
||||
var newPathToDestination;
|
||||
if (typeof pathToDestinationFile === 'undefined') {
|
||||
newPathToDestination = pathToSource;
|
||||
} else {
|
||||
newPathToDestination = pathToDestinationFile + (isDestinationDirectory ? fileName : '');
|
||||
}
|
||||
return newPathToDestination;
|
||||
}
|
||||
|
||||
function html(filepath, fileContent, relativeTo, options){
|
||||
if(relativeTo){
|
||||
filepath = filepath.replace(/[^\/]+\//, relativeTo);
|
||||
}
|
||||
|
||||
fileContent = fileContent.replace(/<inline.+?src=["']([^"']+?)["']\s*?\/>/g, function(matchedWord, src){
|
||||
var ret = matchedWord;
|
||||
|
||||
if(isRemotePath(src) || !grunt.file.isPathAbsolute(src)){
|
||||
|
||||
var inlineFilePath = path.resolve( path.dirname(filepath), src );
|
||||
if( grunt.file.exists(inlineFilePath) ){
|
||||
ret = grunt.file.read( inlineFilePath );
|
||||
|
||||
// @otod need to be checked, add bye herbert
|
||||
var _more = src.match(/^(..\/)+/ig);
|
||||
if(_more = _more && _more[0]){
|
||||
var _addMore = function(){
|
||||
var _ret = arguments[0],_src = arguments[2];
|
||||
if(!_src.match(/^http\:\/\//)){
|
||||
_ret =arguments[1] + _more + arguments[2] + arguments[3];
|
||||
grunt.log.writeln('inline >含有相对目录进行替换操作,替换之后的路径:' + _ret );
|
||||
}
|
||||
return _ret;
|
||||
}
|
||||
ret = ret.replace(/(<script.+?src=["'])([^"']+?)(["'].*?><\/script>)/g,_addMore);
|
||||
}
|
||||
}else{
|
||||
grunt.log.error("Couldn't find " + inlineFilePath + '!');
|
||||
}
|
||||
}
|
||||
|
||||
return ret;
|
||||
}).replace(/<script.+?src=["']([^"']+?)["'].*?>\s*<\/script>/g, function(matchedWord, src){
|
||||
var ret = matchedWord;
|
||||
|
||||
if(!isRemotePath(src) && src.indexOf(options.tag)!=-1){
|
||||
var inlineFilePath = path.resolve( path.dirname(filepath), src ).replace(/\?.*$/, ''); // 将参数去掉
|
||||
if( grunt.file.exists(inlineFilePath) ) {
|
||||
const rawstr = grunt.file.read(inlineFilePath);
|
||||
let c = rawstr;
|
||||
|
||||
if ( options.uglify ) {
|
||||
const uglstr = UglifyJS.minify(rawstr);
|
||||
if ( uglstr.error == undefined )
|
||||
c = uglstr.code;
|
||||
else grunt.log.error("uglify error " + uglstr.code);
|
||||
}
|
||||
|
||||
ret = '<script>\n' + c + '\n</script>';
|
||||
}else{
|
||||
grunt.log.error("Couldn't find " + inlineFilePath + '!');
|
||||
}
|
||||
}
|
||||
grunt.log.debug('ret = : ' + ret +'\n');
|
||||
|
||||
return ret;
|
||||
|
||||
}).replace(/<link.+?href=["']([^"']+?)["'].*?\/?>/g, function(matchedWord, src){
|
||||
var ret = matchedWord;
|
||||
|
||||
if(!isRemotePath(src) && src.indexOf(options.tag)!=-1){
|
||||
|
||||
var inlineFilePath = path.resolve( path.dirname(filepath), src ).replace(/\?.*$/, ''); // 将参数去掉
|
||||
|
||||
if( grunt.file.exists(inlineFilePath) ){
|
||||
var styleSheetContent = grunt.file.read( inlineFilePath );
|
||||
ret = '<style>\n' + cssInlineToHtml(filepath, inlineFilePath, styleSheetContent, relativeTo, options) + '\n</style>';
|
||||
}else{
|
||||
grunt.log.error("Couldn't find " + inlineFilePath + '!');
|
||||
}
|
||||
}
|
||||
grunt.log.debug('ret = : ' + ret +'\n');
|
||||
|
||||
return ret;
|
||||
}).replace(/<img.+?src=["']([^"':]+?)["'].*?\/?\s*?>/g, function(matchedWord, src){
|
||||
var ret = matchedWord;
|
||||
|
||||
if(!grunt.file.isPathAbsolute(src) && src.indexOf(options.tag)!=-1){
|
||||
|
||||
var inlineFilePath = path.resolve( path.dirname(filepath), src ).replace(/\?.*$/, ''); // 将参数去掉
|
||||
|
||||
if( grunt.file.exists(inlineFilePath) ){
|
||||
ret = matchedWord.replace(src, (new datauri(inlineFilePath)).content);
|
||||
}else{
|
||||
grunt.log.error("Couldn't find " + inlineFilePath + '!');
|
||||
}
|
||||
}
|
||||
grunt.log.debug('ret = : ' + ret +'\n');
|
||||
|
||||
return ret;
|
||||
});
|
||||
|
||||
return fileContent;
|
||||
}
|
||||
|
||||
function css(filepath, fileContent, relativeTo, options) {
|
||||
if(relativeTo){
|
||||
filepath = filepath.replace(/[^\/]+\//g, relativeTo);
|
||||
}
|
||||
|
||||
fileContent = fileContent.replace(/url\(["']*([^)'"]+)["']*\)/g, function(matchedWord, imgUrl){
|
||||
var newUrl = imgUrl;
|
||||
var flag = imgUrl.indexOf(options.tag)!=-1; // urls like "img/bg.png?__inline" will be transformed to base64
|
||||
if(isBase64Path(imgUrl) || isRemotePath(imgUrl)){
|
||||
return matchedWord;
|
||||
}
|
||||
grunt.log.debug( 'imgUrl: '+imgUrl);
|
||||
grunt.log.debug( 'filepath: '+filepath);
|
||||
var absoluteImgurl = path.resolve( path.dirname(filepath),imgUrl );
|
||||
grunt.log.debug( 'absoluteImgurl: '+absoluteImgurl);
|
||||
newUrl = path.relative( path.dirname(filepath), absoluteImgurl );
|
||||
grunt.log.debug( 'newUrl: '+newUrl);
|
||||
|
||||
absoluteImgurl = absoluteImgurl.replace(/\?.*$/, '');
|
||||
if(flag && grunt.file.exists(absoluteImgurl)){
|
||||
newUrl = datauri(absoluteImgurl);
|
||||
}else{
|
||||
newUrl = newUrl.replace(/\\/g, '/');
|
||||
}
|
||||
|
||||
return matchedWord.replace(imgUrl, newUrl);
|
||||
});
|
||||
fileContent = options.cssmin ? CleanCSS.process(fileContent) : fileContent;
|
||||
|
||||
return fileContent;
|
||||
}
|
||||
|
||||
function cssInlineToHtml(htmlFilepath, filepath, fileContent, relativeTo, options) {
|
||||
if(relativeTo){
|
||||
filepath = filepath.replace(/[^\/]+\//g, relativeTo);
|
||||
}
|
||||
|
||||
fileContent = fileContent.replace(/url\(["']*([^)'"]+)["']*\)/g, function(matchedWord, imgUrl){
|
||||
var newUrl = imgUrl;
|
||||
var flag = !!imgUrl.match(/\?__inline/); // urls like "img/bg.png?__inline" will be transformed to base64
|
||||
grunt.log.debug('flag:'+flag);
|
||||
if(isBase64Path(imgUrl) || isRemotePath(imgUrl)){
|
||||
return matchedWord;
|
||||
}
|
||||
grunt.log.debug( 'imgUrl: '+imgUrl);
|
||||
grunt.log.debug( 'filepath: '+filepath);
|
||||
var absoluteImgurl = path.resolve( path.dirname(filepath),imgUrl ); // img url relative to project root
|
||||
grunt.log.debug( 'absoluteImgurl: '+absoluteImgurl);
|
||||
newUrl = path.relative( path.dirname(htmlFilepath), absoluteImgurl ); // img url relative to the html file
|
||||
grunt.log.debug([htmlFilepath, filepath, absoluteImgurl, imgUrl]);
|
||||
grunt.log.debug( 'newUrl: '+newUrl);
|
||||
|
||||
absoluteImgurl = absoluteImgurl.replace(/\?.*$/, '');
|
||||
if(flag && grunt.file.exists(absoluteImgurl)){
|
||||
newUrl = datauri(absoluteImgurl);
|
||||
}else{
|
||||
newUrl = newUrl.replace(/\\/g, '/');
|
||||
}
|
||||
|
||||
return matchedWord.replace(imgUrl, newUrl);
|
||||
});
|
||||
fileContent = options.cssmin ? CleanCSS.process(fileContent) : fileContent;
|
||||
|
||||
return fileContent;
|
||||
}
|
||||
};
|
13
build/plugins/grunt-inline/test/dist/css.html
vendored
Normal file
13
build/plugins/grunt-inline/test/dist/css.html
vendored
Normal file
|
@ -0,0 +1,13 @@
|
|||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<title>test</title>
|
||||
<!-- ended with "/>" -->
|
||||
<link href="styles/main.css?__inline=true" rel="stylesheet" />
|
||||
|
||||
<!-- ended with ">" -->
|
||||
<link href="styles/main.css?__inline=true" rel="stylesheet">
|
||||
</head>
|
||||
<body>
|
||||
</body>
|
||||
</html>
|
9
build/plugins/grunt-inline/test/dist/css_greedy.html
vendored
Normal file
9
build/plugins/grunt-inline/test/dist/css_greedy.html
vendored
Normal file
|
@ -0,0 +1,9 @@
|
|||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<title>test</title>
|
||||
<link href="styles/main.css?__inline=true" rel="stylesheet" /><link href="styles/main.css?__inline=true" rel="stylesheet">
|
||||
</head>
|
||||
<body>
|
||||
</body>
|
||||
</html>
|
10
build/plugins/grunt-inline/test/dist/html.html
vendored
Normal file
10
build/plugins/grunt-inline/test/dist/html.html
vendored
Normal file
|
@ -0,0 +1,10 @@
|
|||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<title>test</title>
|
||||
</head>
|
||||
<body>
|
||||
<!-- inline html -->
|
||||
<inline src="html/test.html" />
|
||||
</body>
|
||||
</html>
|
1
build/plugins/grunt-inline/test/dist/html/test.html
vendored
Normal file
1
build/plugins/grunt-inline/test/dist/html/test.html
vendored
Normal file
|
@ -0,0 +1 @@
|
|||
<p>test</p>
|
9
build/plugins/grunt-inline/test/dist/html_greedy.html
vendored
Normal file
9
build/plugins/grunt-inline/test/dist/html_greedy.html
vendored
Normal file
|
@ -0,0 +1,9 @@
|
|||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<title>test</title>
|
||||
</head>
|
||||
<body>
|
||||
<inline src="html/test.html" /><inline src="html/test.html" />
|
||||
</body>
|
||||
</html>
|
10
build/plugins/grunt-inline/test/dist/img.html
vendored
Normal file
10
build/plugins/grunt-inline/test/dist/img.html
vendored
Normal file
|
@ -0,0 +1,10 @@
|
|||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<title>test</title>
|
||||
</head>
|
||||
<body>
|
||||
<!-- inline image -->
|
||||
<img src="img/icon.png?__inline=true" />
|
||||
</body>
|
||||
</html>
|
BIN
build/plugins/grunt-inline/test/dist/img/icon.png
vendored
Normal file
BIN
build/plugins/grunt-inline/test/dist/img/icon.png
vendored
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.4 KiB |
9
build/plugins/grunt-inline/test/dist/img_greedy.html
vendored
Normal file
9
build/plugins/grunt-inline/test/dist/img_greedy.html
vendored
Normal file
|
@ -0,0 +1,9 @@
|
|||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<title>test</title>
|
||||
</head>
|
||||
<body>
|
||||
<img src="img/icon.png?__inline=true" /><img src="img/icon.png?__inline=true" />
|
||||
</body>
|
||||
</html>
|
1
build/plugins/grunt-inline/test/dist/js/export.js
vendored
Normal file
1
build/plugins/grunt-inline/test/dist/js/export.js
vendored
Normal file
|
@ -0,0 +1 @@
|
|||
console.log('test');
|
9
build/plugins/grunt-inline/test/dist/script.html
vendored
Normal file
9
build/plugins/grunt-inline/test/dist/script.html
vendored
Normal file
|
@ -0,0 +1,9 @@
|
|||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<title>test</title>
|
||||
<script src="js/export.js?__inline=true"></script>
|
||||
</head>
|
||||
<body>
|
||||
</body>
|
||||
</html>
|
9
build/plugins/grunt-inline/test/dist/script_greedy.html
vendored
Normal file
9
build/plugins/grunt-inline/test/dist/script_greedy.html
vendored
Normal file
|
@ -0,0 +1,9 @@
|
|||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<title>test</title>
|
||||
<script src="js/export.js?__inline=true"></script><script src="js/export.js?__inline=true"></script>
|
||||
</head>
|
||||
<body>
|
||||
</body>
|
||||
</html>
|
6
build/plugins/grunt-inline/test/dist/styles/main.css
vendored
Normal file
6
build/plugins/grunt-inline/test/dist/styles/main.css
vendored
Normal file
|
@ -0,0 +1,6 @@
|
|||
.main{border: none;}
|
||||
body{background: url(http://www.example.com/img/bg.png);}
|
||||
body{background: url('http://www.example.com/img/bg.png');}
|
||||
body{background: url('../img/icon.png?__inline=true');}
|
||||
body{background: url()
|
||||
body{background: url('')
|
11
build/plugins/grunt-inline/test/expected/css.min.html
Normal file
11
build/plugins/grunt-inline/test/expected/css.min.html
Normal file
|
@ -0,0 +1,11 @@
|
|||
<!DOCTYPE html><html><head><title>test</title><style>.main{border: none;}
|
||||
body{background: url(http://www.example.com/img/bg.png);}
|
||||
body{background: url('http://www.example.com/img/bg.png');}
|
||||
body{background: url('');}
|
||||
body{background: url()
|
||||
body{background: url('')</style><style>.main{border: none;}
|
||||
body{background: url(http://www.example.com/img/bg.png);}
|
||||
body{background: url('http://www.example.com/img/bg.png');}
|
||||
body{background: url('');}
|
||||
body{background: url()
|
||||
body{background: url('')</style></head><body></body></html>
|
11
build/plugins/grunt-inline/test/expected/css_greedy.min.html
Normal file
11
build/plugins/grunt-inline/test/expected/css_greedy.min.html
Normal file
|
@ -0,0 +1,11 @@
|
|||
<!DOCTYPE html><html><head><title>test</title><style>.main{border: none;}
|
||||
body{background: url(http://www.example.com/img/bg.png);}
|
||||
body{background: url('http://www.example.com/img/bg.png');}
|
||||
body{background: url('');}
|
||||
body{background: url()
|
||||
body{background: url('')</style><style>.main{border: none;}
|
||||
body{background: url(http://www.example.com/img/bg.png);}
|
||||
body{background: url('http://www.example.com/img/bg.png');}
|
||||
body{background: url('');}
|
||||
body{background: url()
|
||||
body{background: url('')</style></head><body></body></html>
|
1
build/plugins/grunt-inline/test/expected/html.min.html
Normal file
1
build/plugins/grunt-inline/test/expected/html.min.html
Normal file
|
@ -0,0 +1 @@
|
|||
<!DOCTYPE html><html><head><title>test</title></head><body><p>test</p></body></html>
|
|
@ -0,0 +1 @@
|
|||
<!DOCTYPE html><html><head><title>test</title></head><body><p>test</p><p>test</p></body></html>
|
1
build/plugins/grunt-inline/test/expected/img.min.html
Normal file
1
build/plugins/grunt-inline/test/expected/img.min.html
Normal file
|
@ -0,0 +1 @@
|
|||
<!DOCTYPE html><html><head><title>test</title></head><body><img src=""></body></html>
|
|
@ -0,0 +1 @@
|
|||
<!DOCTYPE html><html><head><title>test</title></head><body><img src=""><img src=""></body></html>
|
1
build/plugins/grunt-inline/test/expected/script.min.html
Normal file
1
build/plugins/grunt-inline/test/expected/script.min.html
Normal file
|
@ -0,0 +1 @@
|
|||
<!DOCTYPE html><html><head><title>test</title><script>console.log('test');</script></head><body></body></html>
|
|
@ -0,0 +1 @@
|
|||
<!DOCTYPE html><html><head><title>test</title><script>console.log('test');</script><script>console.log('test');</script></head><body></body></html>
|
48
build/plugins/grunt-inline/test/greedy_test.js
Normal file
48
build/plugins/grunt-inline/test/greedy_test.js
Normal file
|
@ -0,0 +1,48 @@
|
|||
var grunt = require('grunt');
|
||||
var fs = require('fs');
|
||||
|
||||
function readFile(file) {
|
||||
'use strict';
|
||||
|
||||
var contents = grunt.file.read(file);
|
||||
|
||||
if (process.platform === 'win32') {
|
||||
contents = contents.replace(/\r\n/g, '\n');
|
||||
}
|
||||
|
||||
return contents;
|
||||
}
|
||||
|
||||
function assertFileEquality(test, pathToActual, pathToExpected, message) {
|
||||
var actual = readFile(pathToActual);
|
||||
var expected = readFile(pathToExpected);
|
||||
test.equal(expected, actual, message);
|
||||
}
|
||||
|
||||
exports.inline = function(test) {
|
||||
'use strict';
|
||||
|
||||
test.expect(4);
|
||||
|
||||
assertFileEquality(test,
|
||||
'tmp/img_greedy.min.html',
|
||||
'test/expected/img_greedy.min.html',
|
||||
'Should compile two image target without newline characters');
|
||||
|
||||
assertFileEquality(test,
|
||||
'tmp/css_greedy.min.html',
|
||||
'test/expected/css_greedy.min.html',
|
||||
'Should compile two link target without newline characters');
|
||||
|
||||
assertFileEquality(test,
|
||||
'tmp/html_greedy.min.html',
|
||||
'test/expected/html_greedy.min.html',
|
||||
'Should compile two inline target without newline characters');
|
||||
|
||||
assertFileEquality(test,
|
||||
'tmp/script_greedy.min.html',
|
||||
'test/expected/script_greedy.min.html',
|
||||
'Should compile two script target without newline characters');
|
||||
|
||||
test.done();
|
||||
};
|
48
build/plugins/grunt-inline/test/inline_test.js
Normal file
48
build/plugins/grunt-inline/test/inline_test.js
Normal file
|
@ -0,0 +1,48 @@
|
|||
var grunt = require('grunt');
|
||||
var fs = require('fs');
|
||||
|
||||
function readFile(file) {
|
||||
'use strict';
|
||||
|
||||
var contents = grunt.file.read(file);
|
||||
|
||||
if (process.platform === 'win32') {
|
||||
contents = contents.replace(/\r\n/g, '\n');
|
||||
}
|
||||
|
||||
return contents;
|
||||
}
|
||||
|
||||
function assertFileEquality(test, pathToActual, pathToExpected, message) {
|
||||
var actual = readFile(pathToActual);
|
||||
var expected = readFile(pathToExpected);
|
||||
test.equal(expected, actual, message);
|
||||
}
|
||||
|
||||
exports.inline = function(test) {
|
||||
'use strict';
|
||||
|
||||
test.expect(4);
|
||||
|
||||
assertFileEquality(test,
|
||||
'tmp/css.min.html',
|
||||
'test/expected/css.min.html',
|
||||
'Should compile css inline');
|
||||
|
||||
assertFileEquality(test,
|
||||
'tmp/img.min.html',
|
||||
'test/expected/img.min.html',
|
||||
'Should compile image inline');
|
||||
|
||||
assertFileEquality(test,
|
||||
'tmp/html.min.html',
|
||||
'test/expected/html.min.html',
|
||||
'Should compile html inline');
|
||||
|
||||
assertFileEquality(test,
|
||||
'tmp/script.min.html',
|
||||
'test/expected/script.min.html',
|
||||
'Should compile script inline');
|
||||
|
||||
test.done();
|
||||
};
|
Loading…
Reference in a new issue