UNPKG

@otterlord/astro-compress

Version:

🗜️ AstroJS compression utilities. Compress HTML, CSS, JavaScript and more!

253 lines (188 loc) 5.1 kB
# [astro-compress] 🗜️ > **WARNING** > As of now, this library is not maintained. Please look for suitable alternatives. This **[Astro integration][astro-integration]** brings compression utilities to your Astro project. [CSS][csso] [HTML][html-minifier-terser] [JavaScript][terser] [Images][sharp] [SVG][svgo] > **Note** > > `astro-compress` will not compress your requests, only your statically > generated build and pre-rendered routes. > **Note** > > Use `astro-compress` last in your integration list for the best optimizations. ## Installation There are two ways to add integrations to your project. Let's try the most convenient option first! ### `astro add` command Astro includes a CLI tool for adding first party integrations: `astro add`. This command will: 1. (Optionally) Install all necessary dependencies and peer dependencies 2. (Also optionally) Update your `astro.config.*` file to apply this integration To install `astro-compress`, run the following from your project directory and follow the prompts: Using NPM: ```sh npx astro add astro-compress ``` Using Yarn: ```sh yarn astro add astro-compress ``` Using PNPM: ```sh pnpx astro add astro-compress ``` ### Install dependencies manually First, install the `astro-compress` integration like so: ``` npm install -D -E astro-compress ``` Then, apply this integration to your `astro.config.*` file using the `integrations` property: **`astro.config.ts`** ```ts import compress from "astro-compress"; export default { integrations: [compress()] }; ``` ## Getting started The utility will now automatically compress all your CSS, HTML, SVG, JavaScript and image files in the `dist` folder. The following image file types will be compressed via [sharp]: - avci - avcs - avif - avifs - gif - heic - heics - heif - heifs - jfif - jif - jpe - jpeg - jpg - apng - png - raw - tiff - webp SVG compression is supported via [svgo]. #### You can override any of the default options from the configurations of: - [csso](https://github.com/css/csso#minifysource-options) - [html-minifier-terser](https://github.com/terser/html-minifier-terser#options-quick-reference) - [sharp](https://sharp.pixelplumbing.com/api-output#jpeg) - [svgo](https://github.com/svg/svgo#configuration) - [terser](https://github.com/terser/terser#minify-options-structure) or disable them entirely: **`astro.config.ts`** ```ts import compress from "astro-compress"; export default { integrations: [ compress({ css: false, html: false, img: false, js: false, svg: false, }), ], }; ``` #### If your path is different than `dist` be sure to update it accordingly: **`astro.config.ts`** ```ts import compress from "astro-compress"; export default { outDir: "./build", integrations: [ compress({ path: "./build", }), ], }; ``` #### You can add multiple paths to compress by specifying an array as the `path` variable. **`astro.config.ts`** ```ts import compress from "astro-compress"; export default { integrations: [ compress({ path: ["./build", "./dist"], }), ], }; ``` #### You can also provide a map of paths for different input output directories. **`astro.config.ts`** ```ts import compress from "astro-compress"; export default { integrations: [ compress({ path: new Map([["./input", "./output"]]), }), ], }; ``` #### Or an array of the two. **`astro.config.ts`** ```ts import compress from "astro-compress"; export default { integrations: [ compress({ path: [ // Compress dist "./dist", // Compress dist one more time into a different directory new Map([["./dist", "./dist-compressed"]]), ], }), ], }; ``` #### You can provide a filter to exclude files in your build. A filter can be an array of regexes or a single match. You can use functions, as well to match on file names. **`astro.config.ts`** ```ts import compress from "astro-compress"; export default { integrations: [ compress({ exclude: [ "my-awesome.png", (file: string) => file === "./dist/img/favicon/safari-pinned-tab.svg", ], }), ], }; ``` #### Set `logger` to `0` if you do not want to see debug messages. Default is `2`. **`astro.config.ts`** ```ts import compress from "astro-compress"; export default { integrations: [ compress({ logger: 0, }), ], }; ``` [astro-compress]: https://npmjs.org/astro-compress [csso]: https://npmjs.org/csso [html-minifier-terser]: https://npmjs.org/html-minifier-terser [terser]: https://npmjs.org/terser [sharp]: https://npmjs.org/sharp [svgo]: https://npmjs.org/svgo [astro-integration]: https://docs.astro.build/en/guides/integrations-guide/ ## Changelog See [CHANGELOG.md](CHANGELOG.md) for a history of changes to this integration. [![Lightrix logo](https://raw.githubusercontent.com/Lightrix/npm/main/.github/img/favicon.png "Built with Lightrix/npm")](https://github.com/Lightrix/npm) <sup>Built with [`Lightrix/npm`](https://github.com/Lightrix/npm), powered by [`Lightrix/files-pipe`](https://github.com/Lightrix/files-pipe).</sup>