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

lerret

v2.1.0

Published

A static site generator for image galleries.

Downloads

14

Readme

Lerret

Build Status Coverage Status Dependency Status devDependency Status

Lerret is a simple static site generator for image oriented sites, powered by Node.js. Whilst usable out of the box, Lerret's behaviour can be easily customised and extended through its plugin framework.

Lerret takes care of templating and image repurposing. Lerret doesn't come with any built in tools for generating stylesheets, minifying Javascript, or packaging and deploying your sites. Instead, it's recommended that you use your favourite tools directly to supplement what Lerret does well.

Lerret supports GIF, JPEG, PNG and TIFF image formats. Lerret will also extract any EXIF tags embedded in your images and make them available to your templates and plugins.

Release Notes

2.1.0

  • Enhance pug plugin to allow any of the three templates to be optional.
  • Add the ability to filter which images the convert and copy plugins apply to.

2.0.0

  • Support for Node versions 11 and earlier dropped.
  • Upgraded to Pug 3. See Migrating to Pug 3 for details of how to migrate your templates.
  • Refactored codebase to use async/await.
  • Updated all dependencies.

1.0.0

  • The jade plugin has been removed and replaced with pug. See Migrating to Pug 2 for details of how to migrate your templates.

Getting Started

In order to use Lerret you need to have Node.js and npm installed. Once you have those, install Lerret as follows:

$ npm install -g lerret

Alternatively, if your site uses npm as its package manager then you may add Lerret as a dependency in your package.json file.

Once you have Lerret installed, it's simple to create a new project using the init command.

$ mkdir my-project
$ cd my-project
$ lerret init

This creates a starting config file named lerret.yaml and directories named content, plugins and target.

$ ls
content  lerret.yaml  plugins  target

The generate command generates your site, but first you'll need to add some content and configure Lerret.

$ lerret generate

Supported image formats

Lerret supports the following image formats (and corresponding file extensions) when both reading and writing images.

  • GIF (.gif)
  • JPEG (.jpeg or .jpg)
  • PNG (.png)
  • TIFF (.tif or .tiff)

Organising your content

Lerret traverses your project's content directory building up a map of information as follows.

If the content directory contains a file named site.yaml, then it is parsed as YAML and added to the content map at the root level.

Each directory immediately beneath the content directory is processed as an album. A list of albums is added to the content map at the root level under the key albums.

An album is represented by a map containing a key id with the album directory's name as its value and any other properties from the YAML file album.yaml.

Each directory immediately beneath each album directory is processed as an image. A list of images is added to each album map under the key images. Each image directory must contain exactly one image file, named image and suffixed with a supported file extension.

An image is represented by a map containing a key id with the image directory's name as its value, a key path with the image file path as its value, a key exif containing a map of the image's EXIF tags (if it has any), and any other properties from the YAML file image.yaml.

The site, album and image YAML files are all optional.

The print command outputs the content map to the console in YAML format. This is useful for validating and inspecting your site's content. Note that by default the output includes all exif tags - these may be suppressed using the --no-exif argument.

$ lerret print

Configuration

Lerret is configured in YAML. The configuration is expected in a file named lerret.yaml in your project's root directory, the directory within which the lerret command should be executed.

The following configuration keys are available. Plugin specific configuration is documented with each plugin below.

  • contentDirectory (optional, default: ./content) - The location Lerret searches for album and image content.
  • pluginDirectory (optional, default: ./plugins) - The location Lerret searches for additional plugins.
  • plugins (required) - The list of plugins to execute. Plugins should be referred to by their name as referenced in the PLugins section below.
  • sort (optional)
    • albums (optional)
      • property (optional) - The property, or list of properties, of an album to sort on.
      • order (optional, default: asc) - The order, or list of orders, by which to sort the albums (either asc or desc).
    • images (optional)
      • property (optional) - The property, or list of properties, of an image to sort on.
      • order (optional, default: asc) - The order, or list of orders, by which to sort the images (either asc or desc).
  • targetDirectory (required) - The location Lerret writes the generated site to. The resulting directory structure matches that of the source content directory.

Plugins

Built-in plugins

Lerret includes some core plugins which are documented below.

convert

The convert plugin may be used to repurpose your images. The plugin supports:

  • resizing and cropping
  • sharpening and quality adjustments
  • conversion to different image formats

