/kodex

a simple library for sorting and filtering through parsed front-matter files

Primary LanguageJavaScript

Kodex

Kodex walks a directory of markdown files, parses them as front-matter, and generates a simple API for accessing those files.

The main focus is to provide sorting and filtering methods for (but not limited to) blog posts. The service can be used in any number of ways. Wrap a RESTful API around it, or utilize it during static generation (plays nicely with Nuxt.js).

Features:

  • Recursively walks through a given directory
  • Parses all markdown (.md) files with front-matter
  • Generates a service for acquiring data from the collection

Planned:

  • Pluggable support for other markup languages
  • Custom attributes
  • Sorting and filtering by custom attributes

File Format

./posts/hello-world.md:

---
title: Hello, world!
date: 4/20/2017
tags: [javascript, kodex.js]
---

This is an example markdown.

Currently, the date attribute is the only required front-matter attribute. title and tags are optional attributes.


Usage

let Kodex = require('kodex')
let postKodex = new Kodex(path.join(__dirname, 'posts'))

var helloWorldEntry = postKodex.get('hello-world')

Docs

.get(filename)

Gets an entry by filename

Returns: Object

.search(term)

Searches for files where filename contains term

Returns: Array

.recent(count)

Gets n most recent entries (sorted by date descending)

Returns: Array

.allTags()

Scrapes all tags from files

Returns: Array

.findWithTag(tagName)

Gets all files that have the specified tag

Returns: Array


Caveats:

  • Directory cannot contain extensionless files (matches folders based on lack of period, confuses for folder)