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

minima

v0.0.3

Published

A blog engine where you can do what you want

Downloads

7

Readme

Minima

The blog engine where you can do what you want

What?

With the surge of text editors and cloud storage why can't I use any of them to write my blog? Why do I have to use some crappy HTML5 editor when I have native apps that give me rich features? Why do I have to use your crappy native app to write my blog? Why can't I use plain text markdown? Why can't I use WYSIWYG? How can I trust your document storage to keep my blogs? Maybe I'll keep them in Dropbox, Google Drive, Evernote, etc as a backup.

These are the questions I've heard and asked over and over again. Almost every time I find a cool new blog engine I go through this. I always feel tied to whatever editor and storage the blog engine decides on.

minima |ˈminəmə| plural form of minimum.

Minima aims to be a middle man and a host. The purpose is to let you write however you please. You can write your blogs in anything you want (Evernote, Dropbox, Google Docs). This also opens the door to any text editor you wish. Once you decide how you want to write, find a loader and tell Minima to use it. Can't find one for your middleware? Then write one!

Choosing a Loader

Once you decide on an article loader, mark it as an npm dependency and tell minima to use it. Do this by modifying the app.config.js file.

{
  //...

  articleMiddleware: 'minima-evernote-loader',

  //...

  'minima-evernote-loader': {
      notebookName: 'minima',
      key: '...',
      secret: '...',
      sandbox: false
  },

  //...
}

How to Write Middleware

Examples:

  1. https://github.com/brettof86/minima-evernote-loader
  2. https://github.com/brettof86/minima-dropbox-loader

How you write your middleware is irrelevant. The only requirements is that you exports an Object (which will be constructed) and expose certain methods for Minima to use. They are as follows:

  1. connect
  2. connectCallback
  3. listPages
  4. getPageContent

Constructor

Your constructor will be passed three things: logger, config, and store.

Signature: function(logger, config, store) {}

  1. logger - an instance of log4js. It is highly recommended that you use this so that debugging issues doesn't become an issue in the future. All logging methods use util.format because readability.
  2. config - object containing the configuration values for your middleware. Also contains callbackUrl for oauth purposes (which will directly invoke the connectCallback method of your middleware.
  3. store - a key/value store which exposes get(key), set(key, value), and remove(key). It is sandboxed from the rest of the application. Use this sparingly (i.e. storing oauth tokens).

connect

Signature: function(req, res, next){}

Called from the '/admin/connect' page. When the user first loads the application they will be directed to connect their middleware. Middleware.connect is called directly from Express. You have full access to the request and response objects. This might change in the future. In this method you should perform your typical oauth functions, passing the config.callbackUrl so that the oauth provider invokes your middleware's connectCallback function.

connectCallback

Signature: function(req, res, next) {}

This is only necessary if you're authorization process requires a callback URL (i.e oauth). In your connect method you can use the config.callbackUrl to give to your oauth provider. Once the oauth passes the provider should invoke this method. Once you've completed the oauth you should persist the authentication into the store and attempt to retrieve it in your constructor.

listPages

Signature: function(callback) {}

  1. callback: a Callback function to be invoked with each page. When invoking the callback you should pass one single object which should match the following:
{
    identifier: // some unique identifier that your middleware can identify this note by,
    title: // the title to be shown on the page
    slug: // the slug to use in the url for this page (will default to [slug][] the title)
    createDate: // Date (defaults to Date.now)
    modifiedDate: // Date (defaults to Date.now) and used to determine if an update is needed
    tags: // tags for the page
    unpublished: // boolean - passed if the article should be unpublished
}

getPageContent

Only called when a page detects an update. This prevents Minima from having to load every page each time the application starts. Sometimes it is not possible for your middleware to work this way (e.g. Dropbox). If this is the case then you should cache the pages content when you receive it during the listPages method and fetch that cached content during getPageContent.

Signature: function(note) {}

  1. note - an object containing everything received from listPages

Returns:

  1. Q.promise

Promise should be resolved with the FULL NOTE. Not just the content. This is necessary because the receiving end of this callback is stateless and does not retain each call it makes to getPageContent. When the promise is resolved it will depend on the Note object in it's entirety.

To see implementations of middleware see the examples listed above.