npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

vite-plugin-srcset

v2.1.0

Published

Vite plugin for the automatic generation of images in various formats and widths, for use in srcsets of <picture>- or <img>-elements.

Downloads

131

Readme

Vite Plugin SrcSet npm

Vite plugin for the automatic generation of images in various formats and widths, for use in srcsets of <picture>- or <img>-elements.

How it works

This plugin allows import any common image format as a srcset. While the dev server is running the srcset will only include a source with the format of the original image, but during build assets for all required formats and widths are automatically generated.

Usage

import logoSrcset from './logo.svg?srcset' // ← Use ?srcset to import a srcset

const LOGO_SIZE = '32px';

const sources = logoSrcset.sources.map(s =>
    `<source type="${s.type}" srcset="${s.srcset}" sizes="${LOGO_SIZE}" />`
);

const renderedHTML = `
    <picture>
        ${sources.join('\n')}
        <img src="${logoSrcset.fallback}" />
    </picture>
`;

Installation

Install the package:

npm i --save-dev vite-plugin-srcset

Setup

  1. Add the plugin to the Vite config:

    // vite.config.ts
    
    import { defineConfig } from 'vite';
    import srcset from 'vite-plugin-srcset';
    
    export default defineConfig({
        plugins: [srcset(
            {
                // config 1 (see below for list of options)
            },
            {
                // config 2 (see below for list of options)
            },
            // [...]
        )]
    });
  2. If you're using Typescript, add the the client types to your vite-env.d.ts:

      /// <reference types="vite/client" />
    + /// <reference types="vite-plugin-srcset/client" />

Configuration

This plugin allows to add multiple configs so different source images can have different combinations of output widths and formats. Each configuration may contain an include and an exclude property to determine which source images this configuration should be applied to. If a source image path matches several configurations, the first one is selected.

Options

exclude

Type: String | Array[...String]
Default: null

A minimatch pattern, or array of patterns, which specifies the files in the build the plugin should ignore. By default no files are ignored.

include

Type: String | Array[...String]
Default: null

A minimatch pattern, or array of patterns, which specifies the files in the build the plugin should operate on. By default all files are targeted.

outputFormats

Type: { png?: boolean; webp?: boolean; jpeg?: boolean; avif?: boolean; jxl?: boolean; }
Default: { png: true, webp: true }

Formats to output.

outputWidths

Type: number[]
Default: [64, 128, 256, 512, 1024]

Widths to output.

assetNamePrefix

Type: string
Default: ""

Prefix of the name of the output assets.

loadFile

Type: (this: PluginContext, id: string): Promise<{ contents: Uint8Array }>
Default: A small wrapper around readFile from node:fs

Overwrite the default file loader.

This can be useful if you want to modify or process the file before generating srcsets. For example, you could change the fill color in an SVG from black to white:

import { stripSrcsetQuery } from 'vite-plugin-srcset';
import { normalizePath } from 'vite';

async function loadFile(id: string) {
    // id includes all search params (including srcset), which we don't care about here
    // in this example we'll strip the `srcset` as well as the `dark` query
    const fsPath = normalizePath(stripSrcsetQuery(stripSrcsetQuery(id, 'dark')));
    let text = await readFile(fsPath, 'utf-8');
    text = text.replaceAll('fill="#000000"', 'fill="#FFFFFF"');
    return { contents: Buffer.from(text, 'utf-8') };
}