It is also possible to repurpose each image more than once with different settings.

Note: in order to use this plugin, please install GraphicsMagick.

The following configuration keys are available.

  • convert (optional) - An array of conversion configurations, each containing:
    • filename (required) - The filename to use when writing the repurposed image to the target location.
    • quality (optional) - The resulting image quality (0 to 100, with 100 being best). If not specified, the GraphicsMagick default is used.
    • resize (optional) - Resize the image to fit the width and height values while maintaining the original aspect ratio.
      • width (optional) - The width in pixels. If not set, then the image is resized to the configured height and its width is set accordingly to maintain the aspect ratio.
      • height (optional) - The height in pixels. If not set, then the image is resized to the configured width and its height is set accordingly to maintain the aspect ratio.
      • crop (optional, default: false) - Set to true to scale and crop the image to the configured width and height. When cropping, both width and height are required.
    • unsharp (optional) - Sharpen the image with an unsharp mask operator. Please consult the GraphicsMagick documentation for an explanation of the settings below.
      • radius (required)
      • sigma (required)
      • amount (required)
      • threshold (required)
    • match (optional) - Used to filter which images this conversion applies to.
      • property (required) - The image property to match on.
      • regex (required) - The regular expression applied.

copy

The copy plugin copies images without modification to the target location. This is useful if you have already processed your images for the web.

The following configuration keys are available.

  • copy (optional)
    • filename (optional, default: the source image's filename) - The filename to use when copying the image to the target location.
    • match (optional) - Used to filter which images this plugin applies to.
      • property (required) - The image property to match on.
      • regex (required) - The regular expression applied.

pug

The pug plugin may be used to render Pug templates to HTML. The plugin looks for three optional templates: a home page template, an album template and an image template.

The home page template is rendered once. It is provided with a context containing the following keys.

  • site - The full content map.
  • helpers - Additional helper module.

The album template is rendered once per album. It is provided with a context containing the following keys.

  • album - The map of attributes associated with the album.
  • site - The full content map.
  • helpers - Additional helper module.

The image template is rendered once per image. It is provided with a context containing the following keys.

  • image - The map of attributes associated with the image.
  • album - The map of attributes associated with the album which contains the image.
  • site - The full content map.
  • helpers - Additional helper module.

The following configuration keys are available. Paths are relative to the project root.

  • pug (optional)
    • helpers (optional) - Path to a Node.js module of helper methods to pass to the template.
    • templates (required)
      • home (optional) - Path to a Pug template for the site home page.
      • album (optional) - Path to a Pug template for each album page.
      • image (optional) - Path to a Pug template for each image page.

Writing your own plugins

Lerret looks for additional plugins within your project's configured pluginDirectory. Plugins are just regular Node.js modules (files with an extension of .js or directories containing a file named index.js) that export an object with the following attributes.

  • name (required) - The name of the plugin.
  • processSite (optional) - A function which is called once with the full content map.
  • processAlbum (optional) - A function which is called once per album.
  • processImage (optional) - A function which is called once per image.

Note that at least one of processSite, processAlbum or processImage must be defined.

processSite should be a function that accepts the following arguments. If the function returns a value, the content map is updated to this value and passed to subsequent plugins. If the returned value is a Promise object, it will be followed and its eventual value used.

  • site - The full site content map.
  • config - Lerret's config module.

processAlbum should be a function that accepts the following arguments. If the function returns a value, the album is updated to this value and passed to subsequent plugins. If the returned value is a Promise object, it will be followed and its eventual value used.

  • album - The current album.
  • index - The index of the current album.
  • length - The number of albums.
  • site - The full site content map.
  • config - Lerret's config module.

processImage should be a function that accepts the following arguments. If the function returns a value, the image is updated to this value and passed to subsequent plugins. If the returned values is a Promise object, it will be followed and its eventual value used.

  • image - The current image.
  • index - The index of the current image.
  • length - The number of images.
  • album - The image's album.
  • site - The full site content map.
  • config - Lerret's config module.

The config module that is passed to each provides the following functions. This module allows you to access configuration data in your project's lerret.yaml.

  • get(key, default) - Returns the configuration value associated with the given key. If the key does not exist then an Error is thrown, unless a default value is provided in which case the default is returned.
  • has(key) - Returns true if the given key exists in your config file.

Sites Using Lerret

To add your site here, please submit a pull request.