UNPKG

astro-compress

Version:
288 lines (219 loc) β€’ 13.4 kB
<table><tr> <td colspan="1"> <h3 align="center"> <picture> <source media="(prefers-color-scheme: dark)" srcset="https://PlayForm.Cloud/Dark/Image/GitHub/Astro.svg"> <source media="(prefers-color-scheme: light)" srcset="https://PlayForm.Cloud/Image/GitHub/Astro.svg"> <img width="28" alt="Astro" src="https://PlayForm.Cloud/Image/GitHub/Astro.svg"> </picture> </h3> </td> <td colspan="3" valign="top"> <h3 align="center"> Related </h3> </td> </tr><tr><td valign="top" colspan="1"><a href="https://GitHub.Com/PlayForm/Inline/actions/workflows/Node.yml" target="_blank"> <picture> <source media="(prefers-color-scheme: dark)" srcset="https://img.shields.io/github/actions/workflow/status/PlayForm/Inline/Node.yml?branch=main&label=Build&logo=node.js&color=black&labelColor=black&logoColor=white&logoWidth=0"> <source media="(prefers-color-scheme: light)" srcset="https://img.shields.io/github/actions/workflow/status/PlayForm/Inline/Node.yml?branch=main&label=Build&logo=node.js&color=white&labelColor=white&logoColor=black&logoWidth=0"> <img src="https://img.shields.io/github/actions/workflow/status/PlayForm/Inline/Node.yml?branch=main&label=Build&logo=node.js&color=black&labelColor=black&logoColor=white&logoWidth=0" alt="Build" title="Build"> </picture> </a><br><a href="https://NPMJS.Org/@playform/inline?activeTab=dependencies" target="_blank"> <picture> <source media="(prefers-color-scheme: dark)" srcset="https://img.shields.io/librariesio/release/npm/@playform/inline?logo=dependabot&label=&color=black&labelColor=black&logoColor=white&logoWidth=0"> <source media="(prefers-color-scheme: light)" srcset="https://img.shields.io/librariesio/release/npm/@playform/inline?logo=dependabot&label=&color=white&labelColor=white&logoColor=black&logoWidth=0"> <img src="https://img.shields.io/librariesio/release/npm/@playform/inline?logo=dependabot&label=&color=black&labelColor=black&logoColor=white&logoWidth=0" alt="Dependency" title="Dependency"> </picture> </a><br><a href="https://NPMJS.Org/@playform/inline" target="_blank"> <picture> <source media="(prefers-color-scheme: dark)" srcset="https://img.shields.io/npm/v/@playform/inline?label=Version&logo=npm&color=black&labelColor=black&logoColor=white&logoWidth=0"> <source media="(prefers-color-scheme: light)" srcset="https://img.shields.io/npm/v/@playform/inline?label=Version&logo=npm&color=white&labelColor=white&logoColor=black&logoWidth=0"> <img src="https://img.shields.io/npm/v/@playform/inline?label=Version&logo=npm&color=black&labelColor=black&logoColor=white&logoWidth=0" alt="Version" title="Version"> </picture> </a><br></td><td valign="top" colspan="1"><a href="https://GitHub.Com/PlayForm/Inline" target="_blank"><picture><source media="(prefers-color-scheme: dark)" srcset="https://img.shields.io/github/stars/PlayForm/Inline?style=flat&label=Star&logo=github&color=black&labelColor=black&logoColor=white&logoWidth=0"><source media="(prefers-color-scheme: light)" srcset="https://img.shields.io/github/stars/PlayForm/Inline?style=flat&label=Star&logo=github&color=white&labelColor=white&logoColor=black&logoWidth=0"><img src="https://img.shields.io/github/stars/PlayForm/Inline?style=flat&label=Star&logo=github&color=black&labelColor=black&logoColor=white&logoWidth=0" alt="Star"></picture></a><br><a href="https://NPMJS.Org/@playform/inline" target="_blank"> <picture> <source media="(prefers-color-scheme: dark)" srcset="https://img.shields.io/npm/d18m/@playform/inline?label=Download&logo=npm&color=black&labelColor=black&logoColor=white&logoWidth=0"> <source media="(prefers-color-scheme: light)" srcset="https://img.shields.io/npm/d18m/@playform/inline?label=Download&logo=npm&color=white&labelColor=white&logoColor=black&logoWidth=0"> <img src="https://img.shields.io/npm/d18m/@playform/inline?label=Download&logo=npm&color=black&labelColor=black&logoColor=white&logoWidth=0" alt="Download" title="Download"> </picture> </a><br><a href="https://GitHub.Com/PlayForm/Inline" target="_blank"><b>Inlineβ€πŸ¦”</b></a></td><td valign="top" colspan="1"><a href="https://GitHub.Com/PlayForm/Format/actions/workflows/Node.yml" target="_blank"> <picture> <source media="(prefers-color-scheme: dark)" srcset="https://img.shields.io/github/actions/workflow/status/PlayForm/Format/Node.yml?branch=main&label=Build&logo=node.js&color=black&labelColor=black&logoColor=white&logoWidth=0"> <source media="(prefers-color-scheme: light)" srcset="https://img.shields.io/github/actions/workflow/status/PlayForm/Format/Node.yml?branch=main&label=Build&logo=node.js&color=white&labelColor=white&logoColor=black&logoWidth=0"> <img src="https://img.shields.io/github/actions/workflow/status/PlayForm/Format/Node.yml?branch=main&label=Build&logo=node.js&color=black&labelColor=black&logoColor=white&logoWidth=0" alt="Build" title="Build"> </picture> </a><br><a href="https://NPMJS.Org/@playform/format?activeTab=dependencies" target="_blank"> <picture> <source media="(prefers-color-scheme: dark)" srcset="https://img.shields.io/librariesio/release/npm/@playform/format?logo=dependabot&label=&color=black&labelColor=black&logoColor=white&logoWidth=0"> <source media="(prefers-color-scheme: light)" srcset="https://img.shields.io/librariesio/release/npm/@playform/format?logo=dependabot&label=&color=white&labelColor=white&logoColor=black&logoWidth=0"> <img src="https://img.shields.io/librariesio/release/npm/@playform/format?logo=dependabot&label=&color=black&labelColor=black&logoColor=white&logoWidth=0" alt="Dependency" title="Dependency"> </picture> </a><br><a href="https://NPMJS.Org/@playform/format" target="_blank"> <picture> <source media="(prefers-color-scheme: dark)" srcset="https://img.shields.io/npm/v/@playform/format?label=Version&logo=npm&color=black&labelColor=black&logoColor=white&logoWidth=0"> <source media="(prefers-color-scheme: light)" srcset="https://img.shields.io/npm/v/@playform/format?label=Version&logo=npm&color=white&labelColor=white&logoColor=black&logoWidth=0"> <img src="https://img.shields.io/npm/v/@playform/format?label=Version&logo=npm&color=black&labelColor=black&logoColor=white&logoWidth=0" alt="Version" title="Version"> </picture> </a><br></td><td valign="top" colspan="1"><a href="https://GitHub.Com/PlayForm/Format" target="_blank"><picture><source media="(prefers-color-scheme: dark)" srcset="https://img.shields.io/github/stars/PlayForm/Format?style=flat&label=Star&logo=github&color=black&labelColor=black&logoColor=white&logoWidth=0"><source media="(prefers-color-scheme: light)" srcset="https://img.shields.io/github/stars/PlayForm/Format?style=flat&label=Star&logo=github&color=white&labelColor=white&logoColor=black&logoWidth=0"><img src="https://img.shields.io/github/stars/PlayForm/Format?style=flat&label=Star&logo=github&color=black&labelColor=black&logoColor=white&logoWidth=0" alt="Star"></picture></a><br><a href="https://NPMJS.Org/@playform/format" target="_blank"> <picture> <source media="(prefers-color-scheme: dark)" srcset="https://img.shields.io/npm/d18m/@playform/format?label=Download&logo=npm&color=black&labelColor=black&logoColor=white&logoWidth=0"> <source media="(prefers-color-scheme: light)" srcset="https://img.shields.io/npm/d18m/@playform/format?label=Download&logo=npm&color=white&labelColor=white&logoColor=black&logoWidth=0"> <img src="https://img.shields.io/npm/d18m/@playform/format?label=Download&logo=npm&color=black&labelColor=black&logoColor=white&logoWidth=0" alt="Download" title="Download"> </picture> </a><br><a href="https://GitHub.Com/PlayForm/Format" target="_blank"><b>πŸ—»β€Format —</b></a></td></tr></table><hr> # [Compress]β€πŸ—œοΈ This **[`Astro integration`][astro-integration]** brings compression utilities to your Astro project. [`CSS (csso)`][csso]β€πŸŽ [`CSS (lightningcss)`][lightningcss]β€πŸŽ [`HTML (html-minifier-terser)`][html-minifier-terser]β€πŸŽ [`Image (sharp)`][sharp]β€πŸŽ [`JavaScript (terser)`][terser]β€πŸŽ [`SVG (svgo)`][svgo]β€πŸŽ [`JSON`][JSON]β€πŸŽ > **Note** > > `Compress` will not compress your requests, only your statically generated > build and pre-rendered routes. > [!IMPORTANT] > > Use `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 `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 `Compress` integration like so: ```sh npm install -D -E astro-compress ``` Then, apply this integration to your `astro.config.*` file using the `integrations` property: **`astro.config.ts`** ```ts export default { integrations: [(await import("astro-compress")).default()], }; ``` ## Getting started The utility will now automatically compress all your CSS, HTML, SVG, JavaScript, JSON and image files in the Astro `outDir` folder. The following image file types will be compressed via [`sharp`][sharp]: - avci - avcs - avif - avifs - gif - heic - heics - heif - heifs - jfif - jif - jpe - jpeg - jpg - apng - png - raw - tiff - webp SVG compression is supported, as well via [`svgo`][svgo]. ### Default Compression You can override any of the default options from the configurations of: - [`csso`](HTTPS://GitHub.Com/css/csso#minifysource-options) - [`lightningcss`](HTTPS://GitHub.Com/parcel-bundler/lightningcss/blob/master/node/index.d.ts#L8) - [`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) **`astro.config.ts`** ```ts export default { integrations: [ (await import("astro-compress")).default({ CSS: false, HTML: { "html-minifier-terser": { removeAttributeQuotes: false, }, }, Image: false, JavaScript: false, JSON: false, SVG: false, }), ], }; ``` or disable them entirely: **`astro.config.ts`** ```ts export default { integrations: [ (await import("astro-compress")).default({ CSS: false, HTML: false, Image: false, JavaScript: false, JSON: false, SVG: false, }), ], }; ``` You can see the full option map here: [`Source/Interface/Option.ts`](HTTPS://GitHub.Com/PlayForm/Compress/blob/main/Source/Interface/Option.ts) ### Output By default `Compress` compresses the `outDir` `Astro` directory, if you'd like it to compress a different directory you would have to add it to the `Compress` `Path` option, as well: ```ts export default { integrations: [ (await import("astro-compress")).default({ Path: ["./dist", "./Compress"], }), ], }; ``` ### Add Multiple Paths You can add multiple paths to compress by specifying an array as the `Path` variable. **`astro.config.ts`** ```ts export default { integrations: [ (await import("astro-compress")).default({ Path: ["./Target", "./Build"], }), ], }; ``` ### Input-Output Mapping You can also provide a map of paths for different input output directories. **`astro.config.ts`** ```ts export default { integrations: [ (await import("astro-compress")).default({ Path: new Map([["./Source", "./Target"]]), }), ], }; ``` Or an array of the two: **`astro.config.ts`** ```ts export default { integrations: [ (await import("astro-compress")).default({ Path: [ // Compress Target "./Target", // Compress Target one more time into a different directory new Map([["./Target", "./TargetCompress"]]), ], }), ], }; ``` ### File Filtering You can filter files to exclude specific ones from compression. A filter can be an array of regular expressions or a single match. You can also use functions to match on file names: **`astro.config.ts`** ```ts export default { integrations: [ (await import("astro-compress")).default({ Exclude: [ "File.png", (File: string) => File === "./Target/Favicon/Image/safari-pinned-tab.svg", ], }), ], }; ``` ### Controlling Logging You can control the logging level by setting the `Logger` parameter. The default value is `2`, but you can set it to `0` if you don't want to see debug messages: **`astro.config.ts`** ```ts export default { integrations: [ (await import("astro-compress")).default({ Logger: 0, }), ], }; ``` [Compress]: HTTPS://NPMJS.Org/astro-compress [csso]: HTTPS://NPMJS.Org/csso [lightningcss]: HTTPS://NPMJS.Org/lightningcss [html-minifier-terser]: HTTPS://NPMJS.Org/html-minifier-terser [terser]: HTTPS://NPMJS.Org/terser [sharp]: HTTPS://NPMJS.Org/sharp [svgo]: HTTPS://NPMJS.Org/svgo [JSON]: HTTPS://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify [astro-integration]: HTTPS://docs.astro.build/en/guides/integrations-guide/ ## Changelog See [`CHANGELOG.md`](CHANGELOG.md) for a history of changes to this integration.