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

sitecraft

v1.1.16

Published

Static Site builder

Downloads

37

Readme

SiteCraft

Another dinamic to static page generator (like Hugo but by me)

What is SiteCraft?

Sitecraft helps you to create simple static pages with minimal configuration centered in easy to use and mantain. To create your site you just need to edit the homepage.md file with your needs.

SiteCraft was created to be able to create static pages easily with an opion of creating a blog. So you are not obligated to use any blog style structure unless you want it.

SiteCraft can help you to create a simple static landing page for any needs with a record low price of only-the-cost-of-your-domain, no hosting payments needed if deployed to githubpages.

SiteCraft was made to be able to deploy to github pages, but in reality you can serve the /public directory to any static server (nginx, apache, python, etc).

How to use

Just install it with npm i -D sitecraft and then just use

npx sitecraft build

to build /public directory

or

npx sitecraft serve

to launch a development server. THIS SERVER IS MEANT FOR DEVELOPMENT, only use it while doing changes to your site so you can see them in real time.

also

npx sitecraft create my-page.md

to create a new page at the root of your site

or

npx sitecraft create posts/my-entry.md

to create a new new blog post entry

finally

npx sitecraft help

for help

Use as API

You can also use as API inside a .js or .mjs file

import { build, serve } from 'sitecraft'
  • function build (no args) runs the build job
  • function serve (no args) runs the build job, start a file watcher for changes in your template and content directories, also starts a live-server to watch your changes in real time

Structure

SiteCraft needs a specific file structure to be able to function correctly. This is the file structure:

─ yoursite
  ├─ content
  |  ├─ images
  │  │  └─ your-content-related-image.jpg
  |  ├─ posts
  │  │  └─ your-blog-post.md
  │  ├─ homepage.md
  │  └─ any-other-page.md
  ├─ template
  │  ├─ favicon
  │  │  └─ # all your favicon related files
  │  ├─ images
  │  │  └─ # all your images
  │  ├─ partials
  │  │  └─ # all partials needed for the template and SiteCraft
  │  ├─ page.pug
  │  ├─ post.pug
  │  └─ styles.styl
  ├─ public
  │  └─ # This directory is created with your final site
  └─ site.yml # all your site configurations

Normally you wont need to edit anything inside template and you can just import it from the gallery.

For a regular site, you just need to update the styles.styl with your needs about site colors and fine adjustments. Also all stylus imports are going to be look for inside partials as root inside stylus.

Site definitions

All site definitions should be place inside a site.yml at the root of your site. Here is an example:

siteName: My awesome site
siteDesc: This is my awesome site, come take a look
author:
  name: Myself
  site: my-personal-site buy me a coffe
siteUrl: https://mysite.com
cname: mysite.com
pages:  # this node is optional
  Home: /
  Blog: /blog
  • siteName: used to populate <title> in your website.
  • siteDesc: same, used to populate the site description at your site metadata
  • author: this is added as a comment in the HTML as a small fingerprint
  • siteUrl: This is used to populate the site metadata and used to render non-root websites
  • cname: This will create a CNAME file at the root of your deployment, this is required for githubpages so you can use a custom url. Remember cname must not contain protocol, only the domain
  • pages: this is an optional node, if you add it, it will habilitate the shorthand pages to be used in the templates and display all pages described there.

Create your site

The only required md file is homepage.md which must be located inside /content. This file will be translated as index.html inside /public when built. There you can use md or html to create your homepage. Remember that header, footer and general styles are defined in /template.

Want more pages?

Just create another .md file inside /content, this file will be transposed to the root of your site using the file name as the url.

Want a blog?

Just put inside /content/posts your entries as .md files. Just as with pages, the file name will be transposed as the slug for your post.

  • Currently all blog posts are being deployed to yoursite/posts/your-blog-post For content-related-images (not images that are defined in the template, but actually images for your pages and blog) put them in /content/images, those will be transposed to /content/images on the root of your site.

Blog metadata

All entries (pages and blog posts) are expecting a meta definition at the very begining of the file just like this:

meta:
  title: My post title
  date: 20230609
  author: Zero

# Here is my post title
## H2 title

