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 🙏

© 2024 – Pkg Stats / Ryan Hefner

psi-svg

v1.0.9

Published

Generates a SVG of a given url's PageSpeed Insights statistics via a http endpoint or a cli command.

Downloads

31

Readme

PageSpeed Insights SVG

Example Insights for https://inico.dev/

npm

This node module performs a Google PageSpeed Insights analysis on a given webpage and returns the result as an SVG.

Installation

npm

npm i -g psi-svg

bun

bun i -g psi-svg

yarn

yarn global add psi-svg

Usage

psi-svg can be used as a CLI tool or as a web server. Different options can be used to customize the output in both cases.

CLI

To use psi-svg in the CLI, install it and run it with the URL of the webpage to analyze and the path to the output SVG as arguments:

Example:

psi-svg https://www.example.com ./out.svg

Flags

The following flags can be used to customize the page speed analysis and the output:

| Flag | Description | Type | Default Value | | ---------------------- | -------------------------------------------------- | ---------------------------------------------------------------------- | ------------------------------------------------------ | | --strategy or -s | On what type of device the site should be analyzed | desktop | mobile | mobile | | --categories or -c | The categories to include in the analysis (CSV) | performance | accessibility | best-practices | seo | pwa | performance, accessibility, best-practices, seo, pwa | | --legend or -l | Whether to include the legend in the SVG | true | false | true |

npx

psi-svg can also be run with npx:

npx psi-svg https://www.example.com ./out.svg

Server

To run the psi-svg web server, the --srv or -s flag can be set:

psi-svg -s

By default the server will listen on port 3000. To change this, the --port or -p option can also be set:

psi-svg -s -p 8080

After the server has been started, an insights SVG can be generated by sending a GET request to the server with the URL to analyze as a query parameter:

curl http://localhost:3000/?url=https://www.example.com > example-insights.svg

Query Parameters

The server accepts similar parameters as the CLI tool:

| Parameter | Description | Values | Default | | ------------ | -------------------------- | ---------------------------------------------------------------------- | ------------------------------------------------------ | | url | URL to the site to analyze | string | - | | strategy | See Flags | desktop | mobile | mobile | | categories | See Flags | performance | accessibility | best-practices | seo | pwa | performance, accessibility, best-practices, seo, pwa | | legend | See Flags | true | false | true |

This GET request for example

curl http://localhost:3000/?url=https://www.example.com\&strategy=desktop\&categories=performance,accessibility,seo\&legend=false > example-insights.svg

will return this SVG

Example Insights for https://www.example.com

Note: this analysis ran on the 17. November of 2023; the example page may have changed so the example SVG above may not be accurate anymore.

Environment Variables

The following environment variables can be used to customize the web server:

| Variable | Description | Values | Default | | ------------------ | ---------------------------------------------------------------------------------------------- | -------- | ------- | | DOMAIN_WHITELIST | A comma-separated list of domains to allow requests from. Currently does not support wildcards | string | - |

Setting the DOMAIN_WHITELIST environment variable to example.com for example will allow requests from https://example.com but not from https://example.org. This is especially useful when running the web server in a public environment.

Docker

The application can also be run as a Docker container by following the following steps: (requires docker to be installed)

  1. Clone the repository
git clone https://www.github.com/nico-i/psi-svg
  1. Build the image
docker build -t psi-svg .
  1. Run the image
docker run -p 3000:3000 psi-svg

Github Actions

The application can also be run as a Github Action. An example workflow can be found in .github/workflows/pagespeed.yml. The results of which are visible in docs/img/. To use the action, simply copy the workflow file to your repository and modify the value of the URL_TO_ANALYZE and RESULTS_DIR variables. Also ensure that the Github Action Workers have write access to the repository. You can configure this under Settings > Code and automation > Actions > General > Workflow permissions.

Development

This project uses Node.js and Typescript for development. To get started, clone the repository and install the dependencies:

git clone https://www.github.com/nico-i/psi-svg
cd psi-svg
npm install

To run the application, use the following command:

npm run build && npm run start

This will start the web server on port 3000.

For development I recommend using the API testing tool bruno, which you can point to the /.bruno/ directory of this repo. It contains some helpful requests to test the application.

Credits

This project is based on ankurparihar's readme-pagespeed-insights.

This project improves the original project in the following ways:

  • Added a CLI implementation
  • Added Docker compatibility
  • Removed unnecessary options which previously bloated the code
  • Better SVG generation with individual SVG-files instead of inline SVG strings
  • SVG styling CSS moved to an individual file to facilitate intellisense and linting
  • Improved the file structure and code coupling with Domain Driven Design (DDD)
  • Added the option to disable the legend
  • Made Github action independent of running server
  • Automated unit tests

License

See LICENSE.