Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/teekay/eleventy-plugin-jcomments

A plugin to fetch comments for your website from JComments
https://github.com/teekay/eleventy-plugin-jcomments

Last synced: about 1 month ago
JSON representation

A plugin to fetch comments for your website from JComments

Awesome Lists containing this project

README

        

# eleventy-plugin-jcomments

A plugin for integrating the JComments headless commenting CMS to Eleventy.

## Pre-requisites

Spin up your own instance of the [JComments API](https://github.com/teekay/jcomments) or try it on the [free "playground" instance](https://jcomm-staging-eus-webapp.azurewebsites.net) first.

To use this plugin, you will need to store the URL to your JComments instance (https://example.com/api/comments) and your API key. You will find the latter on your JComments dashboard. A good way to store these is in a `.env` file.

## Installation

`npm install eleventy-plugin-jcomments`

### Configuration

Add the following to your Eleventy config file (most likely `.eleventy.js`):

```javascript
const jcommentsPlugin = require('eleventy-plugin-jcomments');

module.exports = function(eleventyConfig) {
eleventyConfig.addPlugin(jcommentsPlugin, {
apiUrl: '', // URL to the JComments API endpoint, ends with '/api/comments'
apiToken: '', // API key,
format: '', // 'html' or 'text' or 'markdown' - this controls the level of formatting and sanitization that JComments will perform before returning your comments. Note that 'html' is safe to use. JComments returns it sanitized.
dateFormat: '', // how the timestamp of each comment should be rendered, e.g. 'MMM D, YYYY HH:MM' - see https://momentjs.com/docs/#/displaying/format/ for details
pathToCache: '/path/to/comments.json', // absolute path on the local filesystem where the downloaded comments will be persisted
useCached: false, // you can use 'true' in development to avoid needless roundtrips to the JComments API
noFollow: false // or true - whether to append ' rel="nofollow"` to the link to a commenter's website
});
};
```

## Usage

The plugin will hook into the `eleventy.before` event and download all your comments before the build starts. It will place them in a local cache (controlled by the `pathToCache` option).

The easiest way to use the plugin is to use the exported Nunjucks shortcode `commentsForPage`. It will render all comments for a given page as HTML. It will look like this:

```html






What an awesome article! I really enjoyed reading this! Here are my 2 cents: ...





...

```

If you want more granular control over how the comments should be rendered, use the exported functions `commentsForPage` and `commentsRendered` and write your own shortcode.

Once your site builds, all your existing comments will be embedded in the rendered pages, so when a visitor loads the page, there won't be any delay.

You can (and probably should) fetch newer comments with JavaScript. To do that, you will have to write your own front-end code at the moment.

Example (incomplete):

```javascript
async function latestComments() {
let commentSection = document.querySelector('.comments');
let comments = Array.from(document.querySelectorAll('.comment'));
let lastComment = comments[comments.length - 1];
let lastCommentId = lastComment ? lastComment.getAttribute('data-id') : '';
let pageUrl = '{{ metadata.url }}{{ page.url }}';
// TODO this can fail, what then?
let response = await fetch(`{{ comments.API_URL }}?url=${encodeURIComponent(pageUrl)}&since=${lastCommentId}`, {
headers: {
'Content-Type': 'application/json',
'Authorization': 'Bearer {{ comments.API_TOKEN }}'
}
});
let newComments = await response.json();
newComments.forEach(c => {
// render each comment
});
}
```

## Adding a comment form

You can write your own HTML form for readers to post new comments.

Example:

```html











Post your comment

```

JComments API will redirect the commenter back to the page, where your JavaScript will fetch the new comment.

## Feedback

All feedback is very welcome! You can raise bugs, issues, questions, and feature requests in the Issues section.