New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

eleventy-plugin-cloudcannon

Package Overview
Dependencies
Maintainers
6
Versions
40
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

eleventy-plugin-cloudcannon

Eleventy plugin to create CloudCannon editor details

  • 0.0.20
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
1K
increased by5.56%
Maintainers
6
Weekly downloads
 
Created
Source

Eleventy Plugin CloudCannon

An Eleventy (11ty) plugin that creates CloudCannon build information.

version badge downloads badge



Installation

CloudCannon automatically injects this plugin before your site is built. This means you'll get new features and fixes as they are released. You can disable this if you need to maintain the plugin versioning manually.

If you use custom paths for your site, you'll need to pass them to the plugin, either one of:

  • Setting eleventyConfig.cloudcannonOptions
  • Returning from .eleventy.js
module.exports = function (eleventyConfig) {
  const config = {
    pathPrefix: '/',
    dir: {
      input: '.',
      data: '_my-custom-data',
      layouts: '_layouts',
      includes: '_my-includes'
    },
    markdownItOptions: {
      html: true
    }
  };

  // Plugin looks here for plugin options
  eleventyConfig.cloudcannonOptions = config;

  // Plugin also looks at what you return for plugin options
  return config;
};

If you set your custom input path with the --input CLI option, CloudCannon reads it automatically.

Plugin options

The options are either set on the eleventyConfig.cloudcannonOptions key within your .eleventy.js file, or passed to the addPlugin call as a second argument if you are adding the plugin manually.

Should match the return value from your .eleventy.js (https://www.11ty.dev/docs/config/) file.

pathPrefix

The pathPrefix setting your site uses. Defaults to: '/'

dir

Custom paths your site uses. Defaults to:

{
  input: '.',
  data: '_data',
  includes: '_includes',
  layouts: '_includes'
}
markdownItOptions

Options passed to markdown-it. Defaults to { html: true }.

Site configuration

This plugin reads data from cloudcannon if available (i.e. _data/cloudcannon.json or _data/cloudcannon.js).

Details on each property here are listed in the relevant parts of the CloudCannon documentation.

The following is an empty template as an example.

{
  "timezone": "",
  "collections": {
    "projects": {
      "path": "",
      "name": "",
      "title": "",
      "output": false,
      "_sort_key": "",
      "_subtext_key": "",
      "_image_key": "",
      "_image_size": "",
      "_singular_name": "",
      "_singular_key": "",
      "_disable_add": false,
      "_icon": "",
      "_enabled_editors": null,
      "_add_options": []
    }
  },
  "_comments": {},
  "_options": {},
  "_editor": {},
  "_collection_groups": null,
  "_source_editor": {},
  "_array_structures": {},
  "_enabled_editors": null,
  "_select_data": {}
}

Manual installation

Manually managing this plugin means you'll have to upgrade when new versions are released. You can also follow these steps to try it or debug locally.

Manual installation steps

Start by enabling the "Manage eleventy-plugin-cloudcannon plugin manually" option in CloudCannon for your site in Site Settings / Build.

npm install eleventy-plugin-cloudcannon --save

Add the following addPlugin call to the module.exports function in your .eleventy.js file:

const pluginCloudCannon = require('eleventy-plugin-cloudcannon');

module.exports = function (eleventyConfig) {
  eleventyConfig.addPlugin(pluginCloudCannon);
};

If you use custom paths for your site, pass them to the plugin as well:

const pluginCloudCannon = require('eleventy-plugin-cloudcannon');

module.exports = function (eleventyConfig) {
  const config = {
    pathPrefix: '/',
    dir: {
      input: '.',
      data: '_my-custom-data',
      layouts: '_layouts',
      includes: '_my-includes'
    }
  };

  eleventyConfig.addPlugin(pluginCloudCannon, config);
  return config;
};

Disabling the automatic injection prevents the info.json template being copied. In order to retain this, add the following to your .cloudcannon/prebuild build hook:

rm -rf cloudcannon
cp -R node_modules/eleventy-plugin-cloudcannon/cloudcannon .

License

MIT

Keywords

FAQs

Package last updated on 25 Oct 2021

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc