webp-loader
Advanced tools
Comparing version 0.1.1 to 0.2.0
57
index.js
@@ -7,53 +7,28 @@ // Copyright (C) 2016 Max Riveiro <kavu13@gmail.com> | ||
var Imagemin = require('imagemin'); | ||
var imagemin = require('imagemin'); | ||
var imageminWebp = require('imagemin-webp'); | ||
var loaderUtils = require('loader-utils'); | ||
module.exports = function(content) { | ||
module.exports = function (content) { | ||
this.cacheable && this.cacheable(); | ||
var query = loaderUtils.getOptions(this) || {}; | ||
var configKey = query.config || 'webpLoader'; | ||
var config = this.options[configKey] || {}; | ||
var callback = this.async(); | ||
var called = false; | ||
var query = loaderUtils.parseQuery(this.query); | ||
var options = { | ||
preset: query.preset || 'default', | ||
quality: query.quality || 75, | ||
alphaQuality: query.alphaQuality || 100, | ||
method: query.method || 1, | ||
sns: query.sns || 80, | ||
autoFilter: query.autoFilter || false, | ||
sharpness: query.sharpness || 0, | ||
lossless: query.lossless || false, | ||
bypassOnDebug: query.bypassOnDebug || false, | ||
}; | ||
if (query.size) { | ||
options.size = query.size; | ||
} | ||
if (query.filter) { | ||
options.filter = query.filter; | ||
} | ||
if (this.debug === true && options.bypassOnDebug === true) { | ||
if (this.debug === true && config.bypassOnDebug === true) { | ||
return callback(null, content); | ||
} else { | ||
var imagemin = new Imagemin() | ||
.src(content) | ||
.use(imageminWebp(options)); | ||
imagemin.run(function(err, files) { | ||
if (called) { | ||
return; | ||
} | ||
called = true; | ||
if (err) { | ||
imagemin | ||
.buffer(content,{ | ||
plugins: imageminWebp(config) | ||
}) | ||
.then(function(data){ | ||
callback(null, data); | ||
}) | ||
.catch(function(err){ | ||
callback(err); | ||
} else { | ||
callback(null, files[0].contents); | ||
} | ||
}); | ||
}); | ||
} | ||
@@ -60,0 +35,0 @@ }; |
{ | ||
"name": "webp-loader", | ||
"version": "0.1.1", | ||
"version": "0.2.0", | ||
"description": "WebP image loader & converter for Webpack", | ||
"main": "index.js", | ||
"scripts": { | ||
"test": "webpack -d --config test/webpack.config.js", | ||
"lint": "eslint index.js" | ||
"test": "npm run lint && npm run test:webpack1 && npm run test:webpack2 && npm run test:webpack3", | ||
"lint": "npm i && node_modules/.bin/eslint index.js test/*.js", | ||
"test:webpack1": "WEBPACK_VERSION=1.x ./scripts/test.sh", | ||
"test:webpack2": "WEBPACK_VERSION=2.x ./scripts/test.sh", | ||
"test:webpack3": "WEBPACK_VERSION=3.x ./scripts/test.sh" | ||
}, | ||
@@ -26,16 +29,17 @@ "repository": { | ||
"dependencies": { | ||
"imagemin": "^4.0.0", | ||
"imagemin-webp": "^3.1.0", | ||
"loader-utils": "^0.2.12" | ||
"imagemin": "^5.3.1", | ||
"imagemin-webp": "^4.0.0", | ||
"loader-utils": "^1.1.0" | ||
}, | ||
"devDependencies": { | ||
"eslint": "^1.10.3", | ||
"eslint-plugin-nodeca": "^1.0.3", | ||
"file-loader": "^0.8.5", | ||
"multi-loader": "^0.1.0", | ||
"webpack": "^1.12.10" | ||
"eslint": "^4.1.1", | ||
"file-loader": "^0.11.2", | ||
"multi-loader": "^0.1.0" | ||
}, | ||
"engines": { | ||
"node": ">=0.6" | ||
}, | ||
"peerDependencies": { | ||
"webpack": "*" | ||
} | ||
} |
# webp-loader | ||
[![Build Status](https://travis-ci.org/kavu/webp-loader.svg?branch=master)](https://travis-ci.org/kavu/webp-loader) | ||
[WebP](https://developers.google.com/speed/webp/) image loader & converter loader for Webpack. | ||
@@ -20,4 +22,4 @@ | ||
loaders: [ | ||
'file', | ||
'webp' | ||
'file-loader', | ||
'webp-loader' | ||
] | ||
@@ -35,3 +37,3 @@ } | ||
loaders: [ | ||
'file', | ||
'file-loader', | ||
'webp?{quality: 13}' | ||
@@ -43,3 +45,3 @@ ] | ||
Normally you don't want to convert all of your images to WebP format, you just want to make alternate versions. You can use [multi-loader](https://github.com/webpack/multi-loader) to achieve it: | ||
Normally you don't want to convert all of your images to WebP format, you just want to make alternate versions. You can use [multi-loader](https://github.com/webpack-contrib/multi-loader) to achieve it: | ||
@@ -51,4 +53,4 @@ ```javascript | ||
loader: multi( | ||
'file?name=[name].[ext].webp!webp?{quality: 95}' | ||
'file?name=[name].[ext]', | ||
'file-loader?name=[name].[ext].webp!webp?{quality: 95}' | ||
'file-loader?name=[name].[ext]', | ||
) | ||
@@ -55,0 +57,0 @@ }, |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Deprecated
MaintenanceThe maintainer of the package marked it as deprecated. This could indicate that a single version should not be used, or that the package is no longer maintained and any new vulnerabilities will not be fixed.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
85488
3
10
68
4
32
1
+ Added@jridgewell/gen-mapping@0.3.5(transitive)
+ Added@jridgewell/resolve-uri@3.1.2(transitive)
+ Added@jridgewell/set-array@1.2.1(transitive)
+ Added@jridgewell/source-map@0.3.6(transitive)
+ Added@jridgewell/sourcemap-codec@1.5.0(transitive)
+ Added@jridgewell/trace-mapping@0.3.25(transitive)
+ Added@types/estree@1.0.6(transitive)
+ Added@types/json-schema@7.0.15(transitive)
+ Added@types/node@22.6.1(transitive)
+ Added@webassemblyjs/ast@1.12.1(transitive)
+ Added@webassemblyjs/floating-point-hex-parser@1.11.6(transitive)
+ Added@webassemblyjs/helper-api-error@1.11.6(transitive)
+ Added@webassemblyjs/helper-buffer@1.12.1(transitive)
+ Added@webassemblyjs/helper-numbers@1.11.6(transitive)
+ Added@webassemblyjs/helper-wasm-bytecode@1.11.6(transitive)
+ Added@webassemblyjs/helper-wasm-section@1.12.1(transitive)
+ Added@webassemblyjs/ieee754@1.11.6(transitive)
+ Added@webassemblyjs/leb128@1.11.6(transitive)
+ Added@webassemblyjs/utf8@1.11.6(transitive)
+ Added@webassemblyjs/wasm-edit@1.12.1(transitive)
+ Added@webassemblyjs/wasm-gen@1.12.1(transitive)
+ Added@webassemblyjs/wasm-opt@1.12.1(transitive)
+ Added@webassemblyjs/wasm-parser@1.12.1(transitive)
+ Added@webassemblyjs/wast-printer@1.12.1(transitive)
+ Added@xtuc/ieee754@1.2.0(transitive)
+ Added@xtuc/long@4.2.2(transitive)
+ Addedacorn@8.12.1(transitive)
+ Addedacorn-import-attributes@1.9.5(transitive)
+ Addedajv@6.12.6(transitive)
+ Addedajv-keywords@3.5.2(transitive)
+ Addedarray-union@1.0.2(transitive)
+ Addedbig.js@5.2.2(transitive)
+ Addedbrowserslist@4.23.3(transitive)
+ Addedcaniuse-lite@1.0.30001663(transitive)
+ Addedchrome-trace-event@1.0.4(transitive)
+ Addedcross-spawn@5.1.0(transitive)
+ Addedcwebp-bin@4.0.0(transitive)
+ Addedelectron-to-chromium@1.5.27(transitive)
+ Addedemojis-list@3.0.0(transitive)
+ Addedenhanced-resolve@5.17.1(transitive)
+ Addedes-module-lexer@1.5.4(transitive)
+ Addedescalade@3.2.0(transitive)
+ Addedeslint-scope@5.1.1(transitive)
+ Addedesrecurse@4.3.0(transitive)
+ Addedestraverse@4.3.05.3.0(transitive)
+ Addedevents@3.3.0(transitive)
+ Addedexec-buffer@3.2.0(transitive)
+ Addedexeca@0.7.0(transitive)
+ Addedfast-deep-equal@3.1.3(transitive)
+ Addedfast-json-stable-stringify@2.1.0(transitive)
+ Addedfile-type@4.4.0(transitive)
+ Addedget-stream@3.0.0(transitive)
+ Addedglob-to-regexp@0.4.1(transitive)
+ Addedglobby@6.1.0(transitive)
+ Addedhas-flag@4.0.0(transitive)
+ Addedimagemin@5.3.1(transitive)
+ Addedimagemin-webp@4.1.0(transitive)
+ Addedis-cwebp-readable@2.0.1(transitive)
+ Addedisexe@2.0.0(transitive)
+ Addedjest-worker@27.5.1(transitive)
+ Addedjson-parse-even-better-errors@2.3.1(transitive)
+ Addedjson-schema-traverse@0.4.1(transitive)
+ Addedjson5@1.0.2(transitive)
+ Addedloader-runner@4.3.0(transitive)
+ Addedloader-utils@1.4.2(transitive)
+ Addedlru-cache@4.1.5(transitive)
+ Addedmake-dir@1.3.0(transitive)
+ Addedmerge-stream@2.0.0(transitive)
+ Addedmime-db@1.52.0(transitive)
+ Addedmime-types@2.1.35(transitive)
+ Addedneo-async@2.6.2(transitive)
+ Addednode-releases@2.0.18(transitive)
+ Addednpm-run-path@2.0.2(transitive)
+ Addedp-finally@1.0.0(transitive)
+ Addedp-pipe@1.2.0(transitive)
+ Addedpath-key@2.0.1(transitive)
+ Addedpicocolors@1.1.0(transitive)
+ Addedpify@3.0.0(transitive)
+ Addedpseudomap@1.0.2(transitive)
+ Addedpunycode@2.3.1(transitive)
+ Addedrandombytes@2.1.0(transitive)
+ Addedreplace-ext@1.0.1(transitive)
+ Addedschema-utils@3.3.0(transitive)
+ Addedserialize-javascript@6.0.2(transitive)
+ Addedshebang-command@1.2.0(transitive)
+ Addedshebang-regex@1.0.0(transitive)
+ Addedsource-map@0.6.1(transitive)
+ Addedsource-map-support@0.5.21(transitive)
+ Addedstrip-eof@1.0.0(transitive)
+ Addedsupports-color@8.1.1(transitive)
+ Addedtapable@2.2.1(transitive)
+ Addedtemp-dir@1.0.0(transitive)
+ Addedtempfile@2.0.0(transitive)
+ Addedterser@5.33.0(transitive)
+ Addedterser-webpack-plugin@5.3.10(transitive)
+ Addedundici-types@6.19.8(transitive)
+ Addedupdate-browserslist-db@1.1.0(transitive)
+ Addeduri-js@4.4.1(transitive)
+ Addeduuid@3.4.0(transitive)
+ Addedwatchpack@2.4.2(transitive)
+ Addedwebpack@5.94.0(transitive)
+ Addedwebpack-sources@3.2.3(transitive)
+ Addedwhich@1.3.1(transitive)
+ Addedyallist@2.1.2(transitive)
- Removedargparse@1.0.10(transitive)
- Removedbig.js@3.2.0(transitive)
- Removedclap@1.2.3(transitive)
- Removedcoa@1.0.4(transitive)
- Removedcolors@1.1.2(transitive)
- Removedcsso@2.0.0(transitive)
- Removedcwebp-bin@3.2.0(transitive)
- Removedemojis-list@2.1.0(transitive)
- Removedesprima@2.7.3(transitive)
- Removedexec-buffer@2.0.1(transitive)
- Removedgifsicle@3.0.4(transitive)
- Removedimagemin@4.0.0(transitive)
- Removedimagemin-gifsicle@4.2.0(transitive)
- Removedimagemin-jpegtran@4.3.2(transitive)
- Removedimagemin-optipng@4.3.0(transitive)
- Removedimagemin-svgo@4.2.1(transitive)
- Removedimagemin-webp@3.1.1(transitive)
- Removedis-cwebp-readable@1.0.3(transitive)
- Removedis-gif@1.0.0(transitive)
- Removedis-jpg@1.0.1(transitive)
- Removedis-png@1.1.0(transitive)
- Removedis-svg@1.1.1(transitive)
- Removedjpegtran-bin@3.2.0(transitive)
- Removedjs-yaml@3.6.1(transitive)
- Removedjson5@0.5.1(transitive)
- Removedloader-utils@0.2.17(transitive)
- Removedoptional@0.1.4(transitive)
- Removedoptipng-bin@3.1.4(transitive)
- Removedq@1.5.1(transitive)
- Removedsax@1.2.4(transitive)
- Removedsource-map@0.5.7(transitive)
- Removedsprintf-js@1.0.3(transitive)
- Removedsvgo@0.6.6(transitive)
- Removedwhet.extend@0.9.9(transitive)
Updatedimagemin@^5.3.1
Updatedimagemin-webp@^4.0.0
Updatedloader-utils@^1.1.0