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

metalsmith-author

v1.1.0

Published

A metalsmith plugin to input authors information in collection files.

Downloads

7

Readme

metalsmith-author

A metalsmith plugin to input authors information in collection files.

Specially useful for documents (files) with different authors. Requires metalsmith-collections plugin to work.

What it does

Let's say we have several posts from different authors. And let's say we need information about specific authors in each post, i.e. full name, url, twitter, etc (You can define these infos the way you wish.). Instead of duplicating this infos in every post file front matter, we can just define an author identifier and metalsmith-author plugin will set the infos we need for a given author in a post file.

post1.html
---
title: Post 1
author: john
---
Post 1 contents...
post2.html
---
title: Post 2
author: paul
---
Post 2 contents...

These files will be processed to be as:

{
  'post1.html': {
    title: 'Post 1',
    author: {
      name: 'John Lennon',
      url: 'http://somesite.com',
      twitter: '@johnlennon'
    }
    // ...
  },
  'post2.html': {
    title: 'Post 2',
    author: {
      name: 'Paul McCartney',
      url: 'http://somesite.com',
      twitter: '@paulmccartney'
    }
    // ...
  }
}

Installation

Install it via NPM:

$ npm install metalsmith-author

Usage

const metalsmith = require('metalsmith');
const collections = require('metalsmith-collections');
const author = require('metalsmith-author');

metalsmith('working/dir')
  .use(collections({posts: '*.html'}))
  .use(author({ // make sure it comes after collections
    collection: 'posts',
    authors: {
      john: {
        name: 'John Lennon',
        url: 'http://somesite.com',
        twitter: '@johnlennon'
      },
      paul: {
        name: 'Paul McCartney',
        url: 'http://somesite.com',
        twitter: '@paulmccartney'
      }
    }
  }))

Remember to the set the author identifier property in collection files with one of these you passed to the plugin.

Render a single file author

Now you can just use something like {{ author.name }} (or whatever you want) to render the file (post) author's name in your post template.

Render all authors

Complementarily, you can access all authors globally inside any template as well through the authors variable, i.e. {{ authors.john.name }}.

Options

collection string

Required. Name of the configured metalsmith-collection to process files from (see the usage example above).

authors object

Optional. Object containing all authors' metadata. It can contain whatever you want. Despite it isn't a required option, you must provide it in order to input new info in processed files (see the usage example above).

metadataFrom string

Optional. Specify where the plugin can take the authors' metadata from. It looks for data in metalsmith's global metadata scope. You can also pass a path, like 'some.key'.

Contributing

Fork this repo, install the dependecies, run the tests, submit a pull request.

$ cd metalsmith-author
$ npm install
$ grunt test

No grunt? No problem

You can run any grunt task just with npm scripts: npm run grunt -- <taskname>. The following command is the same as grunt test:

$ npm run grunt -- test

Automated workflow

You can keep the tests running automaticaly every time you make any change to the code with dev workflow:

$ grunt dev
$ npm run grunt -- dev

Always implement tests for whatever you're adding to the project. Thanks!

License

MIT © Almir Filho