-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: add image optimization preset (#84)
* add imagemin plugin and optimize preset also remove pngquant and svgo * weird autocomplete * fix imagemin impl * update docs * update lockfile
- Loading branch information
Showing
20 changed files
with
875 additions
and
703 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
# imagemin | ||
|
||
A plugin to optimize your images. | ||
|
||
## Install | ||
|
||
npm i magefront-plugin-imagemin --save-dev | ||
|
||
## Usage | ||
|
||
```js | ||
import imagemin from 'magefront-plugin-imagemin' | ||
|
||
export default { | ||
plugins: [ | ||
imagemin() | ||
] | ||
} | ||
``` | ||
|
||
## Options | ||
|
||
### `src` | ||
|
||
The source images to minify. Default is `**/*.{jpg,jpeg,png,gif,svg}`. | ||
|
||
### `ignore` | ||
|
||
A list of paths to ignore. | ||
|
||
### `plugins` | ||
|
||
A list of plugins to use. |
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,31 @@ | ||
# Optimize preset | ||
|
||
An additional preset to optimize your assets. | ||
|
||
It supports the following image formats: | ||
|
||
- jpg | ||
- png | ||
- gif | ||
- svg | ||
- webp | ||
|
||
## Install | ||
|
||
npm i magefront-preset-optimize --save-dev | ||
|
||
## Usage | ||
|
||
```js | ||
import optimizePreset from 'magefront-preset-optimize' | ||
|
||
export default { | ||
presets: [ | ||
optimizePreset() | ||
] | ||
} | ||
``` | ||
|
||
## Plugins | ||
|
||
- [magefront-plugin-imagemin](plugins/imagemin.md) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
# magefront-plugin-imagemin | ||
|
||
Optimize images with [imagemin](https://github.com/imagemin/imagemin). | ||
|
||
## Install | ||
|
||
npm i magefront-plugin-imagemin | ||
|
||
## Usage | ||
|
||
```js | ||
import imagemin from 'magefront-plugin-imagemin' | ||
|
||
export default { | ||
plugins: [imagemin()], | ||
} | ||
``` | ||
|
||
See the [documentation](https://ubermanu.github.io/magefront/#/plugins/imagemin) for more information. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,46 @@ | ||
import glob, { type Pattern } from 'fast-glob' | ||
import type { Plugin as ImageMinPlugin } from 'imagemin' | ||
import imagemin from 'imagemin' | ||
import type { Plugin } from 'magefront' | ||
import fs from 'node:fs/promises' | ||
import path from 'node:path' | ||
|
||
export interface Options { | ||
src?: string | string[] | ||
ignore?: Pattern[] | ||
dest?: string | ||
plugins?: ImageMinPlugin[] | ||
} | ||
|
||
/** Optimizes images using imagemin. */ | ||
export default (options?: Options): Plugin => { | ||
const { src, ignore, dest, plugins = [] } = { ...options } | ||
|
||
return async (context) => { | ||
const files = await glob(src ?? '**/*.{jpg,jpeg,png,gif,svg}', { | ||
cwd: context.src, | ||
ignore, | ||
}) | ||
|
||
const result = await imagemin( | ||
files.map((file) => path.join(context.src, file)), | ||
{ | ||
plugins, | ||
} | ||
) | ||
|
||
context.logger.info(`Optimized ${result.length} images.`) | ||
|
||
// For each optimized image, write it to the destination. | ||
await Promise.all( | ||
result.map(async (file) => { | ||
// Remove the absolute context.src path from the file's source path. | ||
const sourcePath = path.relative(context.src, file.sourcePath) | ||
const filePath = path.join(context.src, dest ?? '', sourcePath) | ||
|
||
// Write the optimized image to the destination. | ||
await fs.writeFile(filePath, file.data, 'utf8') | ||
}) | ||
) | ||
} | ||
} |
File renamed without changes.
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
Oops, something went wrong.