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

pufferfish-html

v0.1.1

Published

An extensible html templating engine that generates static html. This means that it doesn't affect load times.

Downloads

3

Readme

Pufferfish HTML Templating engine

Pufferfish is an extensible html templating engine that generates raw html, meaning that it will not affect load times of websites.

A full-blown javascript framework is sometimes a bit overkill for a static website. Pufferfish adds some simple templating to html so you don't have to use such a framework for small projects or for pages that require fast loading. Pufferfish will compile your files to raw html.

Pufferfish is still under heavy development

The documentation is currently out of date with new releases

To the documentation!

Overview

Syntax

To include a template file inside of html, simply write %filename%.

Example

<html>
  <body>
    %menu%
    %header.html%
    %footer.handlebars%
  </body>
</html>

If the filename does not include a file extension, .html will be used. You can also specify files with other file extensions.

When compiled, the html above will expand to include the menu.html, header.html and footer.handlebars file contents.

In the future, Pufferfish will support passing variabls to html. Pufferfish is still in early development. If you have any suggestions for its future, please suggest them by opening an issue!

Setting up a Pufferfish project

The recommended folder structure for a Pufferfish project is the followng:

project_name
├── html
├── output
├── templates
└── pufferfish.toml
  • html: contains the html of your website (like the file shown in the Syntax section as example).
  • output: contains the output of pufferfish.
  • templates: contains the files to be used as templates (e.g. menu.html in the example)
  • Pufferfish.toml: the configuration file for the project

These directories can also be set using the config file.

Compiling html

Inside of the directory of the project, run puf build. This will take into account the the config file and build html to the output directory.

Config file

Every Pufferfish project needs a pufferfish.toml file.

The minimum config file looks like this:

[project]

Here is a complete config file with all possible settings and their default values:

[project]
html_dir = "html"
template_dir = "templates"
output_dir = "output"
dev_dir = "output" # Default: set to `output_dir`
pretty = false
minify = false
verbose = false
 
[minify]
method = "default" # values: (default | onepass)
minify_doctype = true
ensure_spec_compliant_unquoted_attribute_values = true
keep_closing_tags = true
keep_html_and_head_opening_tags = true
keep_spaces_between_attributes = false
keep_comments = false
minify_css = true
minify_js = true
remove_bangs = false
remove_processing_instructions = false

[server]
port = "8080"

Further documentation

Go to the dedicated documentation or tutorial for more information on Pufferfish (Currently not maintained due to refactor to Rust).

Download

You can download Pufferfish with the following command:

curl "https://raw.githubusercontent.com/Jomy10/pufferfish/master/installation/install.sh" | sh

Or, you can download the Pufferfish from npm:

npm i -g pufferfish-html

Test if the package was installed using puf --version.

Manual installation

Head over to the Github releases page and download the correct build for your operatin system. You now have an executable which can bee moved to the correct directory.

Manual compilation

Pufferfish can be compiled for any platform, to do so, copy this repository:

git clone https://github.com/Jomy10/pufferfish.git

Then, go into the directory containing the project:

cd pufferfish/pufferfish

Run cargo build --release and the executable will be put in the target directory.

Integrations

Pufferfish is made so it can be included in other build processes. It also includes integrations with htmlbeautifier and minify-html (and minify-html-onepass).

Contributing

Contributions are always welcome. Read the CONTRIBUTING file for more information!

License

Pufferfish is licensed under the MIT license.

© Jonas Everaert 2022