ctrl-content-manager
An abstraction around contentful.
Installation
Yarn is recommended for installation.
$ yarn add ctrl-content-manager
But you can still use npm:
$ npm install --save ctrl-content-manager
Usage
const _ = require('lodash')
const CtrlContentManager = require('ctrl-content-manager')
const cm = new CtrlContentManager({
accessTokens: {
production: 'contentful_production_token'
, preview: 'contentful_preview_token'
}
, fetchInterval: 60 * 60 * 1000
, isProduction: process.env.NODE_ENV === 'production'
, space: 'contentful_space_id'
, parsing: {
keyed: {
tags: 'title'
, authors: 'name'
}
, singles: [
'globalElements'
, 'blogPostElements'
]
}
})
cm.startFetchInterval()
http.get('/blog/?slug', (request, reply) {
const slug = request.params.slug
const blogPost = cm.find('blogPosts', {slug})
if (!blogPost) {
return reply('404-template', {
suggestedBlogs: _.sampleSize(cm.get('blogPosts'), 3)
})
}
const blogPostElements = cm.get('blogPostElements')
const titleSuffix = cm.get('globalElements.titleSuffix')
const otherTags = _.omit(cm.get('tags'), _.map(blogPost.tags, 'title'))
const otherAuthors = _.omit(cm.get('authors'), blogPost.author.name)
return reply('blog-post-template', {
blogPost
, blogPostElements
, titleSuffix
, otherTags
, otherAuthors
})
})
Methods
Full documentation to come soon!
License
Copyright (c) 2016 Martin Experiments LLC
MIT (https://www.opensource.org/licenses/MIT)