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

stitches-purge-utils

v0.0.7

Published

A tool for purging Stitches utils

Downloads

2

Readme

stitches-purge-utils

'stitches-purge-utils` is a tool for purging Stitches utils.

This package is in early development so some features are missing, but it should be already useable. Do not use in production without proper testing.

See usage example

Usage

  1. Put all of the files containing your utils in one folder. In each file export an object literal containing all of the utils defined in that file as a named export called utilList. Create one file in this folder that is exports all of the utils from the other files. This folder will be provided to the script as the utilsInputDir option.

  2. Decide on the folder this plugin will emit the purged utils into. The plugin will copy your util files into that folder with all of the unused utils from the utilList exports removed. This folder will be provided to the script as the utilsOutputDir option.

  3. Create an alias that in development will be resolved to the file exporting all of the utils from the folder with the unpurged utils and in production will be resolved to the file exporting all of the utils from the folder with the purged utils. In your typescript config resovle that alias to the file from the folder with the unpurged utils (so that we always the types for all the utils available).

  4. Create a file that exports your configured css, globalCss and styled functions as named exports with those names.

  5. In this file import the utils from the alias we made in step 3.

  6. Create an alias for this file (the file we created in step 4). This alias will be provided to the script as the configuredStitchesPath option.

  7. In the rest of your code whenever you want to write styles objects, import css or styled through the alias we made in the previous step. Make sure that your style object is one of the arguments to either of those functions. If you want to write global styles, import the globalCss function from this alias, and provide your global styles as one of the arguments for this function.

  8. Before building for production, run the utils purge script with the options described above.

Setup with Vite

Install the package with

npm i -D stitches-purge-utils

Add this to your Vite config

import path from "path"
import { defineConfig } from 'vite'


export default defineConfig(
    ({ mode }) => ({
        resolve: {
            alias: [
                { 
                    find: "~stitches",
                    replacement: path.resolve("../src/example/stitches")
                },
                {
                    find: "~stitches-utils",
                    replacement: mode === "production" 
                        ? path.resolve("../stitches/purged-utils/utils.ts")
                        : path.resolve("../src/stitches-utils/utils.ts")
                }
            ] 
        }
    })
)

Add this script to your package.json

"stitches:purge-utils": "stitches-purge-utils --configuredStitchesPath ~stitches --srcDir ./src --utilsInputDir ./src/stitches-utils --utilsOutputDir ./stitches/purged-utils"

Add this to your tsconfig.json

{
  	"compilerOptions": {
		"baseUrl": "./",
	    "paths": {
        	"~stitches": ["src/stitches.ts"],
        	"~utils": ["src/stitches-utils/utils.ts"]
    	}
  	}
}

In both the vite config and the package.json script:

  • Replace "../src/example/stitches" with the file that export the configured css, globalCss and styled (described in step 4)

  • Replace "~stitches" with the alias for this file (described in step 6).

  • Replace `"./src" with the source directory.

  • Replace "./src/stitches-utils" with the folder with your unpurged utils (described in step 1).

  • Replace "../src/stitches-utils/utils.ts" with the file exporting all of your unpurged utils (described in step 1).

  • Replace "./stitches/purged-utils" with the folder with your purged utils (described in step 2).

  • Replace "../stitches/purged-utils/utils.ts" with the file exporting all of your purged utils (described in step 2).

  • Replace "~stitches-utils" with the alias that will be resolved in development to your unpurged utils and in production to you purged utils (described in step 3).

Now before building you can purge the utils with

npm run stitches:purge-utils