Here is my post in markdown

meta is formatted as yaml and it should have:

  • title: the title of your post to render in the post list and navigation and to the <title> in the final HTML
  • date: consider using YYYYMMDD or YYYYMMDDHHmm if you are planning to post more than one post per day. SiteCraft will automatically order them using this value
  • author: you <3
  • excerpt: A short description of your post
  • image: Url to your showcase image of the post
  • tags: a list of tags for your post

This metadata is required for all blog posts, but not for pages. If you don't want to add any metadata to page just skip two lines and start your content at the 3rd line. (might think in something clever later, but for now, that works just fine)

RSS

SiteCraft will render a simple atom.xml RSS file directly on the root of your site containing all information about your latest 10 entries. It is important that it relies on the same metadata defined on each post, so keep in mind that.

Sitemap

Similart to atom.xml SiteCraft will render a sitemap.xml directly on root of your site. Containing links to all your pages and blog posts

XML Styles

Both RSS and Sitemaps are defined with XSL transformers that use the same styles.css that powers your site. It only uses the class xml to contain everything, define your styles according to that if you want to change it.

Shorthands and variables

All variables defined in site.yml can be accesed at the pug files and can be used at a glance. Meanwhile, from inside the .md files, you cannot acces this variables, so ther are a couple of shorthands that you can use to improve your site.

  • !{blogList} will render a HTML with the list of all the blog entries. No pagination available by now
  • !{siteName} will render your site name as defined in site.yml
  • !{siteDesc} will render your site description as defined in site.yml
  • !{siteUrl} will render your site url as defined in site.yml

blogList requires a /template/blogList.pug file in your site so it can render correctly. Check the example in SiteCraft Gallery.

This shorthands can be used from pages and blog posts

More shorthands will come as needed

Tags

Since version 1.1.12 Tags are available for each post, you just need to define them in your .md file and use them in your blog template (see example in SiteCraft Gallery) To make them work, you must create a /content/post.md file where you must define the blogList shorthand and a simple script to hide discriminated objects. I suggest not to include this page in your site.yml since is just an indiscrimitaed list of posts.

Images and favicon

Everything inside content/images/ will be transposed to public/content/images/ Everything inside template/images/ will be transposed to public/images/ Everything inside template/favicon/ will be transposed to public/ (root of your website) So browsers will look there for favicon.ico and other alternatives. Also check template/partials/headMeta.pug that is where all meta tags are defined (inside <head>) for all pages and blog posts

Deploying

Sitecraft creates (using npx sitecraft build) a /public directory wich can be served using nginx, apache or any simple http server. To deploy to github pages, you will need an action like this:

name: GitHub Pages

on:
  workflow_dispatch:
    inputs:

jobs:
  deploy:
    env:
      ENV: production  # This is important so the build knows how to handle site URLs as absolute
    runs-on: ubuntu-22.04
    permissions:
      contents: write
    concurrency:
      group: ${{ github.workflow }}-${{ github.ref }}
    steps:
      - uses: actions/checkout@v3

      - name: Setup Node
        uses: actions/setup-node@v3
        with:
          node-version: '18'

      - name: Cache dependencies
        uses: actions/cache@v3
        with:
          path: ~/.npm
          key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }}
          restore-keys: |
            ${{ runner.os }}-node-

      - run: npm ci
      - run: npm run build

      - name: Deploy
        uses: peaceiris/actions-gh-pages@v3
        with:
          github_token: ${{ secrets.GITHUB_TOKEN }}
          publish_dir: ./public

Remember to

  • Put this action as gh-pages.yml inside /.github/workflows/
  • Add "build": "sitecraft build" to your scripts inside package.json
  • This workflow only works when dispatched from github actions. If you want something to run on every push to main, you could use something like this:
on:
  push:
    branches:
      - 'main'

note that this action will look for ./public and will deploy that to the root of a new branch called gh-pages. Then just activate the gh-pages page for that repository

This looks a lot like Hugo

Yes it does, I just didn't liked how hugo was working and how it was blog oriented instead of page oriented Also since I like easy stuff, I'm using styl and pug files to reduce the templating system.